Jordan Rupprecht | a28b8d7 | 2019-08-21 18:00:17 +0000 | [diff] [blame] | 1 | llvm-size - print size information |
| 2 | ================================== |
| 3 | |
| 4 | .. program:: llvm-size |
| 5 | |
| 6 | SYNOPSIS |
| 7 | -------- |
| 8 | |
James Henderson | e8ed932 | 2019-09-16 13:20:37 +0000 | [diff] [blame] | 9 | :program:`llvm-size` [*options*] [*input...*] |
Jordan Rupprecht | a28b8d7 | 2019-08-21 18:00:17 +0000 | [diff] [blame] | 10 | |
| 11 | DESCRIPTION |
| 12 | ----------- |
| 13 | |
James Henderson | e8ed932 | 2019-09-16 13:20:37 +0000 | [diff] [blame] | 14 | :program:`llvm-size` is a tool that prints size information for binary files. |
| 15 | It is intended to be a drop-in replacement for GNU's :program:`size`. |
| 16 | |
| 17 | The tool prints size information for each ``input`` specified. If no input is |
| 18 | specified, the program prints size information for ``a.out``. If "``-``" is |
| 19 | specified as an input file, :program:`llvm-size` reads a file from the standard |
| 20 | input stream. If an input is an archive, size information will be displayed for |
| 21 | all its members. |
| 22 | |
| 23 | OPTIONS |
| 24 | ------- |
| 25 | |
| 26 | .. option:: -A |
| 27 | |
| 28 | Equivalent to :option:`--format` with a value of ``sysv``. |
| 29 | |
| 30 | .. option:: --arch=<arch> |
| 31 | |
| 32 | Architecture(s) from Mach-O universal binaries to display information for. |
| 33 | |
| 34 | .. option:: -B |
| 35 | |
| 36 | Equivalent to :option:`--format` with a value of ``berkeley``. |
| 37 | |
| 38 | .. option:: --common |
| 39 | |
| 40 | Include ELF common symbol sizes in bss size for ``berkeley`` output format, or |
| 41 | as a separate section entry for ``sysv`` output. If not specified, these |
James Henderson | eefbc35 | 2019-09-24 13:14:22 +0000 | [diff] [blame] | 42 | symbols are ignored. |
James Henderson | e8ed932 | 2019-09-16 13:20:37 +0000 | [diff] [blame] | 43 | |
| 44 | .. option:: -d |
| 45 | |
| 46 | Equivalent to :option:`--radix` with a value of ``10``. |
| 47 | |
| 48 | .. option:: -l |
| 49 | |
| 50 | Display verbose address and offset information for segments and sections in |
| 51 | Mach-O files in ``darwin`` format. |
| 52 | |
| 53 | .. option:: --format=<format> |
| 54 | |
| 55 | Set the output format to the ``<format>`` specified. Available ``<format>`` |
| 56 | options are ``berkeley`` (the default), ``sysv`` and ``darwin``. |
| 57 | |
| 58 | Berkeley output summarises text, data and bss sizes in each file, as shown |
| 59 | below for a typical pair of ELF files: |
| 60 | |
| 61 | .. code-block:: console |
| 62 | |
| 63 | $ llvm-size --format=berkeley test.o test2.o |
| 64 | text data bss dec hex filename |
| 65 | 182 16 5 203 cb test.elf |
| 66 | 82 8 1 91 5b test2.o |
| 67 | |
| 68 | For Mach-O files, the output format is slightly different: |
| 69 | |
| 70 | .. code-block:: console |
| 71 | |
| 72 | $ llvm-size --format=berkeley macho.obj macho2.obj |
| 73 | __TEXT __DATA __OBJC others dec hex |
| 74 | 4 8 0 0 12 c macho.obj |
| 75 | 16 32 0 0 48 30 macho2.obj |
| 76 | |
| 77 | Sysv output displays size and address information for most sections, with each |
| 78 | file being listed separately: |
| 79 | |
| 80 | .. code-block:: console |
| 81 | |
| 82 | $ llvm-size --format=sysv test.elf test2.o |
| 83 | test.elf : |
| 84 | section size addr |
| 85 | .eh_frame 92 2097496 |
| 86 | .text 90 2101248 |
| 87 | .data 16 2105344 |
| 88 | .bss 5 2105360 |
| 89 | .comment 209 0 |
| 90 | Total 412 |
| 91 | |
| 92 | test2.o : |
| 93 | section size addr |
| 94 | .text 26 0 |
| 95 | .data 8 0 |
| 96 | .bss 1 0 |
| 97 | .comment 106 0 |
| 98 | .note.GNU-stack 0 0 |
| 99 | .eh_frame 56 0 |
| 100 | .llvm_addrsig 2 0 |
| 101 | Total 199 |
| 102 | |
| 103 | ``darwin`` format only affects Mach-O input files. If an input of a different |
| 104 | file format is specified, :program:`llvm-size` falls back to ``berkeley`` |
| 105 | format. When producing ``darwin`` format, the tool displays information about |
| 106 | segments and sections: |
| 107 | |
| 108 | .. code-block:: console |
| 109 | |
| 110 | $ llvm-size --format=darwin macho.obj macho2.obj |
| 111 | macho.obj: |
| 112 | Segment : 12 |
| 113 | Section (__TEXT, __text): 4 |
| 114 | Section (__DATA, __data): 8 |
| 115 | total 12 |
| 116 | total 12 |
| 117 | macho2.obj: |
| 118 | Segment : 48 |
| 119 | Section (__TEXT, __text): 16 |
| 120 | Section (__DATA, __data): 32 |
| 121 | total 48 |
| 122 | total 48 |
| 123 | |
| 124 | .. option:: --help, -h |
| 125 | |
| 126 | Display a summary of command line options. |
| 127 | |
| 128 | .. option:: --help-list |
| 129 | |
| 130 | Display an uncategorized summary of command line options. |
| 131 | |
| 132 | .. option:: -m |
| 133 | |
| 134 | Equivalent to :option:`--format` with a value of ``darwin``. |
| 135 | |
| 136 | .. option:: -o |
| 137 | |
| 138 | Equivalent to :option:`--radix` with a value of ``8``. |
| 139 | |
| 140 | .. option:: --radix=<value> |
| 141 | |
| 142 | Display size information in the specified radix. Permitted values are ``8``, |
| 143 | ``10`` (the default) and ``16`` for octal, decimal and hexadecimal output |
| 144 | respectively. |
| 145 | |
| 146 | Example: |
| 147 | |
| 148 | .. code-block:: console |
| 149 | |
| 150 | $ llvm-size --radix=8 test.o |
| 151 | text data bss oct hex filename |
| 152 | 0152 04 04 162 72 test.o |
| 153 | |
| 154 | $ llvm-size --radix=10 test.o |
| 155 | text data bss dec hex filename |
| 156 | 106 4 4 114 72 test.o |
| 157 | |
| 158 | $ llvm-size --radix=16 test.o |
| 159 | text data bss dec hex filename |
| 160 | 0x6a 0x4 0x4 114 72 test.o |
| 161 | |
| 162 | .. option:: --totals, -t |
| 163 | |
| 164 | Applies only to ``berkeley`` output format. Display the totals for all listed |
| 165 | fields, in addition to the individual file listings. |
| 166 | |
| 167 | Example: |
| 168 | |
| 169 | .. code-block:: console |
| 170 | |
| 171 | $ llvm-size --totals test.elf test2.o |
| 172 | text data bss dec hex filename |
| 173 | 182 16 5 203 cb test.elf |
| 174 | 82 8 1 91 5b test2.o |
| 175 | 264 24 6 294 126 (TOTALS) |
| 176 | |
| 177 | .. option:: --version |
| 178 | |
| 179 | Display the version of the :program:`llvm-size` executable. |
| 180 | |
| 181 | .. option:: -x |
| 182 | |
| 183 | Equivalent to :option:`--radix` with a value of ``16``. |
| 184 | |
| 185 | .. option:: @<FILE> |
| 186 | |
| 187 | Read command-line options from response file ``<FILE>``. |
| 188 | |
| 189 | EXIT STATUS |
| 190 | ----------- |
| 191 | |
| 192 | :program:`llvm-size` exits with a non-zero exit code if there is an error. |
| 193 | Otherwise, it exits with code 0. |
| 194 | |
| 195 | BUGS |
| 196 | ---- |
| 197 | |
Sylvestre Ledru | 9860517 | 2020-03-22 22:45:15 +0100 | [diff] [blame] | 198 | To report bugs, please visit <https://bugs.llvm.org/>. |