xref: /freebsd/contrib/elftoolchain/readelf/readelf.1 (revision b6d812d2dd13cc529373804524174497a73a4818)
12c23cb7cSEd Maste.\" Copyright (c) 2009,2011 Joseph Koshy <jkoshy@users.sourceforge.net>
22c23cb7cSEd Maste.\" All rights reserved.
32c23cb7cSEd Maste.\"
42c23cb7cSEd Maste.\" Redistribution and use in source and binary forms, with or without
52c23cb7cSEd Maste.\" modification, are permitted provided that the following conditions
62c23cb7cSEd Maste.\" are met:
72c23cb7cSEd Maste.\" 1. Redistributions of source code must retain the above copyright
82c23cb7cSEd Maste.\"    notice, this list of conditions and the following disclaimer
92c23cb7cSEd Maste.\"    in this position and unchanged.
102c23cb7cSEd Maste.\" 2. Redistributions in binary form must reproduce the above copyright
112c23cb7cSEd Maste.\"    notice, this list of conditions and the following disclaimer in the
122c23cb7cSEd Maste.\"    documentation and/or other materials provided with the distribution.
132c23cb7cSEd Maste.\"
142c23cb7cSEd Maste.\" THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR
152c23cb7cSEd Maste.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
162c23cb7cSEd Maste.\" OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
172c23cb7cSEd Maste.\" IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
182c23cb7cSEd Maste.\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
192c23cb7cSEd Maste.\" NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
202c23cb7cSEd Maste.\" DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
212c23cb7cSEd Maste.\" THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
222c23cb7cSEd Maste.\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
232c23cb7cSEd Maste.\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
242c23cb7cSEd Maste.\"
25*b6d812d2SEd Maste.\" $Id: readelf.1 3486 2016-08-22 14:10:05Z emaste $
262c23cb7cSEd Maste.\"
272c23cb7cSEd Maste.Dd September 13, 2012
282c23cb7cSEd Maste.Os
292c23cb7cSEd Maste.Dt READELF 1
302c23cb7cSEd Maste.Sh NAME
312c23cb7cSEd Maste.Nm readelf
322c23cb7cSEd Maste.Nd display information about ELF objects
332c23cb7cSEd Maste.Sh SYNOPSIS
342c23cb7cSEd Maste.Nm
352c23cb7cSEd Maste.Op Fl a | Fl -all
362c23cb7cSEd Maste.Op Fl c | Fl -archive-index
372c23cb7cSEd Maste.Op Fl d | Fl -dynamic
382c23cb7cSEd Maste.Op Fl e | Fl -headers
392c23cb7cSEd Maste.Op Fl g | Fl -section-groups
402c23cb7cSEd Maste.Op Fl h | Fl -file-header
412c23cb7cSEd Maste.Op Fl l | Fl -program-headers
422c23cb7cSEd Maste.Op Fl n | Fl -notes
432c23cb7cSEd Maste.Op Fl p Ar section | Fl -string-dump Ns = Ns Ar section
442c23cb7cSEd Maste.Op Fl r | Fl -relocs
452c23cb7cSEd Maste.Op Fl t | Fl -section-details
462c23cb7cSEd Maste.Op Fl v | Fl -version
472c23cb7cSEd Maste.Oo
482c23cb7cSEd Maste.Fl w Ns Oo Ns Ar afilmoprsFLR Ns Oc |
492c23cb7cSEd Maste.Fl -debug-dump Ns Op Ns = Ns Ar long-option-name , Ns ...
502c23cb7cSEd Maste.Oc
51*b6d812d2SEd Maste.Op Fl x Ar section | Fl -hex-dump Ns = Ns Ar section
522c23cb7cSEd Maste.Op Fl A | Fl -arch-specific
532c23cb7cSEd Maste.Op Fl D | Fl -use-dynamic
542c23cb7cSEd Maste.Op Fl H | Fl -help
552c23cb7cSEd Maste.Op Fl I | Fl -histogram
562c23cb7cSEd Maste.Op Fl N | -full-section-name
572c23cb7cSEd Maste.Op Fl S | Fl -sections | Fl -section-headers
582c23cb7cSEd Maste.Op Fl V | Fl -version-info
592c23cb7cSEd Maste.Op Fl W | Fl -wide
602c23cb7cSEd Maste.Ar file...
612c23cb7cSEd Maste.Sh DESCRIPTION
622c23cb7cSEd MasteThe
632c23cb7cSEd Maste.Nm
642c23cb7cSEd Masteutility displays information about ELF objects and
652c23cb7cSEd Maste.Xr ar 1
662c23cb7cSEd Mastearchives.
672c23cb7cSEd Maste.Pp
682c23cb7cSEd MasteThe
692c23cb7cSEd Maste.Nm
702c23cb7cSEd Masteutility recognizes the following options:
712c23cb7cSEd Maste.Bl -tag -width indent
722c23cb7cSEd Maste.It Fl a | Fl -all
732c23cb7cSEd MasteTurn on the following flags:
742c23cb7cSEd Maste.Fl d ,
752c23cb7cSEd Maste.Fl h ,
762c23cb7cSEd Maste.Fl I ,
772c23cb7cSEd Maste.Fl l ,
782c23cb7cSEd Maste.Fl r ,
792c23cb7cSEd Maste.Fl s ,
802c23cb7cSEd Maste.Fl A ,
812c23cb7cSEd Maste.Fl S
822c23cb7cSEd Masteand
832c23cb7cSEd Maste.Fl V .
842c23cb7cSEd Maste.It Fl c | Fl -archive-index
852c23cb7cSEd MastePrint the archive symbol table for archives.
862c23cb7cSEd Maste.It Fl d | Fl -dynamic
872c23cb7cSEd MastePrint the contents of the
882c23cb7cSEd Maste.Li SHT_DYNAMIC
892c23cb7cSEd Mastesections in the ELF object.
902c23cb7cSEd Maste.It Fl e | Fl -headers
912c23cb7cSEd MastePrint all program, file and section headers in the ELF object.
922c23cb7cSEd Maste.It Fl g | Fl -section-groups
933ef90571SEd MastePrint the contents of the section groups in the ELF object.
942c23cb7cSEd Maste.It Fl h | Fl -file-header
952c23cb7cSEd MastePrint the file header of the ELF object.
962c23cb7cSEd Maste.It Fl l | Fl -program-headers
972c23cb7cSEd MastePrint the content of the program header table for the object.
982c23cb7cSEd Maste.It Fl n | Fl -notes
992c23cb7cSEd MastePrint the contents of
1002c23cb7cSEd Maste.Li PT_NOTE
1012c23cb7cSEd Mastesegments or
1022c23cb7cSEd Maste.Li SHT_NOTE
1032c23cb7cSEd Mastesections present in the ELF object.
1042c23cb7cSEd Maste.It Fl p Ar section | Fl -string-dump Ns = Ns Ar section
1052c23cb7cSEd MastePrint the contents of the specified section as printable strings.
1062c23cb7cSEd MasteThe argument
1072c23cb7cSEd Maste.Ar section
1082c23cb7cSEd Masteshould be the name of a section or a numeric section index.
1092c23cb7cSEd Maste.It Fl r | Fl -relocs
1102c23cb7cSEd MastePrint relocation information.
1112c23cb7cSEd Maste.It Fl s | Fl -syms | Fl -symbols
1122c23cb7cSEd MastePrint symbol tables.
1132c23cb7cSEd Maste.It Fl t | Fl -section-details
1142c23cb7cSEd MastePrint additional information about sections, such as the flags
1152c23cb7cSEd Mastefields in section headers.
1162c23cb7cSEd Maste.It Fl v | Fl -version
1172c23cb7cSEd MastePrints a version identifier for
1182c23cb7cSEd Maste.Nm
1192c23cb7cSEd Masteand exits.
1202c23cb7cSEd Maste.It Fl w Ns Oo afilmoprsFLR Oc | Xo
1212c23cb7cSEd Maste.Fl -debug-dump Ns Op Ns = Ns Ar long-option-name , Ns ...
1222c23cb7cSEd Maste.Xc
1232c23cb7cSEd MasteDisplay DWARF information.
1242c23cb7cSEd MasteThe
1252c23cb7cSEd Maste.Fl w
1262c23cb7cSEd Masteoption is used with the short options in the following
1272c23cb7cSEd Mastetable; the
1282c23cb7cSEd Maste.Fl -debug-dump
1292c23cb7cSEd Masteoption is used with a comma-separated list of the corresponding long
1302c23cb7cSEd Masteoption names:
1312c23cb7cSEd Maste.Bl -column ".Em Short Option" "aranges|ranges"
1322c23cb7cSEd Maste.It Em Short Option Ta Em Long Option Ta Em Description
1332c23cb7cSEd Maste.It a Ta abbrev Ta Show abbreviation information.
1342c23cb7cSEd Maste.It f Ta frames Ta Show frame information, displaying frame instructions.
1352c23cb7cSEd Maste.It i Ta info Ta Show debugging information entries.
1362c23cb7cSEd Maste.It l Ta rawline Ta Show line information in raw form.
1372c23cb7cSEd Maste.It m Ta macro Ta Show macro information.
1382c23cb7cSEd Maste.It o Ta loc Ta Show location list information.
1392c23cb7cSEd Maste.It p Ta pubnames Ta Show global names.
1402c23cb7cSEd Maste.It r Ta aranges|ranges Ta Show address range information.
1412c23cb7cSEd Maste.It s Ta str Ta Show the debug string table.
142cf781b2eSEd Maste.It F Ta frames-interp Ta Show frame information, displaying register rules.
1432c23cb7cSEd Maste.It L Ta decodedline Ta Show line information in decoded form.
1442c23cb7cSEd Maste.It R Ta Ranges Ta Show range lists.
1452c23cb7cSEd Maste.El
1462c23cb7cSEd Maste.Pp
1472c23cb7cSEd MasteIf no sub-options are specified, the default is to show information
1482c23cb7cSEd Mastecorresponding to the
1492c23cb7cSEd Maste.Ar a , f , i, l , o , p , r , s
1502c23cb7cSEd Masteand
1512c23cb7cSEd Maste.Ar R
1522c23cb7cSEd Masteshort options.
1532c23cb7cSEd Maste.It Fl x Ar section | Fl -hex-dump Ns = Ns Ar section
1542c23cb7cSEd MasteDisplay the contents of the specified section in hexadecimal.
1552c23cb7cSEd MasteThe argument
1562c23cb7cSEd Maste.Ar section
1572c23cb7cSEd Masteshould be the name of a section or a numeric section index.
1582c23cb7cSEd Maste.It Fl A | Fl -arch-specific
1592c23cb7cSEd MasteThis option is accepted but is currently unimplemented.
1602c23cb7cSEd Maste.It Fl D | Fl -use-dynamic
1612c23cb7cSEd MastePrint the symbol table specified by the
1622c23cb7cSEd Maste.Li DT_SYMTAB
1632c23cb7cSEd Masteentry in the
1642c23cb7cSEd Maste.Dq Li .dynamic
1652c23cb7cSEd Mastesection.
1662c23cb7cSEd Maste.It Fl H | Fl -help
1672c23cb7cSEd MastePrint a help message.
1682c23cb7cSEd Maste.It Fl I | Fl -histogram
1692c23cb7cSEd MastePrint information on bucket list lengths for sections of type
1702c23cb7cSEd Maste.Li SHT_HASH
1712c23cb7cSEd Masteand
1722c23cb7cSEd Maste.Li SHT_GNU_HASH .
1732c23cb7cSEd Maste.It Fl N | Fl -full-section-name
1742c23cb7cSEd MasteThis option is accepted but is currently unimplemented.
1752c23cb7cSEd Maste.It Fl S | Fl -sections | Fl -section-headers
1762c23cb7cSEd MastePrint information in the section headers for each ELF object.
1772c23cb7cSEd Maste.It Fl V | Fl -version-info
1782c23cb7cSEd MastePrint symbol versioning information.
1792c23cb7cSEd Maste.It Fl W | Fl -wide
1802c23cb7cSEd MastePrint information about ELF structures using one long line per
1812c23cb7cSEd Mastestructure.
1822c23cb7cSEd MasteIf this option is not specified,
1832c23cb7cSEd Maste.Nm
1842c23cb7cSEd Mastewill list information in the headers of 64 bit ELF objects on two
1852c23cb7cSEd Masteseparate lines.
1862c23cb7cSEd Maste.El
1872c23cb7cSEd Maste.Sh EXIT STATUS
1882c23cb7cSEd Maste.Ex -std
1892c23cb7cSEd Maste.Sh SEE ALSO
1902c23cb7cSEd Maste.Xr nm 1 ,
1912c23cb7cSEd Maste.Xr addr2line 1 ,
1922c23cb7cSEd Maste.Xr elfcopy 1 ,
1932c23cb7cSEd Maste.Sh AUTHORS
1942c23cb7cSEd MasteThe
1952c23cb7cSEd Maste.Nm
1962c23cb7cSEd Masteutility was written by
197b00fe64fSEd Maste.An Kai Wang Aq Mt kaiwang27@users.sourceforge.net .
198