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

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)