75 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			OCaml
		
	
	
	
	
	
			
		
		
	
	
			75 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			OCaml
		
	
	
	
	
	
(*
 | 
						|
 * Copyright (c) 1997-1999 Massachusetts Institute of Technology
 | 
						|
 * Copyright (c) 2003, 2007-14 Matteo Frigo
 | 
						|
 * Copyright (c) 2003, 2007-14 Massachusetts Institute of Technology
 | 
						|
 *
 | 
						|
 * This program is free software; you can redistribute it and/or modify
 | 
						|
 * it under the terms of the GNU General Public License as published by
 | 
						|
 * the Free Software Foundation; either version 2 of the License, or
 | 
						|
 * (at your option) any later version.
 | 
						|
 *
 | 
						|
 * This program is distributed in the hope that it will be useful,
 | 
						|
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
						|
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
						|
 * GNU General Public License for more details.
 | 
						|
 *
 | 
						|
 * You should have received a copy of the GNU General Public License
 | 
						|
 * along with this program; if not, write to the Free Software
 | 
						|
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
 | 
						|
 *
 | 
						|
 *)
 | 
						|
 | 
						|
type stride = 
 | 
						|
  | SVar of string
 | 
						|
  | SConst of string
 | 
						|
  | SInteger of int
 | 
						|
  | SNeg of stride
 | 
						|
val array_subscript : string -> stride -> int -> string
 | 
						|
val varray_subscript : string -> stride -> stride -> int -> int -> string
 | 
						|
 | 
						|
val real_of : string -> string
 | 
						|
val imag_of : string -> string
 | 
						|
 | 
						|
val realtype : string
 | 
						|
val realtypep : string
 | 
						|
val constrealtype : string
 | 
						|
val constrealtypep : string
 | 
						|
val stridetype : string
 | 
						|
 | 
						|
type c_decl = 
 | 
						|
  | Decl of string * string
 | 
						|
  | Tdecl of string                (* arbitrary text declaration *)
 | 
						|
 | 
						|
and c_ast =
 | 
						|
  | Asch of Annotate.annotated_schedule
 | 
						|
  | Simd_leavefun
 | 
						|
  | Return of c_ast
 | 
						|
  | For of c_ast * c_ast * c_ast * c_ast
 | 
						|
  | If of c_ast * c_ast
 | 
						|
  | Block of (c_decl list) * (c_ast list)
 | 
						|
  | Binop of string * c_ast * c_ast
 | 
						|
  | Expr_assign of c_ast * c_ast
 | 
						|
  | Stmt_assign of c_ast * c_ast
 | 
						|
  | Comma of c_ast * c_ast
 | 
						|
  | Integer of int
 | 
						|
  | CVar of string
 | 
						|
  | CCall of string * c_ast
 | 
						|
  | CPlus of c_ast list
 | 
						|
  | ITimes of c_ast * c_ast
 | 
						|
  | CUminus of c_ast
 | 
						|
and c_fcn = | Fcn of string * string * c_decl list * c_ast
 | 
						|
 | 
						|
val unparse_expr : Expr.expr -> string
 | 
						|
val unparse_assignment : Expr.assignment -> string
 | 
						|
val unparse_annotated : bool -> Annotate.annotated_schedule -> string
 | 
						|
val unparse_decl : c_decl -> string
 | 
						|
val unparse_ast : c_ast -> string
 | 
						|
val unparse_function : c_fcn -> string
 | 
						|
 | 
						|
val flops_of : c_fcn -> string
 | 
						|
val print_cost : c_fcn -> string
 | 
						|
 | 
						|
val ast_to_expr_list : c_ast -> Expr.expr list
 | 
						|
val extract_constants : c_ast -> c_decl list
 | 
						|
val ctimes : (c_ast * c_ast) -> c_ast
 |