Provided by: frama-c-base_20191204+calcium-0.1_amd64 

NAME
frama-c[.byte] - a static analyzer for C programs
frama-c-gui[.byte] - the graphical interface of frama-c
SYNOPSIS
frama-c [ options ] files
DESCRIPTION
frama-c is a suite of tools dedicated to the analysis of source code written in C. It gathers several
analysis techniques in a single collaborative framework. This framework can be extended by additional
plugins placed in the $FRAMAC_PLUGIN directory. The command
frama-c --plugins
will provide the full list of the plugins that are currently installed.
frama-c-gui is the graphical user interface of frama-c. It features the same options as the command-line
version.
frama-c.byte and frama-c-gui.byte are the OCaml bytecode versions of the command-line and graphical user
interface respectively.
By default, Frama-C recognizes .c files as C files needing pre-processing and .i files as C files having
been already pre-processed. Some plugins may extend the list of recognized files. Pre-processing can be
customized through the -cpp-command and -cpp-extra-args options.
OPTIONS
Syntax
Options taking an additional parameter can also be written under the form
-option=param
This form is mandatory when param starts with a dash (`-').
Most options that take no parameter have a corresponding
-no-option
option which has the opposite effect.
Help options
-help gives a short usage notice.
-kernel-help
prints the list of options recognized by Frama-C's kernel
-verbose n
sets verbosity level. Defaults to 1. Setting it to 0 will output less progress messages. This
level can also be set on a per-plugin basis, with option -plugin-verbose n. Verbosity level of
the kernel can be controlled with option -kernel-verbose n.
-debug n
sets debugging level. Defaults to 0, meaning no debugging messages. This option has the same
per-plugin (and kernel) specializations as -verbose.
-quiet sets verbosity and debugging level to 0.
Options controlling Frama-C's kernel
-absolute-valid-range min-max
considers that all numerical addresses in the range min-max are valid. Bounds are parsed as OCaml
integer constants. By default, all numerical addresses are considered invalid.
-add-path p1[,p2[...,pn]]
adds directories p1 through pn to the list of directories in which plugins are searched.
[-no]-aggressive-merging
merges function definitions modulo renaming. Defaults to no.
[-no]-allow-duplication
allows duplication of small blocks during normalization of tests and loops. Otherwise,
normalization uses labels and gotos. Bigger blocks and blocks with non-trivial control flow are
never duplicated. Defaults to yes.
[-no]-annot
reads ACSL annotations. This is the default. Annotations are pre-processed by default. Use
-no-pp-annot if you don't want to expand macros in annotations.
-big-ints-hex max
integers larger than max are displayed in hexadecimal (by default, all integers are displayed in
decimal).
-check performs integrity checks on the internal AST (for developers only).
[-no]-asm-contracts
generates contracts for assembly code written according to gcc's extended syntax. Defaults to
yes.
[-no]-asm-contracts-auto-validate
automatically marks contracts generated from asm as valid. Defaults to no.
-c11 enables (partial) C11 compatibility, e.g. typedef redefinitions. Defaults to no.
[-no]-collapse-call-cast
allows implicit cast between the value returned by a function and the lvalue it is assigned to.
Otherwise, a temporary variable is used and the cast is made explicit. Defaults to yes.
[-no]-constfold
folds all syntactically constant expressions in the code before analyses. Defaults to no.
-const-readonly
variables with const qualifier must be actually constant. Defaults to yes. The opposite option
is -unsafe-writable.
[-no]-continue-annot-error
when analyzing an annotation, the default behavior (the -no version of this option) when a
typechecking error occurs is to reject the source file as is the case for typechecking errors
within the C code. With this option on, the typechecker will only output a warning and discard
the annotation but type‐checking will continue (errors in C code are still fatal, though).
Deprecated: use -kernel-warn-key annot-error instead.
-cpp-command cmd
uses cmd as the command to pre-process C files. Defaults to the CPP environment variable or to
gcc -C -E -I.
if it is not set. If unset, the command is built as follows:
CPP -o
%1 and %2 can be used into the CPP string to mark the position of and respectively. Note that this
option is often better replaced by -cpp-extra-args.
-cpp-extra-args args
gives additional arguments to the pre-processor. Pre-processing annotations is done in two
separate pre-processing stages. The first one is a normal pass on the C code which retains macro
definitions. These are then used in the second pass during which annotations are pre-processed.
args are used only for the first pass, so that arguments that should not be used twice (such as
additional include directives or macro definitions) must thus go there instead of -cpp-command.
[-no]-cpp-frama-c-compliant
indicates that the chosen preprocessor complies to some Frama-C requirements, such as accepting
the same set of options as GNU cpp, and accepting architecture-specific options such as -m32/-m64.
Default values depend on the installed preprocessor at configure time. See also -pp-annot.
[-no]-autoload-plugins
when on, load all the dynamic plugins found in the search path (see -print-plugin-path for more
information on the default search path). Otherwise, only plugins requested by -load-module will
be loaded. Defaults to on.
-enums repr
choose the way the representation of enumerated types is determined. frama-c -enums help gives
the list of available options. Default is gcc-enums.
-float-digits n
when outputting floating-point numbers, display n digits. Defaults to 12.
-float-flush-to-zero
floating point operations flush to zero.
-float-hex
display floats as hexadecimal.
-float-normal
display floats with the standard OCaml routine.
-float-relative
display float intervals as [ lower_bound++width ].
[-no]-frama-c-stdlib
adds -I$FRAMAC_SHARE/libc to the options given to the cpp command. If -cpp-frama-c-compliant is
not false, also adds -nostdinc to prevent an inconsistent mix of system and Frama-C header files.
Defaults to yes.
-implicit-function-declaration action
warns or aborts when a function is called before it has been declared. action can be one of
ignore, warn, or error. Defaults to warn.
Deprecated: use -kernel-warn-key typing:implicit-function-declaration instead.
-initialized-padding-locals
implicit initialization of locals sets padding bits to 0. If false, padding bits are left
uninitialized. Defaults to yes.
-inline-calls f1,...,fn
syntactically inlines calls to functions f1,...,fn. Use @inline to select all functions with
attribute inline. Recursive functions are inlined only at the first level. Calls via function
pointers are not inlined.
-journal-disable
do not output a journal of the current session. See -journal-enable.
-journal-enable
on by default, dumps a journal of all the actions performed during the current Frama-C session in
the form of an OCaml script that can be replayed with -load-script. The name of the script can be
set with the -journal-name option.
-journal-name name
sets the name of the journal file (without the .ml extension). Defaults to frama_c_journal.
-json-compilation-database path
use path as a JSON compilation database (see
<https://clang.llvm.org/docs/JSONCompilationDatabase.html> for more information): each file
preprocessed by Frama-C will include corresponding -I and -D flags according to the specifications
in path. If path is a directory, use <path>/compile_commands.json. Disabled by default.
[-no]-keep-comments
tries to preserve comments when pretty-printing the source code. Defaults to no.
[-no]-keep-switch
when -simplify-cfg is set, keeps switch statements. Defaults to no.
-keep-unused-specified-functions
see -remove-unused-specified-functions.
-keep-unused-types
see -remove-unused-types.
-kernel-log kind:file
copies log messages from the Frama-C's kernel to file. kind specifies which kinds of messages to
be copied (e.g. w for warnings, e for errors, etc.). See -kernel-help for more details. Can
also be set on a per-plugin basis, with option -<plugin>-log.
-kernel-msg-key k1,...,kn
controls the emission of messages based on categories. Use -kernel-msg-key help to get a list of
available categories, and -kernel-msg-key=“*” to control all categories. To disable a category,
add a - before its name; to enable a category, simply add its name, with an optional + before it.
For instance, -kernel-msg-key=-k1,k2 will disable messages from category k1 and enable those from
category k2. Can also be set on a per-plugin basis, with option -<plugin>-msg-key. Note that
each plugin has its own set of categories.
-kernel-warn-key k1=a1,...,kn=an
controls the emission of warnings based on categories: for each warning category k, associate
action a. Use -kernel-warn-key help to get a list of available warning categories and their
currently associated actions. The following actions can be set per category: active (warn),
feedback, error, abort, once, feedback-once, err-once. Omitting the action is equivalent to
setting it to active. Warning categories can also be set on a per-plugin basis, with option
-<plugin>-warn-key.
[-no]-lib-entry
indicates that the entry point is called during program execution. This implies in particular
that global variables cannot be assumed to have their initial values. The default is
-no-lib-entry: the entry point is also the starting point of the program and globals have their
initial value.
-load file
loads the (previously saved) state contained in file.
-load-module SPEC
dynamically load OCaml plug-ins, modules and scripts. Each SPEC can be an OCaml source or object
file, with or without extension, or a Findlib package. Loading order is preserved and additional
dependencies can be listed in *.depend files.
-load-script SPEC
alias for option -load-module.
-machdep machine
uses machine as the current machine-dependent configuration (size of the various integer types,
endiandness, ...). The list of currently supported machines is available through option -machdep
help. Default is x86_32.
-main f
sets f as the entry point of the analysis. Defaults to main. By default, it is considered as the
starting point of the program under analysis. Use -lib-entry if f is supposed to be called in the
middle of an execution.
-obfuscate
prints an obfuscated version of the code (where original identifiers are replaced by meaningless
ones) and exits. The correspondence table between original and new symbols is kept at the
beginning of the result.
-ocode file
redirects pretty-printed code to file instead of standard output.
[-no]-orig-name
During the normalization phase, some variables may get renamed when different variables with the
same name can co-exist (e.g. a global variable and a formal parameter). When this option is on, a
message is printed each time this occurs. Defaults to no.
[-no]-pp-annot
pre-processes annotations. This is currently only possible when using gcc (or GNU cpp)
pre-processor. The default is to pre-process annotations when the default pre-processor is
identified as GNU or GNU-like. See also -cpp-frama-c-compliant.
[-no]-print
pretty-prints the source code as normalized by CIL. Defaults to no.
[-no]-print-libc
expands #include directives in the pretty-printed CIL code for files in the Frama-C standard
library. Defaults to no.
-print-libpath
outputs the directory where the Frama-C kernel library is installed.
-print-path
alias of -print-share-path.
-print-plugin-path
outputs the directory where Frama-C searches its plugins (can be overridden by the FRAMAC_PLUGIN
variable and the -add-path option).
-print-share-path
outputs the directory where Frama-C stores its data (can be overridden by the FRAMAC_SHARE
variable).
[-no]-remove-exn
transforms throw and try/catch statements into normal C functions. Defaults to no, unless the
input source language has an exception mechanism.
-remove-inlined f1,...,fn
removes inlined functions f1,...,fn from the AST, which must have been given to -inline-calls.
Note: this option does not check if the given functions were fully inlined.
-remove-projects p1,...,pn
removes the given projects p1,...,pn. @all_but_current removes all projects but the current one.
-remove-unused-specified-functions
keeps function prototypes that have an ACSL specification but are not used in the code. This is
the default. Functions having the attribute FRAMAC_BUILTIN are always kept.
-remove-unused-types
remove types and struct/union/enum declarations that are not referenced anywhere else in the code.
This is the default. Use -keep-unused-types to keep these definitions.
-safe-arrays
for multidimensional arrays or arrays that are fields inside structs, assumes that all accesses
must be in bound (set by default). The opposite option is -unsafe-arrays.
-save file
saves Frama-C's state into file after analyses have taken place.
-session s
sets s as the directory in which session files are searched.
[-no]-set-project-as-default
the current project becomes the default one (and so future -then sequences are applied on it).
Defaults to no.
[-no]-simplify-cfg
removes break, continue and switch statements before analyses. Defaults to no.
[-no]-simplify-trivial-loops
simplifies trivial loops such as do ... while (0) loops. Defaults to yes.
-then allows one to compose analyses: a first run of Frama-C will occur with the options before -then
and a second run will be done with the options after -then on the current project from the first
run.
-then-last
like -then, but the second group of actions is executed on the last project created by a program
transformer.
-then-on prj
similar to -then except that the second run is performed in project prj. If no such project
exists, Frama-C exits with an error.
-then-replace
like -then-last, but also removes the previous current project.
-time file
appends user time and date in the given file when Frama-C exits.
-typecheck
forces typechecking of the source files. This option is only relevant if no further analysis is
requested (as typechecking will implicitly occur before the analysis is launched).
-ulevel n
syntactically unroll loops n times before the analysis. This can be quite costly and some plugins
(e.g. Eva) provide more efficient ways to perform the same thing. See their respective manuals
for more information. This can also be activated on a per-loop basis via the loop pragma unroll
directive. A negative value for n will inhibit such pragmas.
[-no]-ulevel-force
ignores UNROLL loop pragmas disabling unrolling.
[-no]-unicode outputs ACSL formulas with UTF-8 characters. This is the default. When given the
-no-unicode option, Frama-C will use the ASCII version instead. See the ACSL manual for the
correspondence.
-unsafe-arrays
see -safe-arrays.
[-no]-unspecified-access
checks that read/write accesses occurring in an unspecified order (according to the C standard's
notion of sequence points) are performed on separate locations. With -no-unspecified-access,
assumes that it is always the case (this is the default).
-version
outputs the version string of Frama-C.
-warn-decimal-float freq
warns when a floating-point constant cannot be exactly represented (e.g. 0.1). freq can be one of
none, once, or all.
Deprecated: use -kernel-warn-key parser:decimal-float=once (and variants) instead.
[-no]-warn-left-shift-negative
generate alarms for signed left shifts on negative values. Defaults to yes.
[-no]-warn-right-shift-negative
generate alarms for signed right shifts on negative values. Defaults to no.
[-no]-warn-signed-downcast
generates alarms when signed downcasts may exceed the destination range. Defaults to no.
[-no]-warn-signed-overflow
generates alarms for signed operations that overflow. Defaults to yes.
[-no]-warn-unsigned-downcast
generates alarms when unsigned downcasts may exceed the destination range. Defaults to no.
[-no]-warn-unsigned-overflow
generates alarms for unsigned operations that overflow. Defaults to no.
[-no]-warn-invalid-bool
generates alarms for reads of trap representations of _Bool lvalues. Defaults to yes.
Plugin-specific options
For each plugin, the command
frama-c -plugin-help
will give the list of options that are specific to the plugin.
EXIT STATUS
0 Successful execution
1 Invalid user input
2 User interruption (kill or equivalent)
3 Unimplemented feature
4 5 6 Internal error
125 Unknown error
Exit statuses greater than 2 can be considered as a bug (or a feature request for the case of exit status
3) and may be reported on Frama-C's BTS (see below).
ENVIRONMENT VARIABLES
It is possible to control the places where Frama-C looks for its files through the following variables.
FRAMAC_LIB
The directory where kernel's compiled interfaces are installed.
FRAMAC_PLUGIN
The directory where Frama-C can find standard plugins. If you wish to have plugins in several
places, use -add-path instead.
FRAMAC_SHARE
The directory where Frama-C data (e.g. its version of the standard library) is installed.
SEE ALSO
Frama-C user manual: http://frama-c.com/download/frama-c-user-manual.pdf
Frama-C homepage: http://frama-c.com
Frama-C BTS: http://bts.frama-c.com
2019-07-29 FRAMA-C(1)