You've already forked linux-packaging-mono
							
							
		
			
	
	
		
			197 lines
		
	
	
		
			6.6 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
		
		
			
		
	
	
			197 lines
		
	
	
		
			6.6 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
|   | bugpoint - automatic test case reduction tool
 | ||
|  | =============================================
 | ||
|  | 
 | ||
|  | SYNOPSIS
 | ||
|  | --------
 | ||
|  | 
 | ||
|  | **bugpoint** [*options*] [*input LLVM ll/bc files*] [*LLVM passes*] **--args**
 | ||
|  | *program arguments*
 | ||
|  | 
 | ||
|  | DESCRIPTION
 | ||
|  | -----------
 | ||
|  | 
 | ||
|  | **bugpoint** narrows down the source of problems in LLVM tools and passes.  It
 | ||
|  | can be used to debug three types of failures: optimizer crashes, miscompilations
 | ||
|  | by optimizers, or bad native code generation (including problems in the static
 | ||
|  | and JIT compilers).  It aims to reduce large test cases to small, useful ones.
 | ||
|  | For more information on the design and inner workings of **bugpoint**, as well as
 | ||
|  | advice for using bugpoint, see :doc:`/Bugpoint` in the LLVM
 | ||
|  | distribution.
 | ||
|  | 
 | ||
|  | OPTIONS
 | ||
|  | -------
 | ||
|  | 
 | ||
|  | **--additional-so** *library*
 | ||
|  | 
 | ||
|  |  Load the dynamic shared object *library* into the test program whenever it is
 | ||
|  |  run.  This is useful if you are debugging programs which depend on non-LLVM
 | ||
|  |  libraries (such as the X or curses libraries) to run.
 | ||
|  | 
 | ||
|  | **--append-exit-code**\ =\ *{true,false}*
 | ||
|  | 
 | ||
|  |  Append the test programs exit code to the output file so that a change in exit
 | ||
|  |  code is considered a test failure. Defaults to false.
 | ||
|  | 
 | ||
|  | **--args** *program args*
 | ||
|  | 
 | ||
|  |  Pass all arguments specified after **--args** to the test program whenever it runs.
 | ||
|  |  Note that if any of the *program args* start with a "``-``", you should use:
 | ||
|  | 
 | ||
|  |  .. code-block:: bash
 | ||
|  | 
 | ||
|  |       bugpoint [bugpoint args] --args -- [program args]
 | ||
|  | 
 | ||
|  |  The "``--``" right after the **--args** option tells **bugpoint** to consider
 | ||
|  |  any options starting with "``-``" to be part of the **--args** option, not as
 | ||
|  |  options to **bugpoint** itself.
 | ||
|  | 
 | ||
|  | **--tool-args** *tool args*
 | ||
|  | 
 | ||
|  |  Pass all arguments specified after **--tool-args** to the LLVM tool under test
 | ||
|  |  (**llc**, **lli**, etc.) whenever it runs.  You should use this option in the
 | ||
|  |  following way:
 | ||
|  | 
 | ||
|  |  .. code-block:: bash
 | ||
|  | 
 | ||
|  |       bugpoint [bugpoint args] --tool-args -- [tool args]
 | ||
|  | 
 | ||
|  |  The "``--``" right after the **--tool-args** option tells **bugpoint** to
 | ||
|  |  consider any options starting with "``-``" to be part of the **--tool-args**
 | ||
|  |  option, not as options to **bugpoint** itself. (See **--args**, above.)
 | ||
|  | 
 | ||
|  | **--safe-tool-args** *tool args*
 | ||
|  | 
 | ||
|  |  Pass all arguments specified after **--safe-tool-args** to the "safe" execution
 | ||
|  |  tool.
 | ||
|  | 
 | ||
|  | **--gcc-tool-args** *gcc tool args*
 | ||
|  | 
 | ||
|  |  Pass all arguments specified after **--gcc-tool-args** to the invocation of
 | ||
|  |  **gcc**.
 | ||
|  | 
 | ||
|  | **--opt-args** *opt args*
 | ||
|  | 
 | ||
|  |  Pass all arguments specified after **--opt-args** to the invocation of **opt**.
 | ||
|  | 
 | ||
|  | **--disable-{dce,simplifycfg}**
 | ||
|  | 
 | ||
|  |  Do not run the specified passes to clean up and reduce the size of the test
 | ||
|  |  program. By default, **bugpoint** uses these passes internally when attempting to
 | ||
|  |  reduce test programs.  If you're trying to find a bug in one of these passes,
 | ||
|  |  **bugpoint** may crash.
 | ||
|  | 
 | ||
|  | **--enable-valgrind**
 | ||
|  | 
 | ||
|  |  Use valgrind to find faults in the optimization phase. This will allow
 | ||
|  |  bugpoint to find otherwise asymptomatic problems caused by memory
 | ||
|  |  mis-management.
 | ||
|  | 
 | ||
|  | **-find-bugs**
 | ||
|  | 
 | ||
|  |  Continually randomize the specified passes and run them on the test program
 | ||
|  |  until a bug is found or the user kills **bugpoint**.
 | ||
|  | 
 | ||
|  | **-help**
 | ||
|  | 
 | ||
|  |  Print a summary of command line options.
 | ||
|  | 
 | ||
