cannam@95
|
1 (*
|
cannam@95
|
2 * Copyright (c) 1997-1999 Massachusetts Institute of Technology
|
cannam@95
|
3 * Copyright (c) 2003, 2007-11 Matteo Frigo
|
cannam@95
|
4 * Copyright (c) 2003, 2007-11 Massachusetts Institute of Technology
|
cannam@95
|
5 *
|
cannam@95
|
6 * This program is free software; you can redistribute it and/or modify
|
cannam@95
|
7 * it under the terms of the GNU General Public License as published by
|
cannam@95
|
8 * the Free Software Foundation; either version 2 of the License, or
|
cannam@95
|
9 * (at your option) any later version.
|
cannam@95
|
10 *
|
cannam@95
|
11 * This program is distributed in the hope that it will be useful,
|
cannam@95
|
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
|
cannam@95
|
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
cannam@95
|
14 * GNU General Public License for more details.
|
cannam@95
|
15 *
|
cannam@95
|
16 * You should have received a copy of the GNU General Public License
|
cannam@95
|
17 * along with this program; if not, write to the Free Software
|
cannam@95
|
18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
cannam@95
|
19 *
|
cannam@95
|
20 *)
|
cannam@95
|
21
|
cannam@95
|
22 (* magic parameters *)
|
cannam@95
|
23 let verbose = ref false
|
cannam@95
|
24 let vneg = ref false
|
cannam@95
|
25 let karatsuba_min = ref 15
|
cannam@95
|
26 let karatsuba_variant = ref 2
|
cannam@95
|
27 let circular_min = ref 64
|
cannam@95
|
28 let rader_min = ref 13
|
cannam@95
|
29 let rader_list = ref [5]
|
cannam@95
|
30 let alternate_convolution = ref 17
|
cannam@95
|
31 let threemult = ref false
|
cannam@95
|
32 let inline_single = ref true
|
cannam@95
|
33 let inline_loads = ref false
|
cannam@95
|
34 let inline_loads_constants = ref false
|
cannam@95
|
35 let inline_constants = ref true
|
cannam@95
|
36 let trivial_stores = ref false
|
cannam@95
|
37 let locations_are_special = ref false
|
cannam@95
|
38 let strength_reduce_mul = ref false
|
cannam@95
|
39 let number_of_variables = ref 4
|
cannam@95
|
40 let codelet_name = ref "unnamed"
|
cannam@95
|
41 let randomized_cse = ref true
|
cannam@95
|
42 let dif_split_radix = ref false
|
cannam@95
|
43 let enable_fma = ref false
|
cannam@95
|
44 let deep_collect_depth = ref 1
|
cannam@95
|
45 let schedule_type = ref 0
|
cannam@95
|
46 let compact = ref false
|
cannam@95
|
47 let dag_dump_file = ref ""
|
cannam@95
|
48 let alist_dump_file = ref ""
|
cannam@95
|
49 let asched_dump_file = ref ""
|
cannam@95
|
50 let lisp_syntax = ref false
|
cannam@95
|
51 let network_transposition = ref true
|
cannam@95
|
52 let inklude = ref ""
|
cannam@95
|
53 let generic_arith = ref false
|
cannam@95
|
54 let reorder_insns = ref false
|
cannam@95
|
55 let reorder_loads = ref false
|
cannam@95
|
56 let reorder_stores = ref false
|
cannam@95
|
57 let precompute_twiddles = ref false
|
cannam@95
|
58 let newsplit = ref false
|
cannam@95
|
59 let standalone = ref false
|
cannam@95
|
60 let pipeline_latency = ref 0
|
cannam@95
|
61 let schedule_for_pipeline = ref false
|
cannam@95
|
62 let generate_bytw = ref true
|
cannam@95
|
63
|
cannam@95
|
64 (* command-line parser for magic parameters *)
|
cannam@95
|
65 let undocumented = " Undocumented voodoo parameter"
|
cannam@95
|
66
|
cannam@95
|
67 let set_bool var = Arg.Unit (fun () -> var := true)
|
cannam@95
|
68 let unset_bool var = Arg.Unit (fun () -> var := false)
|
cannam@95
|
69 let set_int var = Arg.Int(fun i -> var := i)
|
cannam@95
|
70 let set_string var = Arg.String(fun s -> var := s)
|
cannam@95
|
71
|
cannam@95
|
72 let speclist = [
|
cannam@95
|
73 "-name", set_string codelet_name, " set codelet name";
|
cannam@95
|
74 "-standalone", set_bool standalone, " standalone codelet (no desc)";
|
cannam@95
|
75 "-include", set_string inklude, undocumented;
|
cannam@95
|
76
|
cannam@95
|
77 "-verbose", set_bool verbose, " Enable verbose logging messages to stderr";
|
cannam@95
|
78
|
cannam@95
|
79 "-rader-min", set_int rader_min,
|
cannam@95
|
80 "<n> : Use Rader's algorithm for prime sizes >= <n>";
|
cannam@95
|
81
|
cannam@95
|
82 "-threemult", set_bool threemult,
|
cannam@95
|
83 " Use 3-multiply complex multiplications";
|
cannam@95
|
84
|
cannam@95
|
85 "-karatsuba-min", set_int karatsuba_min, undocumented;
|
cannam@95
|
86 "-karatsuba-variant", set_int karatsuba_variant, undocumented;
|
cannam@95
|
87 "-circular-min", set_int circular_min, undocumented;
|
cannam@95
|
88
|
cannam@95
|
89 "-compact", set_bool compact,
|
cannam@95
|
90 " Mangle variable names to reduce size of source code";
|
cannam@95
|
91 "-no-compact", unset_bool compact,
|
cannam@95
|
92 " Disable -compact";
|
cannam@95
|
93
|
cannam@95
|
94 "-dump-dag", set_string dag_dump_file, undocumented;
|
cannam@95
|
95 "-dump-alist", set_string alist_dump_file, undocumented;
|
cannam@95
|
96 "-dump-asched", set_string asched_dump_file, undocumented;
|
cannam@95
|
97 "-lisp-syntax", set_bool lisp_syntax, undocumented;
|
cannam@95
|
98
|
cannam@95
|
99 "-alternate-convolution", set_int alternate_convolution, undocumented;
|
cannam@95
|
100 "-deep-collect-depth", set_int deep_collect_depth, undocumented;
|
cannam@95
|
101 "-schedule-type", set_int schedule_type, undocumented;
|
cannam@95
|
102 "-pipeline-latency", set_int pipeline_latency, undocumented;
|
cannam@95
|
103 "-schedule-for-pipeline", set_bool schedule_for_pipeline, undocumented;
|
cannam@95
|
104
|
cannam@95
|
105 "-dif-split-radix", set_bool dif_split_radix, undocumented;
|
cannam@95
|
106 "-dit-split-radix", unset_bool dif_split_radix, undocumented;
|
cannam@95
|
107
|
cannam@95
|
108 "-generic-arith", set_bool generic_arith, undocumented;
|
cannam@95
|
109 "-no-generic-arith", unset_bool generic_arith, undocumented;
|
cannam@95
|
110
|
cannam@95
|
111 "-precompute-twiddles", set_bool precompute_twiddles, undocumented;
|
cannam@95
|
112 "-no-precompute-twiddles", unset_bool precompute_twiddles, undocumented;
|
cannam@95
|
113
|
cannam@95
|
114 "-inline-single", set_bool inline_single, undocumented;
|
cannam@95
|
115 "-no-inline-single", unset_bool inline_single, undocumented;
|
cannam@95
|
116
|
cannam@95
|
117 "-inline-loads", set_bool inline_loads, undocumented;
|
cannam@95
|
118 "-no-inline-loads", unset_bool inline_loads, undocumented;
|
cannam@95
|
119
|
cannam@95
|
120 "-inline-loads-constants", set_bool inline_loads_constants, undocumented;
|
cannam@95
|
121 "-no-inline-loads-constants",
|
cannam@95
|
122 unset_bool inline_loads_constants, undocumented;
|
cannam@95
|
123
|
cannam@95
|
124 "-inline-constants", set_bool inline_constants, undocumented;
|
cannam@95
|
125 "-no-inline-constants", unset_bool inline_constants, undocumented;
|
cannam@95
|
126
|
cannam@95
|
127 "-trivial-stores", set_bool trivial_stores, undocumented;
|
cannam@95
|
128 "-no-trivial-stores", unset_bool trivial_stores, undocumented;
|
cannam@95
|
129
|
cannam@95
|
130 "-locations-are-special", set_bool locations_are_special, undocumented;
|
cannam@95
|
131 "-no-locations-are-special", unset_bool locations_are_special, undocumented;
|
cannam@95
|
132
|
cannam@95
|
133 "-randomized-cse", set_bool randomized_cse, undocumented;
|
cannam@95
|
134 "-no-randomized-cse", unset_bool randomized_cse, undocumented;
|
cannam@95
|
135
|
cannam@95
|
136 "-network-transposition", set_bool network_transposition, undocumented;
|
cannam@95
|
137 "-no-network-transposition", unset_bool network_transposition, undocumented;
|
cannam@95
|
138
|
cannam@95
|
139 "-reorder-insns", set_bool reorder_insns, undocumented;
|
cannam@95
|
140 "-no-reorder-insns", unset_bool reorder_insns, undocumented;
|
cannam@95
|
141 "-reorder-loads", set_bool reorder_loads, undocumented;
|
cannam@95
|
142 "-no-reorder-loads", unset_bool reorder_loads, undocumented;
|
cannam@95
|
143 "-reorder-stores", set_bool reorder_stores, undocumented;
|
cannam@95
|
144 "-no-reorder-stores", unset_bool reorder_stores, undocumented;
|
cannam@95
|
145
|
cannam@95
|
146 "-newsplit", set_bool newsplit, undocumented;
|
cannam@95
|
147
|
cannam@95
|
148 "-vneg", set_bool vneg, undocumented;
|
cannam@95
|
149 "-fma", set_bool enable_fma, undocumented;
|
cannam@95
|
150 "-no-fma", unset_bool enable_fma, undocumented;
|
cannam@95
|
151
|
cannam@95
|
152 "-variables", set_int number_of_variables, undocumented;
|
cannam@95
|
153
|
cannam@95
|
154 "-strength-reduce-mul", set_bool strength_reduce_mul, undocumented;
|
cannam@95
|
155 "-no-strength-reduce-mul", unset_bool strength_reduce_mul, undocumented;
|
cannam@95
|
156
|
cannam@95
|
157 "-generate-bytw", set_bool generate_bytw, undocumented;
|
cannam@95
|
158 "-no-generate-bytw", unset_bool generate_bytw, undocumented;
|
cannam@95
|
159 ]
|
cannam@95
|
160
|
cannam@95
|
161
|