xref: /freebsd/contrib/elftoolchain/nm/nm.1 (revision b2d2a78ad80ec68d4a17f5aef97d21686cb1e29b)
1.\" Copyright (c) 2007 Hyogeol Lee <hyogeollee@gmail.com>
2.\" All rights reserved.
3.\"
4.\" Redistribution and use in source and binary forms, with or without
5.\" modification, are permitted provided that the following conditions
6.\" are met:
7.\" 1. Redistributions of source code must retain the above copyright
8.\"    notice, this list of conditions and the following disclaimer
9.\"    in this position and unchanged.
10.\" 2. Redistributions in binary form must reproduce the above copyright
11.\"    notice, this list of conditions and the following disclaimer in the
12.\"    documentation and/or other materials provided with the distribution.
13.\"
14.\" THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR
15.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
16.\" OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
17.\" IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
18.\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
19.\" NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
20.\" DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
21.\" THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22.\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
23.\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24.\"
25.\" $Id: nm.1 3642 2018-10-14 14:24:28Z jkoshy $
26.\"
27.Dd September 13, 2017
28.Dt NM 1
29.Os
30.Sh NAME
31.Nm nm
32.Nd display symbolic information in object files
33.Sh SYNOPSIS
34.Nm
35.Op Fl -debug-syms
36.Op Fl -defined-only
37.Op Fl -demangle Ns Op = Ns style
38.Op Fl -dynamic
39.Op Fl -extern-only
40.Op Fl -help
41.Op Fl -line-numbers
42.Op Fl -no-demangle
43.Op Fl -no-sort
44.Op Fl -numeric-sort
45.Op Fl -print-armap
46.Op Fl -print-file-name
47.Op Fl -print-size
48.Op Fl -radix= Ns Ar format
49.Op Fl -reverse-sort
50.Op Fl -size-sort
51.Op Fl -undefined-only
52.Op Fl -version
53.Op Fl A
54.Op Fl B
55.Op Fl C Op Ar style
56.Op Fl D
57.Op Fl P
58.Op Fl V
59.Op Fl a
60.Op Fl e
61.Op Fl g
62.Op Fl h
63.Op Fl l
64.Op Fl n
65.Op Fl o
66.Op Fl p
67.Op Fl r
68.Op Fl S
69.Op Fl s
70.Op Fl t Ar format
71.Op Fl u
72.Op Fl x
73.Ar
74.Sh DESCRIPTION
75The
76.Nm
77utility displays symbolic information in the object files,
78executables, and object library files named by its arguments.
79Lack of symbolic information in an otherwise valid input
80file, is not considered to be an error.
81If no files are specified on the command line,
82.Nm
83will attempt to read
84.Pa a.out .
85.Pp
86The
87.Nm
88utility recognizes the following options:
89.Bl -tag -width ".Fl d Ar argument"
90.It Fl -debug-syms
91Display all symbols, including debugger-only symbols.
92.It Fl -defined-only
93Display only defined symbols.
94.It Fl -demangle Ns Op = Ns Ar style
95Decode (demangle) low-level symbol names into human-readable names.
96Supported values for argument
97.Ar style
98are
99.Sq auto ,
100.Sq gnu-v2 ,
101.Sq gnu-v3
102and
103.Sq arm.
104If argument
105.Ar style
106is not specified, it is taken to be
107.Sq auto .
108.It Fl -dynamic
109Only display dynamic symbols.
110This option is only meaningful for shared libraries.
111.It Fl -extern-only
112Only display information about global (external) symbols.
113.It Fl -help
114Display a help message and exit.
115.It Fl -format Ns = Ns Ar format
116Display output in the format specified by argument
117.Ar format .
118Supported values for the format argument are
119.Sq bsd ,
120.Sq sysv ,
121and
122.Sq posix .
123The default output format is
124.Sq bsd .
125.It Fl -line-numbers
126Display the filename and line number associated a symbol using
127any debugging information present in the input file.
128For defined symbols, look up the line number associated with
129the address of the symbol.
130For undefined symbols, look up the line number associated with
131a relocation entry that refers to the symbol.
132If line number information can be determined, it is displayed after
133other symbol information.
134.It Fl -no-demangle
135Do not demangle symbol names (default).
136.It Fl -no-sort
137Do not sort symbols.
138.It Fl -numeric-sort
139Sort symbols numerically by address instead of alphabetically by name.
140.It Fl -print-armap
141For
142.Xr ar 1
143archives, include the index of the archive's members.
144.It Fl -print-file-name
145Write the full pathname or library name of an object on each line,
146before the rest of the information for a symbol.
147If this option is not specified,
148.Nm
149will only identify an input file once, before its symbols are
150listed.
151.It Fl -print-size
152Print the size of each symbol instead of its value.
153.It Fl -radix Ns = Ns Ar radix
154Print numeric values using the specified radix.
155Supported values for argument
156.Ar radix
157are
158.Sq d
159for decimal,
160.Sq o
161for octal, and
162.Sq x
163for hexadecimal.
164.It Fl -reverse-sort
165Reverse the order of the sort.
166.It Fl -size-sort
167Sort symbols by size instead of alphabetically by name.
168.It Fl -undefined-only
169Display only undefined symbols.
170.It Fl -version
171Display the version identifier for
172.Nm
173and exit.
174.It Fl A
175Equivalent to specifying option
176.Fl -print-file-name .
177.It Fl B
178Equivalent to specifying option
179.Fl -format= Ns Ar bsd .
180.It Fl C Op Ar style
181Equivalent to specifying option
182.Fl -demangle Ns Op = Ns Ar style .
183.It Fl D
184Equivalent to specifying option
185.Fl -dynamic .
186.It Fl F Ar format
187Equivalent to specifying option
188.Fl -format Ns = Ns Ar format .
189.It Fl P
190Equivalent to specifying option
191.Fl -format Ns = Ns Ar posix .
192.It Fl S
193Equivalent to specifying option
194.Fl -print-size .
195.It Fl V
196Equivalent to specifying option
197.Fl -version .
198.It Fl a
199Equivalent to specifying option
200.Fl -debug-syms .
201.It Fl e
202Only display information for global and static symbols.
203.It Fl f
204Produce full output (default).
205.It Fl g
206Equivalent to specifying option
207.Fl -extern-only .
208.It Fl h
209Equivalent to specifying option
210.Fl -help .
211.It Fl l
212Equivalent to specifying option
213.Fl -line-numbers .
214.It Fl n
215Equivalent to specifying option
216.Fl -numeric-sort .
217.It Fl o
218If POSIX output was specified using the
219.Fl F Ar posix
220or
221.Fl P
222options, this option is equivalent to specifying
223.Fl -radix Ns = Ns Sq Ar o .
224If POSIX output was not specified, this option
225acts as a synonym for the
226.Fl -print-file-name
227option.
228.It Fl p
229Equivalent to specifying option
230.Fl -no-sort .
231.It Fl v
232Equivalent to option
233.Fl n .
234.It Fl r
235Equivalent to specifying option
236.Fl -reverse-sort
237.It Fl s
238Equivalent to specifying option
239.Fl -print-armap .
240.It Fl t Ar radix
241Equivalent to specifying option
242.Fl -radix= Ns Ar radix .
243.It Fl u
244Equivalent to specifying option
245.Fl -undefined-only .
246.It Fl x
247Write numeric values in hexadecimal (equivalent to -t x).
248.El
249.Sh OUTPUT FORMAT
250.Pp
251The
252.Nm
253utility can present its information in a number of formats, numeric
254radices and sort orders.
255By default
256.Nm
257uses BSD style output, a hexadecimal radix, without output sorted
258alphabetically by name and without demangling of names.
259.Pp
260For each symbol listed,
261.Nm
262presents the following information:
263.Bl -bullet -compact
264.It
265The library or object name, if options
266.Fl A
267or
268.Fl -print-file-name
269were specified.
270.It
271The symbol name.
272.It
273The type of the symbol denoted by a single character as below:
274.Bl -tag -compact -width indent
275.It A
276A global, absolute symbol.
277.It B
278A global
279.Dq bss
280(uninitialized data) symbol.
281.It C
282A
283.Dq common
284symbol, representing uninitialized data.
285.It D
286A global symbol naming initialized data.
287.It N
288A debugger symbol.
289.It R
290A read-only data symbol.
291.It T
292A global text symbol.
293.It U
294An undefined symbol.
295.It V
296A weak object.
297.It W
298A weak reference.
299.It a
300A local absolute symbol.
301.It b
302A local
303.Dq bss
304(uninitialized data) symbol.
305.It d
306A local data symbol.
307.It r
308A local read-only data symbol.
309.It t
310A local text symbol.
311.It v
312A weak object that is undefined.
313.It w
314A weak symbol that is undefined.
315.It ?
316None of the above.
317.El
318.It
319The value of the symbol.
320.It
321The size of the symbol if applicable.
322.It
323Line number information, if available and if options
324.Fl l
325or
326.Fl -line-numbers
327were specified.
328.El
329.Sh EXIT STATUS
330.Ex -std
331.Sh SEE ALSO
332.Xr ar 1 ,
333.Xr objdump 1 ,
334.Xr ranlib 1 ,
335.Xr elf 3
336.Sh AUTHORS
337The
338.Nm
339utility and this manual page were written by
340.An Hyogeol Lee Aq Mt hyogeollee@gmail.com .
341