|  | **--input** *filename*
 | ||
|  | 
 | ||
|  |  Open *filename* and redirect the standard input of the test program, whenever
 | ||
|  |  it runs, to come from that file.
 | ||
|  | 
 | ||
|  | **--load** *plugin*
 | ||
|  | 
 | ||
|  |  Load the dynamic object *plugin* into **bugpoint** itself.  This object should
 | ||
|  |  register new optimization passes.  Once loaded, the object will add new command
 | ||
|  |  line options to enable various optimizations.  To see the new complete list of
 | ||
|  |  optimizations, use the **-help** and **--load** options together; for example:
 | ||
|  | 
 | ||
|  | 
 | ||
|  |  .. code-block:: bash
 | ||
|  | 
 | ||
|  |       bugpoint --load myNewPass.so -help
 | ||
|  | 
 | ||
|  | **--mlimit** *megabytes*
 | ||
|  | 
 | ||
|  |  Specifies an upper limit on memory usage of the optimization and codegen. Set
 | ||
|  |  to zero to disable the limit.
 | ||
|  | 
 | ||
|  | **--output** *filename*
 | ||
|  | 
 | ||
|  |  Whenever the test program produces output on its standard output stream, it
 | ||
|  |  should match the contents of *filename* (the "reference output"). If you
 | ||
|  |  do not use this option, **bugpoint** will attempt to generate a reference output
 | ||
|  |  by compiling the program with the "safe" backend and running it.
 | ||
|  | 
 | ||
|  | **--run-{int,jit,llc,custom}**
 | ||
|  | 
 | ||
|  |  Whenever the test program is compiled, **bugpoint** should generate code for it
 | ||
|  |  using the specified code generator.  These options allow you to choose the
 | ||
|  |  interpreter, the JIT compiler, the static native code compiler, or a
 | ||
|  |  custom command (see **--exec-command**) respectively.
 | ||
|  | 
 | ||
|  | **--safe-{llc,custom}**
 | ||
|  | 
 | ||
|  |  When debugging a code generator, **bugpoint** should use the specified code
 | ||
|  |  generator as the "safe" code generator. This is a known-good code generator
 | ||
|  |  used to generate the "reference output" if it has not been provided, and to
 | ||
|  |  compile portions of the program that as they are excluded from the testcase.
 | ||
|  |  These options allow you to choose the
 | ||
|  |  static native code compiler, or a custom command, (see **--exec-command**)
 | ||
|  |  respectively. The interpreter and the JIT backends cannot currently
 | ||
|  |  be used as the "safe" backends.
 | ||
|  | 
 | ||
|  | **--exec-command** *command*
 | ||
|  | 
 | ||
|  |  This option defines the command to use with the **--run-custom** and
 | ||
|  |  **--safe-custom** options to execute the bitcode testcase. This can
 | ||
|  |  be useful for cross-compilation.
 | ||
|  | 
 | ||
|  | **--compile-command** *command*
 | ||
|  | 
 | ||
|  |  This option defines the command to use with the **--compile-custom**
 | ||
|  |  option to compile the bitcode testcase. The command should exit with a
 | ||
|  |  failure exit code if the file is "interesting" and should exit with a
 | ||
|  |  success exit code (i.e. 0) otherwise (this is the same as if it crashed on
 | ||
|  |  "interesting" inputs).
 | ||
|  | 
 | ||
|  |  This can be useful for
 | ||
|  |  testing compiler output without running any link or execute stages. To
 | ||
|  |  generate a reduced unit test, you may add CHECK directives to the
 | ||
|  |  testcase and pass the name of an executable compile-command script in this form:
 | ||
|  | 
 | ||
|  |  .. code-block:: sh
 | ||
|  | 
 | ||
|  |       #!/bin/sh
 | ||
|  |       llc "$@"
 | ||
|  |       not FileCheck [bugpoint input file].ll < bugpoint-test-program.s
 | ||
|  | 
 | ||
|  |  This script will "fail" as long as FileCheck passes. So the result
 | ||
|  |  will be the minimum bitcode that passes FileCheck.
 | ||
|  | 
 | ||
|  | **--safe-path** *path*
 | ||
|  | 
 | ||
|  |  This option defines the path to the command to execute with the
 | ||
|  |  **--safe-{int,jit,llc,custom}**
 | ||
|  |  option.
 | ||
|  | 
 | ||
|  | **--verbose-errors**\ =\ *{true,false}*
 | ||
|  | 
 | ||
|  |  The default behavior of bugpoint is to print "<crash>" when it finds a reduced
 | ||
|  |  test that crashes compilation. This flag prints the output of the crashing
 | ||
|  |  program to stderr. This is useful to make sure it is the same error being
 | ||
|  |  tracked down and not a different error that happens to crash the compiler as
 | ||
|  |  well. Defaults to false.
 | ||
|  | 
 | ||
|  | EXIT STATUS
 | ||
|  | -----------
 | ||
|  | 
 | ||
|  | If **bugpoint** succeeds in finding a problem, it will exit with 0.  Otherwise,
 | ||
|  | if an error occurs, it will exit with a non-zero value.
 | ||
|  | 
 | ||
|  | SEE ALSO
 | ||
|  | --------
 | ||
|  | 
 | ||
|  | opt|opt
 |