blob: 91477f9abd924ba054cbd82a598b1a88dbf97ef4 [file] [log] [blame]
Steve Blocka7e24c12009-10-30 11:49:00 +00001// Copyright 2008 the V8 project authors. All rights reserved.
2// Redistribution and use in source and binary forms, with or without
3// modification, are permitted provided that the following conditions are
4// met:
5//
6// * Redistributions of source code must retain the above copyright
7// notice, this list of conditions and the following disclaimer.
8// * Redistributions in binary form must reproduce the above
9// copyright notice, this list of conditions and the following
10// disclaimer in the documentation and/or other materials provided
11// with the distribution.
12// * Neither the name of Google Inc. nor the names of its
13// contributors may be used to endorse or promote products derived
14// from this software without specific prior written permission.
15//
16// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27
28// This file defines all of the flags. It is separated into different section,
29// for Debug, Release, Logging and Profiling, etc. To add a new flag, find the
30// correct section, and use one of the DEFINE_ macros, without a trailing ';'.
31//
32// This include does not have a guard, because it is a template-style include,
33// which can be included multiple times in different modes. It expects to have
34// a mode defined before it's included. The modes are FLAG_MODE_... below:
35
36// We want to declare the names of the variables for the header file. Normally
37// this will just be an extern declaration, but for a readonly flag we let the
38// compiler make better optimizations by giving it the value.
39#if defined(FLAG_MODE_DECLARE)
40#define FLAG_FULL(ftype, ctype, nam, def, cmt) \
41 extern ctype FLAG_##nam;
42#define FLAG_READONLY(ftype, ctype, nam, def, cmt) \
43 static ctype const FLAG_##nam = def;
44
45// We want to supply the actual storage and value for the flag variable in the
46// .cc file. We only do this for writable flags.
47#elif defined(FLAG_MODE_DEFINE)
48#define FLAG_FULL(ftype, ctype, nam, def, cmt) \
49 ctype FLAG_##nam = def;
50#define FLAG_READONLY(ftype, ctype, nam, def, cmt)
51
52// We need to define all of our default values so that the Flag structure can
53// access them by pointer. These are just used internally inside of one .cc,
54// for MODE_META, so there is no impact on the flags interface.
55#elif defined(FLAG_MODE_DEFINE_DEFAULTS)
56#define FLAG_FULL(ftype, ctype, nam, def, cmt) \
57 static ctype const FLAGDEFAULT_##nam = def;
58#define FLAG_READONLY(ftype, ctype, nam, def, cmt)
59
60
61// We want to write entries into our meta data table, for internal parsing and
62// printing / etc in the flag parser code. We only do this for writable flags.
63#elif defined(FLAG_MODE_META)
64#define FLAG_FULL(ftype, ctype, nam, def, cmt) \
65 { Flag::TYPE_##ftype, #nam, &FLAG_##nam, &FLAGDEFAULT_##nam, cmt, false },
66#define FLAG_READONLY(ftype, ctype, nam, def, cmt)
67
68#else
69#error No mode supplied when including flags.defs
70#endif
71
72#ifdef FLAG_MODE_DECLARE
73// Structure used to hold a collection of arguments to the JavaScript code.
74struct JSArguments {
75public:
76 JSArguments();
77 JSArguments(int argc, const char** argv);
78 int argc() const;
79 const char** argv();
80 const char*& operator[](int idx);
81 JSArguments& operator=(JSArguments args);
82private:
83 int argc_;
84 const char** argv_;
85};
86#endif
87
88#define DEFINE_bool(nam, def, cmt) FLAG(BOOL, bool, nam, def, cmt)
89#define DEFINE_int(nam, def, cmt) FLAG(INT, int, nam, def, cmt)
90#define DEFINE_float(nam, def, cmt) FLAG(FLOAT, double, nam, def, cmt)
91#define DEFINE_string(nam, def, cmt) FLAG(STRING, const char*, nam, def, cmt)
92#define DEFINE_args(nam, def, cmt) FLAG(ARGS, JSArguments, nam, def, cmt)
93
94//
95// Flags in all modes.
96//
97#define FLAG FLAG_FULL
98
Steve Block3ce2e202009-11-05 08:53:23 +000099// assembler-ia32.cc / assembler-arm.cc / assembler-x64.cc
Steve Blocka7e24c12009-10-30 11:49:00 +0000100DEFINE_bool(debug_code, false,
101 "generate extra code (comments, assertions) for debugging")
102DEFINE_bool(emit_branch_hints, false, "emit branch hints")
Leon Clarkef7060e22010-06-03 12:02:55 +0100103DEFINE_bool(peephole_optimization, true,
104 "perform peephole optimizations in assembly code")
105DEFINE_bool(print_peephole_optimization, false,
106 "print peephole optimizations in assembly code")
Steve Block3ce2e202009-11-05 08:53:23 +0000107DEFINE_bool(enable_sse2, true,
108 "enable use of SSE2 instructions if available")
109DEFINE_bool(enable_sse3, true,
110 "enable use of SSE3 instructions if available")
111DEFINE_bool(enable_cmov, true,
112 "enable use of CMOV instruction if available")
113DEFINE_bool(enable_rdtsc, true,
114 "enable use of RDTSC instruction if available")
115DEFINE_bool(enable_sahf, true,
116 "enable use of SAHF instruction if available (X64 only)")
Steve Blockd0582a62009-12-15 09:54:21 +0000117DEFINE_bool(enable_vfp3, true,
118 "enable use of VFP3 instructions if available (ARM only)")
Andrei Popescu31002712010-02-23 13:46:05 +0000119DEFINE_bool(enable_armv7, true,
120 "enable use of ARMv7 instructions if available (ARM only)")
Steve Blocka7e24c12009-10-30 11:49:00 +0000121
122// bootstrapper.cc
123DEFINE_string(expose_natives_as, NULL, "expose natives in global object")
124DEFINE_string(expose_debug_as, NULL, "expose debug in global object")
Steve Blocka7e24c12009-10-30 11:49:00 +0000125DEFINE_bool(expose_gc, false, "expose gc extension")
126DEFINE_int(stack_trace_limit, 10, "number of stack frames to capture")
Steve Block6ded16b2010-05-10 14:33:55 +0100127DEFINE_bool(disable_native_files, false, "disable builtin natives files")
Steve Blocka7e24c12009-10-30 11:49:00 +0000128
129// builtins-ia32.cc
130DEFINE_bool(inline_new, true, "use fast inline allocation")
131
132// checks.cc
133DEFINE_bool(stack_trace_on_abort, true,
134 "print a stack trace if an assertion failure occurs")
135
136// codegen-ia32.cc / codegen-arm.cc
137DEFINE_bool(trace, false, "trace function calls")
138DEFINE_bool(defer_negation, true, "defer negation operation")
Steve Blocka7e24c12009-10-30 11:49:00 +0000139
140// codegen.cc
141DEFINE_bool(lazy, true, "use lazy compilation")
142DEFINE_bool(debug_info, true, "add debug information to compiled functions")
143
144// compiler.cc
145DEFINE_bool(strict, false, "strict error checking")
146DEFINE_int(min_preparse_length, 1024,
Steve Block3ce2e202009-11-05 08:53:23 +0000147 "minimum length for automatic enable preparsing")
Leon Clarked91b9f72010-01-27 17:25:45 +0000148DEFINE_bool(full_compiler, true, "enable dedicated backend for run-once code")
149DEFINE_bool(fast_compiler, false, "enable speculative optimizing backend")
150DEFINE_bool(always_full_compiler, false,
151 "try to use the dedicated run-once backend for all code")
Steve Blockd0582a62009-12-15 09:54:21 +0000152DEFINE_bool(always_fast_compiler, false,
Leon Clarked91b9f72010-01-27 17:25:45 +0000153 "try to use the speculative optimizing backend for all code")
154DEFINE_bool(trace_bailout, false,
155 "print reasons for falling back to using the classic V8 backend")
Steve Block6ded16b2010-05-10 14:33:55 +0100156DEFINE_bool(safe_int32_compiler, true,
157 "enable optimized side-effect-free int32 expressions.")
158DEFINE_bool(use_flow_graph, false, "perform flow-graph based optimizations")
Steve Blocka7e24c12009-10-30 11:49:00 +0000159
160// compilation-cache.cc
161DEFINE_bool(compilation_cache, true, "enable compilation cache")
162
Steve Block6ded16b2010-05-10 14:33:55 +0100163// data-flow.cc
164DEFINE_bool(loop_peeling, false, "Peel off the first iteration of loops.")
165
Steve Blocka7e24c12009-10-30 11:49:00 +0000166// debug.cc
167DEFINE_bool(remote_debugging, false, "enable remote debugging")
168DEFINE_bool(trace_debug_json, false, "trace debugging JSON request/response")
Steve Blockd0582a62009-12-15 09:54:21 +0000169DEFINE_bool(debugger_auto_break, true,
Steve Blocka7e24c12009-10-30 11:49:00 +0000170 "automatically set the debug break flag when debugger commands are "
Steve Blockd0582a62009-12-15 09:54:21 +0000171 "in the queue")
Steve Block6ded16b2010-05-10 14:33:55 +0100172DEFINE_bool(enable_liveedit, true, "enable liveedit experimental feature")
Steve Blocka7e24c12009-10-30 11:49:00 +0000173
174// frames.cc
175DEFINE_int(max_stack_trace_source_length, 300,
176 "maximum length of function source code printed in a stack trace.")
177
178// heap.cc
Steve Block3ce2e202009-11-05 08:53:23 +0000179DEFINE_int(max_new_space_size, 0, "max size of the new generation")
180DEFINE_int(max_old_space_size, 0, "max size of the old generation")
Steve Blocka7e24c12009-10-30 11:49:00 +0000181DEFINE_bool(gc_global, false, "always perform global GCs")
182DEFINE_int(gc_interval, -1, "garbage collect after <n> allocations")
183DEFINE_bool(trace_gc, false,
184 "print one trace line following each garbage collection")
Leon Clarkef7060e22010-06-03 12:02:55 +0100185DEFINE_bool(trace_gc_nvp, false,
186 "print one detailed trace line in name=value format "
187 "after each garbage collection")
188DEFINE_bool(print_cumulative_gc_stat, false,
189 "print cumulative GC statistics in name=value format on exit")
Steve Blocka7e24c12009-10-30 11:49:00 +0000190DEFINE_bool(trace_gc_verbose, false,
191 "print more details following each garbage collection")
192DEFINE_bool(collect_maps, true,
193 "garbage collect maps from which no objects can be reached")
Ben Murdoch7f4d5bd2010-06-15 11:15:29 +0100194DEFINE_bool(flush_code, false,
195 "flush code that we expect not to use again before full gc")
Steve Blocka7e24c12009-10-30 11:49:00 +0000196
197// v8.cc
198DEFINE_bool(use_idle_notification, true,
199 "Use idle notification to reduce memory footprint.")
200// ic.cc
201DEFINE_bool(use_ic, true, "use inline caching")
202
203// macro-assembler-ia32.cc
204DEFINE_bool(native_code_counters, false,
205 "generate extra code for manipulating stats counters")
206
207// mark-compact.cc
208DEFINE_bool(always_compact, false, "Perform compaction on every full GC")
209DEFINE_bool(never_compact, false,
210 "Never perform compaction on full GC - testing only")
211DEFINE_bool(cleanup_ics_at_gc, true,
212 "Flush inline caches prior to mark compact collection.")
213DEFINE_bool(cleanup_caches_in_maps_at_gc, true,
214 "Flush code caches in maps during mark compact cycle.")
Steve Block6ded16b2010-05-10 14:33:55 +0100215DEFINE_int(random_seed, 0,
216 "Default seed for initializing random generator "
217 "(0, the default, means to use system random).")
Steve Blocka7e24c12009-10-30 11:49:00 +0000218
219DEFINE_bool(canonicalize_object_literal_maps, true,
220 "Canonicalize maps for object literals.")
221
Leon Clarkee46be812010-01-19 14:06:41 +0000222DEFINE_bool(use_big_map_space, true,
223 "Use big map space, but don't compact if it grew too big.")
224
Leon Clarked91b9f72010-01-27 17:25:45 +0000225DEFINE_int(max_map_space_pages, MapSpace::kMaxMapPageIndex - 1,
226 "Maximum number of pages in map space which still allows to encode "
227 "forwarding pointers. That's actually a constant, but it's useful "
228 "to control it with a flag for better testing.")
229
Steve Blocka7e24c12009-10-30 11:49:00 +0000230// mksnapshot.cc
231DEFINE_bool(h, false, "print this message")
Steve Blockd0582a62009-12-15 09:54:21 +0000232DEFINE_bool(new_snapshot, true, "use new snapshot implementation")
Steve Blocka7e24c12009-10-30 11:49:00 +0000233
234// parser.cc
235DEFINE_bool(allow_natives_syntax, false, "allow natives syntax")
236
237// rewriter.cc
238DEFINE_bool(optimize_ast, true, "optimize the ast")
239
Andrei Popescu31002712010-02-23 13:46:05 +0000240// simulator-arm.cc and simulator-mips.cc
Steve Block6ded16b2010-05-10 14:33:55 +0100241DEFINE_bool(trace_sim, false, "Trace simulator execution")
242DEFINE_bool(check_icache, false, "Check icache flushes in ARM simulator")
Steve Blocka7e24c12009-10-30 11:49:00 +0000243DEFINE_int(stop_sim_at, 0, "Simulator stop after x number of instructions")
Steve Block6ded16b2010-05-10 14:33:55 +0100244DEFINE_int(sim_stack_alignment, 8,
245 "Stack alingment in bytes in simulator (4 or 8, 8 is default)")
Steve Blocka7e24c12009-10-30 11:49:00 +0000246
247// top.cc
248DEFINE_bool(trace_exception, false,
249 "print stack trace when throwing exceptions")
250DEFINE_bool(preallocate_message_memory, false,
251 "preallocate some memory to build stack traces.")
252
Steve Blocka7e24c12009-10-30 11:49:00 +0000253// v8.cc
254DEFINE_bool(preemption, false,
255 "activate a 100ms timer that switches between V8 threads")
256
257// Regexp
258DEFINE_bool(trace_regexps, false, "trace regexp execution")
259DEFINE_bool(regexp_optimization, true, "generate optimized regexp code")
Leon Clarkee46be812010-01-19 14:06:41 +0000260DEFINE_bool(regexp_entry_native, true, "use native code to enter regexp")
Steve Blocka7e24c12009-10-30 11:49:00 +0000261
262// Testing flags test/cctest/test-{flags,api,serialization}.cc
263DEFINE_bool(testing_bool_flag, true, "testing_bool_flag")
264DEFINE_int(testing_int_flag, 13, "testing_int_flag")
265DEFINE_float(testing_float_flag, 2.5, "float-flag")
266DEFINE_string(testing_string_flag, "Hello, world!", "string-flag")
267DEFINE_int(testing_prng_seed, 42, "Seed used for threading test randomness")
268#ifdef WIN32
269DEFINE_string(testing_serialization_file, "C:\\Windows\\Temp\\serdes",
270 "file in which to testing_serialize heap")
271#else
272DEFINE_string(testing_serialization_file, "/tmp/serdes",
273 "file in which to serialize heap")
274#endif
275
276//
277// Dev shell flags
278//
279
280DEFINE_bool(help, false, "Print usage message, including flags, on console")
281DEFINE_bool(dump_counters, false, "Dump counters on exit")
Ben Murdoch7f4d5bd2010-06-15 11:15:29 +0100282DEFINE_bool(debugger, false, "Enable JavaScript debugger")
Steve Blocka7e24c12009-10-30 11:49:00 +0000283DEFINE_bool(remote_debugger, false, "Connect JavaScript debugger to the "
284 "debugger agent in another process")
285DEFINE_bool(debugger_agent, false, "Enable debugger agent")
286DEFINE_int(debugger_port, 5858, "Port to use for remote debugging")
287DEFINE_string(map_counters, false, "Map counters to a file")
288DEFINE_args(js_arguments, JSArguments(),
289 "Pass all remaining arguments to the script. Alias for \"--\".")
290
291//
292// Debug only flags
293//
294#undef FLAG
295#ifdef DEBUG
296#define FLAG FLAG_FULL
297#else
298#define FLAG FLAG_READONLY
299#endif
300
301// checks.cc
302DEFINE_bool(enable_slow_asserts, false,
303 "enable asserts that are slow to execute")
304
305// codegen-ia32.cc / codegen-arm.cc
306DEFINE_bool(trace_codegen, false,
307 "print name of functions for which code is generated")
308DEFINE_bool(print_source, false, "pretty print source code")
309DEFINE_bool(print_builtin_source, false,
310 "pretty print source code for builtins")
311DEFINE_bool(print_ast, false, "print source AST")
312DEFINE_bool(print_builtin_ast, false, "print source AST for builtins")
Steve Block3ce2e202009-11-05 08:53:23 +0000313DEFINE_bool(print_json_ast, false, "print source AST as JSON")
314DEFINE_bool(print_builtin_json_ast, false,
315 "print source AST for builtins as JSON")
Steve Blocka7e24c12009-10-30 11:49:00 +0000316DEFINE_bool(trace_calls, false, "trace calls")
317DEFINE_bool(trace_builtin_calls, false, "trace builtins calls")
318DEFINE_string(stop_at, "", "function name where to insert a breakpoint")
319
320// compiler.cc
321DEFINE_bool(print_builtin_scopes, false, "print scopes for builtins")
322DEFINE_bool(print_scopes, false, "print scopes")
Leon Clarke4515c472010-02-03 11:58:03 +0000323DEFINE_bool(print_ir, false, "print the AST as seen by the backend")
Steve Block6ded16b2010-05-10 14:33:55 +0100324DEFINE_bool(print_graph_text, false,
325 "print a text representation of the flow graph")
Steve Blocka7e24c12009-10-30 11:49:00 +0000326
327// contexts.cc
328DEFINE_bool(trace_contexts, false, "trace contexts operations")
329
330// heap.cc
331DEFINE_bool(gc_greedy, false, "perform GC prior to some allocations")
332DEFINE_bool(gc_verbose, false, "print stuff during garbage collection")
333DEFINE_bool(heap_stats, false, "report heap statistics before and after GC")
334DEFINE_bool(code_stats, false, "report code statistics after GC")
335DEFINE_bool(verify_heap, false, "verify heap pointers before and after GC")
336DEFINE_bool(print_handles, false, "report handles after GC")
337DEFINE_bool(print_global_handles, false, "report global handles after GC")
Steve Blocka7e24c12009-10-30 11:49:00 +0000338
339// ic.cc
340DEFINE_bool(trace_ic, false, "trace inline cache state transitions")
341
342// objects.cc
343DEFINE_bool(trace_normalization,
344 false,
345 "prints when objects are turned into dictionaries.")
346
347// runtime.cc
348DEFINE_bool(trace_lazy, false, "trace lazy compilation")
349
350// serialize.cc
351DEFINE_bool(debug_serialization, false,
352 "write debug information into the snapshot.")
353
354// spaces.cc
355DEFINE_bool(collect_heap_spill_statistics, false,
356 "report heap spill statistics along with heap_stats "
357 "(requires heap_stats)")
358
359// Regexp
Leon Clarkee46be812010-01-19 14:06:41 +0000360DEFINE_bool(regexp_possessive_quantifier,
361 false,
362 "enable possessive quantifier syntax for testing")
Steve Blocka7e24c12009-10-30 11:49:00 +0000363DEFINE_bool(trace_regexp_bytecodes, false, "trace regexp bytecode execution")
364DEFINE_bool(trace_regexp_assembler,
365 false,
366 "trace regexp macro assembler calls.")
367
368//
369// Logging and profiling only flags
370//
371#undef FLAG
372#ifdef ENABLE_LOGGING_AND_PROFILING
373#define FLAG FLAG_FULL
374#else
375#define FLAG FLAG_READONLY
376#endif
377
378// log.cc
379DEFINE_bool(log, false,
380 "Minimal logging (no API, code, GC, suspect, or handles samples).")
381DEFINE_bool(log_all, false, "Log all events to the log file.")
382DEFINE_bool(log_runtime, false, "Activate runtime system %Log call.")
383DEFINE_bool(log_api, false, "Log API events to the log file.")
384DEFINE_bool(log_code, false,
385 "Log code events to the log file without profiling.")
386DEFINE_bool(log_gc, false,
387 "Log heap samples on garbage collection for the hp2ps tool.")
388DEFINE_bool(log_handles, false, "Log global handle events.")
Leon Clarkee46be812010-01-19 14:06:41 +0000389DEFINE_bool(log_snapshot_positions, false,
390 "log positions of (de)serialized objects in the snapshot.")
Steve Blocka7e24c12009-10-30 11:49:00 +0000391DEFINE_bool(log_state_changes, false, "Log state changes.")
392DEFINE_bool(log_suspect, false, "Log suspect operations.")
Steve Block3ce2e202009-11-05 08:53:23 +0000393DEFINE_bool(log_producers, false, "Log stack traces of JS objects allocations.")
Steve Blocka7e24c12009-10-30 11:49:00 +0000394DEFINE_bool(compress_log, false,
395 "Compress log to save space (makes log less human-readable).")
396DEFINE_bool(prof, false,
397 "Log statistical profiling information (implies --log-code).")
398DEFINE_bool(prof_auto, true,
399 "Used with --prof, starts profiling automatically")
400DEFINE_bool(prof_lazy, false,
401 "Used with --prof, only does sampling and logging"
402 " when profiler is active (implies --noprof_auto).")
Steve Block6ded16b2010-05-10 14:33:55 +0100403DEFINE_bool(prof_browser_mode, true,
404 "Used with --prof, turns on browser-compatible mode for profiling.")
Steve Blocka7e24c12009-10-30 11:49:00 +0000405DEFINE_bool(log_regexp, false, "Log regular expression execution.")
406DEFINE_bool(sliding_state_window, false,
407 "Update sliding state window counters.")
Andrei Popescu402d9372010-02-26 13:31:12 +0000408DEFINE_string(logfile, "v8.log", "Specify the name of the log file.")
Steve Blocka7e24c12009-10-30 11:49:00 +0000409DEFINE_bool(oprofile, false, "Enable JIT agent for OProfile.")
410
411//
412// Heap protection flags
413// Using heap protection requires ENABLE_LOGGING_AND_PROFILING as well.
414//
415#ifdef ENABLE_HEAP_PROTECTION
416#undef FLAG
417#define FLAG FLAG_FULL
418
419DEFINE_bool(protect_heap, false,
420 "Protect/unprotect V8's heap when leaving/entring the VM.")
421
422#endif
423
424//
425// Disassembler only flags
426//
427#undef FLAG
428#ifdef ENABLE_DISASSEMBLER
429#define FLAG FLAG_FULL
430#else
431#define FLAG FLAG_READONLY
432#endif
433
434// code-stubs.cc
435DEFINE_bool(print_code_stubs, false, "print code stubs")
436
437// codegen-ia32.cc / codegen-arm.cc
438DEFINE_bool(print_code, false, "print generated code")
439DEFINE_bool(print_builtin_code, false, "print generated code for builtins")
440
441// Cleanup...
442#undef FLAG_FULL
443#undef FLAG_READONLY
444#undef FLAG
445
446#undef DEFINE_bool
447#undef DEFINE_int
448#undef DEFINE_string
449
450#undef FLAG_MODE_DECLARE
451#undef FLAG_MODE_DEFINE
452#undef FLAG_MODE_DEFINE_DEFAULTS
453#undef FLAG_MODE_META