dwww Home | Manual pages | Find package

LLVM-MC(1)                       User Commands                      LLVM-MC(1)

NAME
       llvm-mc - manual page for llvm-mc 11

DESCRIPTION
       OVERVIEW: llvm machine code playground

       USAGE: llvm-mc [options] <input file>

       OPTIONS:

       Color Options:

       --color                                            - Use colors in out-
              put (default=autodetect)

       General options:

       -I=<directory>                                     - Directory  of  in-
              clude files

       --aarch64-neon-syntax=<value>                       -  Choose  style of
              NEON code to emit from AArch64 backend:

       =generic
              -   Emit generic NEON assembly

       =apple -   Emit Apple-style NEON assembly

       --amdgpu-bypass-slow-div                           - Skip 64-bit divide
              for dynamic 32-bit values

       --amdgpu-disable-loop-alignment                     -  Do not align and
              prefetch loops

       --amdgpu-disable-power-sched                       - Disable scheduling
              to minimize mAI power bursts

       --amdgpu-dpp-combine                                -  Enable  DPP com-
              biner

       --amdgpu-dump-hsa-metadata                         -  Dump  AMDGPU  HSA
              Metadata

       --amdgpu-enable-global-sgpr-addr                   - Enable use of SGPR
              regs for GLOBAL LOAD/STORE instructions

       --amdgpu-enable-merge-m0                           - Merge and hoist M0
              initializations

       --amdgpu-promote-alloca-to-vector-limit=<uint>      - Maximum byte size
              to consider promote alloca to vector

       --amdgpu-reserve-vgpr-for-sgpr-spill               - Allocates one VGPR
              for future SGPR Spill

       --amdgpu-sdwa-peephole                              - Enable SDWA peep-
              holer

       --amdgpu-verify-hsa-metadata                       - Verify AMDGPU  HSA
              Metadata

       --amdgpu-vgpr-index-mode                            -  Use GPR indexing
              mode instead of movrel for vector indexing

       --arch=<string>                                    - Target arch to as-
              semble for, see -version for available targets

       --arm-add-build-attributes                         -

       --arm-implicit-it=<value>                           - Allow conditional
              instructions outdside of an IT block

       =always
              -   Accept in both ISAs, emit implicit ITs in Thumb

       =never -   Warn in ARM, reject in Thumb

       =arm   -   Accept in ARM, reject in Thumb

       =thumb -   Warn in ARM, emit implicit ITs in Thumb

       --asm-show-inst                                    - Emit internal  in-
              struction representation to assembly file

              Action to perform:

       --as-lex                                           -  Lex tokens from a
              .s file

       --assemble                                        - Assemble a .s  file
              (default)

       --disassemble                                     - Disassemble strings
              of hex bytes

       --mdis                                            - Marked up disassem-
              bly of strings of hex bytes

       --atomic-counter-update-promoted                    - Do counter update
       using atomic fetch add
              for promoted counters only

       --atomic-first-counter                             - Use  atomic  fetch
              add for first counter in a function (usually the entry counter)

       --bounds-checking-single-trap                      - Use one trap block
              per function

       --cfg-hide-deoptimize-paths                        -

       --cfg-hide-unreachable-paths                       -

       --compress-debug-sections=<value>                  - Choose DWARF debug
              sections compression:

       =none  -   No compression

       =zlib  -   Use zlib compression

       =zlib-gnu
              -   Use zlib-gnu compression (deprecated)

       --cost-kind=<value>                                - Target cost kind

       =throughput
              -   Reciprocal throughput

       =latency
              -   Instruction latency

       =code-size
              -   Code size

       --cvp-dont-add-nowrap-flags                        -

       --debugify-level=<value>                           - Kind of debug info
              to add

       =locations
              -   Locations only

       =location+variables
              -   Locations and Variables

       --debugify-quiet                                   -  Suppress  verbose
              debugify output

       --defsym=<string>                                   -  Defines a symbol
              to be an integer constant

       --disable-promote-alloca-to-lds                     -  Disable  promote
              alloca to LDS

       --disable-promote-alloca-to-vector                  -  Disable  promote
              alloca to vector

       --do-counter-promotion                             - Do counter  regis-
              ter promotion

       --dwarf-version=<int>                              - Dwarf version

       --dwarf64                                          - Generate debugging
              info in the 64-bit DWARF format

       --emscripten-cxx-exceptions-allowed=<string>       - The list of  func-
              tion  names  in which Emscripten-style exception handling is en-
              abled (see emscripten EMSCRIPTEN_CATCHING_ALLOWED options)

       --enable-cse-in-irtranslator                       - Should enable  CSE
              in irtranslator

       --enable-cse-in-legalizer                           - Should enable CSE
              in Legalizer

       --enable-emscripten-cxx-exceptions                  -  WebAssembly  Em-
              scripten-style exception handling

       --enable-emscripten-sjlj                            -  WebAssembly  Em-
              scripten-style setjmp/longjmp handling

       --enable-gvn-hoist                                  -  Enable  the  GVN
              hoisting pass (default = off)

       --enable-gvn-memdep                                -

       --enable-gvn-sink                                   -  Enable  the  GVN
              sinking pass (default = off)

       --enable-load-in-loop-pre                          -

       --enable-load-pre                                  -

       --enable-loop-simplifycfg-term-folding             -

       --enable-name-compression                          - Enable  name/file-
              name string compression

       --fatal-warnings                                    - Treat warnings as
              errors

       --fdebug-compilation-dir=<string>                  - Specifies the  de-
              bug info's compilation dir

       --fdebug-prefix-map=<=  separated  key-value  pairs>  - Map file source
              paths in debug info

       --filetype=<value>                                 - Choose  an  output
              file type:

       =asm   -   Emit an assembly ('.s') file

       =null  -   Don't emit anything (for timing purposes)

       =obj   -   Emit a native object ('.o') file

       -g                                                 - Generate dwarf de-
              bugging info for assembly source files

       --gpsize=<uint>                                    - Global Pointer Ad-
       dressing Size.
              The default size is 8.

       --hash-based-counter-split                           -  Rename  counter
              variable of a comdat function based on cfg hash

       --hot-cold-split                                    -  Enable  hot-cold
              splitting pass

       --import-all-index                                  - Import all exter-
              nal functions in index.

       --incremental-linker-compatible                     -  When  used  with
              filetype=obj,  emit an object file which can be used with an in-
              cremental linker

       --instcombine-code-sinking                         - Enable code  sink-
              ing

       --instcombine-guard-widening-window=<uint>          -  How  wide an in-
              struction window to bypass looking for another guard

       --instcombine-max-iterations=<uint>                - Limit the  maximum
              number of instruction combining iterations

       --instcombine-max-num-phis=<uint>                    -  Maximum  number
              phis to handle in intptr/ptrint folding

       --instcombine-maxarray-size=<uint>                 - Maximum array size
              considered when doing a combine

       --instcombine-negator-enabled                       - Should we attempt
              to sink negations?

       --instcombine-negator-max-depth=<uint>             - What is the  maxi-
              mal  lookup depth when trying to check for viability of negation
              sinking.

       --instrprof-atomic-counter-update-all              - Make  all  profile
              counter updates atomic (for testing only)

       --internalize-public-api-file=<filename>            - A file containing
              list of symbol names to preserve

       --internalize-public-api-list=<list>               - A list  of  symbol
              names to preserve

       --iterative-counter-promotion                      - Allow counter pro-
              motion across the whole loop nest.

       --large-code-model                                 - Create cfi  direc-
              tives that assume the code might be more than 2gb away

       --lto-embed-bitcode                                - Embed LLVM bitcode
              in object files produced by LTO

       --lto-pass-remarks-filter=<regex>                  - Only record  opti-
              mization remarks from passes whose names match the given regular
              expression

       --lto-pass-remarks-format=<format>                 -  The  format  used
              for serializing remarks (default: YAML)

       --lto-pass-remarks-output=<filename>                -  Output  filename
              for pass remarks

       --main-file-name=<string>                          - Specifies the name
              we should consider the input file

       --masm-integers                                     - Enable binary and
              hex masm integers (0b110 and 0ABCh)

       --matrix-default-layout=<value>                    - Sets  the  default
              matrix layout

       =column-major
              -   Use column-major layout

       =row-major
              -   Use row-major layout

       --mattr=<a1,+a2,-a3,...>                            -  Target  specific
              attributes (-mattr=help for details)

       --max-counter-promotions=<int>                     - Max number of  al-
              lowed counter promotions

       --max-counter-promotions-per-loop=<uint>           - Max number counter
              promotions per loop to avoid increasing  register  pressure  too
              much

       --mc-relax-all                                      -  When  used  with
              filetype=obj, relax all fixups in the emitted object file

       --mcpu=<cpu-name>                                  - Target a  specific
              cpu type (-mcpu=help for details)

       --memop-size-large=<uint>                           -  Set  large value
              thresthold in memory intrinsic size profiling. Value of  0  dis-
              ables the large value profiling.

       --memop-size-range=<string>                         -  Set the range of
              size in memory intrinsic calls to be profiled  precisely,  in  a
              format of <start_val>:<end_val>

       --merror-missing-parenthesis                        - Error for missing
              parenthesis around predicate registers

       --merror-noncontigious-register                    - Error for register
              names that aren't contigious

       --mhvx                                               -  Enable  Hexagon
              Vector eXtensions

       --mhvx=<value>                                      -  Enable   Hexagon
              Vector eXtensions

       =v60   -   Build for HVX v60

       =v62   -   Build for HVX v62

       =v65   -   Build for HVX v65

       =v66   -   Build for HVX v66

       =v67   -   Build for HVX v67

       --mips-compact-branches=<value>                      -  MIPS  Specific:
              Compact branch policy.

       =never
              -   Do not use compact branches if possible.

       =optimal
              -   Use compact branches where appropriate (default).

       =always
              -   Always use compact branches if possible.

       --mips16-constant-islands                          - Enable mips16 con-
              stant islands.

       --mips16-hard-float                                - Enable mips16 hard
              float.

       --mir-strip-debugify-only                                -       Should
              mir-strip-debug only strip debug info from debugified modules by
              default

       --mno-compound                                      -  Disable  looking
              for compound instructions for Hexagon

       --mno-fixup                                         - Disable fixing up
              resolved relocations for Hexagon

       --mno-ldc1-sdc1                                    - Expand double pre-
              cision loads and stores to their single precision counterparts

       --mno-pairing                                       -  Disable  looking
              for duplex instructions for Hexagon

       --mwarn-missing-parenthesis                        - Warn  for  missing
              parenthesis around predicate registers

       --mwarn-noncontigious-register                      - Warn for register
              names that arent contigious

       --mwarn-sign-mismatch                              - Warn for mismatch-
              ing a signed and unsigned value

       -n                                                  -  Don't assume as-
              sembly file starts in the text section

       --no-deprecated-warn                               - Suppress all  dep-
              recated warnings

       --no-discriminators                                - Disable generation
              of discriminator information.

       --no-exec-stack                                    - File doesn't  need
              an exec stack

       --no-warn                                          - Suppress all warn-
              ings

       --nvptx-sched4reg                                   -  NVPTX  Specific:
              schedule for register pressue

       -o=<filename>                                      - Output filename

       --output-asm-variant=<uint>                         - Syntax variant to
              use for output printing

       --poison-checking-function-local                   - Check that returns
              are non-poison (for testing)

       --position-independent                              - Position indepen-
              dent

       --preserve-comments                                - Preserve  Comments
              in outputted assembly

       --print-imm-hex                                     - Prefer hex format
              for immediate values

       --r600-ir-structurize                              - Use StructurizeCFG
              IR pass

       --rdf-dump                                         -

       --rdf-limit=<uint>                                 -

       --relax-relocations                                - Emit R_X86_64_GOT-
              PCRELX instead of R_X86_64_GOTPCREL

       --runtime-counter-relocation                       - Enable  relocating
              counters at runtime.

       --safepoint-ir-verifier-print-only                 -

       --sample-profile-check-record-coverage=<N>          - Emit a warning if
              less than N% of records in the input profile are matched to  the
              IR.

       --sample-profile-check-sample-coverage=<N>          - Emit a warning if
              less than N% of samples in the input profile are matched to  the
              IR.

       --sample-profile-max-propagate-iterations=<uint>    - Maximum number of
              iterations to go  through  when  propagating  sample  block/edge
              weights through the CFG.

       --save-temp-labels                                 - Don't discard tem-
              porary labels

       --show-encoding                                    -  Show  instruction
              encodings

       --show-inst                                         - Show internal in-
              struction representation

       --show-inst-operands                               - Show  instructions
              operands as parsed

       --speculative-counter-promotion-max-exiting=<uint>  - The max number of
       exiting blocks of a loop to allow
              speculative counter promotion

       --speculative-counter-promotion-to-loop            - When the option is
       false,  if  the target block is in a loop, the promotion will be disal-
       lowed unless the promoted counter
              update can be further/iteratively promoted into an acyclic   re-
              gion.

       --split-dwarf-file=<filename>                       -  DWO output file-
              name

       --summary-file=<string>                            - The  summary  file
              to use for function importing.

       --tail-predication=<value>                          - MVE tail-predica-
              tion options

       =disabled
              -   Don't tail-predicate loops

       =enabled-no-reductions
              -   Enable tail-predication, but not for reduction loops

       =enabled
              -   Enable tail-predication, including reduction loops

       =force-enabled-no-reductions
              -   Enable tail-predication, but not for  reduction  loops,  and
              force this which might be unsafe

       =force-enabled
              -    Enable  tail-predication,  including  reduction  loops, and
              force this which might be unsafe

       --threads=<int>                                    -

       --triple=<string>                                  - Target  triple  to
              assemble for, see -version for available targets

       --verify-region-info                               - Verify region info
              (time consuming)

       --vp-counters-per-site=<number>                    - The average number
              of profile counters allocated per value profiling site.

       --vp-static-alloc                                   - Do static counter
              allocation for value profiler

       --x86-align-branch=<string>                        - Specify  types  of
       branches to align (plus separated list of types):
              jcc       indicates  conditional  jumps fused    indicates fused
              conditional jumps jmp      indicates direct unconditional  jumps
              call      indicates direct and indirect calls ret      indicates
              rets indirect indicates indirect unconditional jumps

       --x86-align-branch-boundary=<uint>                 -  Control  how  the
              assembler should align branches with NOP. If the boundary's size
              is not 0, it should be a  power  of  2  and  no  less  than  32.
              Branches will be aligned to prevent from being across or against
              the boundary of specified size. The default  value  0  does  not
              align branches.

       --x86-branches-within-32B-boundaries               - Align selected in-
       structions to mitigate negative performance  impact  of  Intel's  micro
       code update for errata skx102.
              May  break  assumptions about labels corresponding to particular
              instructions, and should be used with caution.

       --x86-pad-max-prefix-size=<uint>                   - Maximum number  of
              prefixes to use for padding

       Generic Options:

       --help                                              - Display available
              options (--help-hidden for more)

       --help-list                                        -  Display  list  of
              available options (--help-list-hidden for more)

       --version                                           -  Display the ver-
              sion of this program

       Polly Options: Configure the polly loop optimizer

       --polly                                            - Enable  the  polly
              optimizer (only at -O3)

       --polly-2nd-level-tiling                           - Enable a 2nd level
              loop of loop tiling

       --polly-ast-print-accesses                         - Print  memory  ac-
              cess functions

       --polly-context=<isl parameter set>                - Provide additional
              constraints on the context parameters

       --polly-dce-precise-steps=<int>                    - The number of pre-
              cise  steps between two approximating iterations. (A value of -1
              schedules another approximation stage  before  the  actual  dead
              code elimination.

       --polly-delicm-max-ops=<int>                        - Maximum number of
              isl operations to invest for lifetime analysis; 0=no limit

       --polly-detect-full-functions                      - Allow  the  detec-
              tion of full functions

       --polly-dump-after                                  - Dump module after
              Polly transformations into a file suffixed with "-after"

       --polly-dump-after-file=<string>                   - Dump module  after
              Polly transformations to the given file

       --polly-dump-before                                - Dump module before
              Polly transformations into a file suffixed with "-before"

       --polly-dump-before-file=<string>                  - Dump module before
              Polly transformations to the given file

       --polly-enable-simplify                             - Simplify SCoP af-
              ter optimizations

       --polly-ignore-func=<string>                       -  Ignore  functions
              that  match  a  regex.  Multiple regexes can be comma separated.
              Scop detection will ignore all functions that match ANY  of  the
              regexes provided.

       --polly-isl-arg=<argument>                          -  Option passed to
              ISL

       --polly-on-isl-error-abort                         - Abort  if  an  isl
              error is encountered

       --polly-only-func=<string>                          - Only run on func-
              tions that match a regex. Multiple regexes can  be  comma  sepa-
              rated.  Scop  detection will run on all functions that match ANY
              of the regexes provided.

       --polly-only-region=<identifier>                   - Only run  on  cer-
              tain regions (The provided identifier must appear in the name of
              the region's entry block

       --polly-only-scop-detection                        - Only run scop  de-
              tection, but no other optimizations

       --polly-optimized-scops                            - Polly - Dump poly-
              hedral description of Scops optimized with  the  isl  scheduling
              optimizer  and the set of post-scheduling transformations is ap-
              plied on the schedule tree

       --polly-parallel                                    -  Generate  thread
              parallel code (isl codegen only)

       --polly-parallel-force                              -  Force generation
              of thread parallel code ignoring any cost model

       --polly-pattern-matching-based-opts                - Perform  optimiza-
              tions based on pattern matching

       --polly-process-unprofitable                       - Process scops that
              are unlikely to benefit from Polly optimizations.

       --polly-register-tiling                             -  Enable  register
              tiling

       --polly-report                                      - Print information
              about the activities of Polly

       --polly-show                                       - Highlight the code
              regions  that  will  be  optimized in a (CFG BBs and LLVM-IR in-
              structions)

       --polly-show-only                                  - Highlight the code
              regions that will be optimized in a (CFG only BBs)

       --polly-stmt-granularity=<value>                    -  Algorithm to use
              for splitting basic blocks into multiple statements

       =bb    -   One statement per basic block

       =scalar-indep
              -   Scalar independence heuristic

       =store -   Store-level granularity

       --polly-target=<value>                             -  The  hardware  to
              target

       =cpu   -   generate CPU code

       --polly-tiling                                     - Enable loop tiling

       --polly-vectorizer=<value>                         - Select the vector-
              ization strategy

       =none  -   No Vectorization

       =polly -   Polly internal vectorizer

       =stripmine
              -   Strip-mine outer loops for the loop-vectorizer to trigger

llvm-mc 11                       January 2022                       LLVM-MC(1)

Generated by dwww version 1.14 on Fri Jan 24 09:28:33 CET 2025.