1 llvm-remarkutil - Remark utility
2 ================================
4 .. program:: llvm-remarkutil
9 :program:`llvm-remarkutil` [*subcommmand*] [*options*]
14 Utility for displaying information from, and converting between different
15 `remark <https://llvm.org/docs/Remarks.html>`_ formats.
20 * :ref:`bitstream2yaml_subcommand` - Reserialize bitstream remarks to YAML.
21 * :ref:`yaml2bitstream_subcommand` - Reserialize YAML remarks to bitstream.
22 * :ref:`instruction-count_subcommand` - Output function instruction counts.
23 * :ref:`annotation-count_subcommand` - Output remark type count from annotation remarks.
24 * :ref:`size-diff_subcommand` - Compute diff in size remarks.
26 .. _bitstream2yaml_subcommand:
31 .. program:: llvm-remarkutil bitstream2yaml
33 USAGE: :program:`llvm-remarkutil` bitstream2yaml <input file> -o <output file>
38 Takes a bitstream remark file as input, and reserializes that file as YAML.
40 .. _yaml2bitstream_subcommand:
45 .. program:: llvm-remarkutil yaml2bitstream
47 USAGE: :program:`llvm-remarkutil` yaml2bitstream <input file> -o <output file>
52 Takes a YAML remark file as input, and reserializes that file in the bitstream
55 .. _instruction-count_subcommand:
60 .. program:: llvm-remarkutil instruction-count
62 USAGE: :program:`llvm-remarkutil` instruction-count <input file> --parser=<bitstream|yaml> [--use-debug-loc] -o <output file>
67 Outputs instruction count remarks for every function. Instruction count remarks
68 encode the number of instructions in a function at assembly printing time.
70 Instruction count remarks require asm-printer remarks.
72 CSV format is as follows:
75 Function,InstructionCount
78 if `--use-debug-loc` is passed then the CSV will include the source path, line number and column.
81 Source,Function,InstructionCount
82 path:line:column,foo,3
84 .. _annotation-count_subcommand:
89 .. program:: llvm-remarkutil annotation-count
91 USAGE: :program:`llvm-remarkutil` annotation-count <input file> --parser=<bitstream|yaml> --annotation-type=<type> [--use-debug-loc] -o <output file>
96 Outputs a count for annotation-type `<type>` remark for every function. The count expresses
97 the number of remark checks inserted at the function.
99 Annotation count remarks require AnnotationRemarksPass remarks.
101 CSV format is as follows:
107 if `--use-debug-loc` is passed then the CSV will include the source path, line number and column.
110 Source,Function,Count
111 path:line:column,foo,3
113 .. _count_subcommand:
118 ..program:: llvm-remarkutil count
120 USAGE: :program:`llvm-remarkutil` count [*options*] <input file>
125 :program:`llvm-remarkutil count` counts `remarks <https://llvm.org/docs/Remarks.html>` based on specified properties.
126 By default the tool counts remarks based on how many occour in a source file or function or total for the generated remark file.
127 The tool also supports collecting count based on specific remark arguments. The specified arguments should have an integer value to be able to report a count.
129 The tool contains utilities to filter the remark count based on remark name, pass name, argument value and remark type.
133 .. option:: --parser=<yaml|bitstream>
135 Select the type of input remark parser. Required.
136 * ``yaml``: The tool will parse YAML remarks.
137 * ``bitstream``: The tool will parse bitstream remarks.
139 .. option:: --count-by<value>
140 Select option to collect remarks by.
141 * ``remark-name``: count how many individual remarks exist.
142 * ``arg``: count remarks based on specified arguments passed by --(r)args. The argument value must be a number.
144 .. option:: --group-by=<value>
145 group count of remarks by property.
146 * ``source``: Count will be collected per source path. Remarks with no debug location will not be counted.
147 * ``function``: Count is collected per function.
148 * ``function-with-loc``: Count is collected per function per source. Remarks with no debug location will not be counted.
149 * ``Total``: Report a count for the provided remark file.
151 .. option:: --args[=arguments]
152 If `count-by` is set to `arg` this flag can be used to collect from specified remark arguments represented as a comma seperated string.
153 The arguments must have a numeral value to be able to count remarks by
155 .. option:: --rargs[=arguments]
156 If `count-by` is set to `arg` this flag can be used to collect from specified remark arguments using regular expression.
157 The arguments must have a numeral value to be able to count remarks by
159 .. option:: --pass-name[=<string>]
160 Filter count by pass name.
162 .. option:: --rpass-name[=<string>]
163 Filter count by pass name using regular expressions.
165 .. option:: --remark-name[=<string>]
166 Filter count by remark name.
168 .. option:: --rremark-name[=<string>]
169 Filter count by remark name using regular expressions.
171 .. option:: --filter-arg-by[=<string>]
172 Filter count by argument value.
174 .. option:: --rfilter-arg-by[=<string>]
175 Filter count by argument value using regular expressions.
177 .. option:: --remark-type=<value>
178 Filter remarks by type with the following options.
183 * ``analysis-fp-commute``
184 * ``analysis-aliasing``
187 .. _size-diff_subcommand:
191 .. program:: llvm-remarkutil size-diff
193 USAGE: :program:`llvm-remarkutil` size-diff [*options*] *file_a* *file_b* **--parser** *parser*
198 :program:`llvm-remarkutil size-diff` diffs size `remarks <https://llvm.org/docs/Remarks.html>`_ in two remark files: ``file_a``
201 :program:`llvm-remarkutil size-diff` can be used to gain insight into which
202 functions were impacted the most by code generation changes.
204 In most common use-cases ``file_a`` and ``file_b`` will be remarks output by
205 compiling a **fixed source** with **differing compilers** or
206 **differing optimization settings**.
208 :program:`llvm-remarkutil size-diff` handles both
209 `YAML <https://llvm.org/docs/Remarks.html#yaml-remarks>`_ and
210 `bitstream <https://llvm.org/docs/Remarks.html#llvm-bitstream-remarks>`_
216 .. option:: --parser=<yaml|bitstream>
218 Select the type of input remark parser. Required.
219 * ``yaml``: The tool will parse YAML remarks.
220 * ``bitstream``: The tool will parse bitstream remarks.
222 .. option:: --report-style=<human|json>
225 * ``human``: Human-readable textual report. Default option.
226 * ``json``: JSON report.
230 Pretty-print JSON output. Optional.
232 If output is not set to JSON, this does nothing.
234 .. option:: -o=<file>
236 Output file for the report. Outputs to stdout by default.
238 HUMAN-READABLE OUTPUT
239 ---------------------
241 The human-readable format for :program:`llvm-remarkutil size-diff` is composed of
244 * Per-function changes.
245 * A high-level summary of all changes.
247 Changed Function Section
248 ~~~~~~~~~~~~~~~~~~~~~~~~
250 Suppose you are comparing two remark files OLD and NEW.
252 For each function with a **changed instruction count** in OLD and NEW,
253 :program:`llvm-remarkutil size-diff` will emit a line like below:
257 (++|--|==) (>|<) function_name, N instrs, M stack B
259 A breakdown of the format is below:
262 Which of OLD and NEW the ``function_name`` is present in.
264 * ``++``: Only in NEW. ("Added")
265 * ``--``: Only in OLD. ("Removed")
269 Denotes if ``function_name`` has more instructions or fewer instructions in
272 * ``>``: More instructions in second file than first file.
273 * ``<``: Fewer instructions in second file than in first file.
276 The name of the changed function.
279 Second file instruction count - first file instruction count.
282 Second file stack byte count - first file stack byte count.
287 :program:`llvm-remarkutil size-diff` will output a high-level summary after
288 printing all changed functions.
292 instruction count: N (inst_pct_change%)
293 stack byte usage: M (sb_pct_change%)
296 Sum of all instruction count changes between the second and first file.
299 Percent increase or decrease in instruction count between the second and first
303 Sum of all stack byte count changes between the second and first file.
306 Percent increase or decrease in stack byte usage between the second and first
315 Suppose we are comparing two files, OLD and NEW.
317 :program:`llvm-remarkutil size-diff` will output JSON as follows.
340 Original paths to remark files.
342 * ``A``: Path to the first file.
343 * ``B``: Path to the second file.
346 Functions present in both files.
349 Functions only present in the first file.
352 Functions only present in the second file.
357 The ``InBoth``, ``OnlyInA``, and ``OnlyInB`` sections contain size information
358 for each function in the input remark files.
363 "FunctionName" : "function_name"
375 Name of the function.
378 Instruction counts for the function.
380 * ``INST_COUNT_A``: Instruction count in OLD.
381 * ``INST_COUNT_B``: Instruction count in NEW.
384 Stack byte counts for the function.
386 * ``STACK_BYTES_A``: Stack bytes in OLD.
387 * ``STACK_BYTES_B``: Stack bytes in NEW.
389 Computing Diffs From Function JSON
390 ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
392 Function JSON does not contain the diffs. Tools consuming JSON output from
393 :program:`llvm-remarkutil size-diff` are responsible for computing the diffs
396 **To compute the diffs:**
398 * Instruction count diff: ``INST_COUNT_B - INST_COUNT_A``
399 * Stack byte count diff: ``STACK_BYTES_B - STACK_BYTES_A``
404 :program:`llvm-remarkutil size-diff` returns 0 on success, and a non-zero value