from small one page howto to huge articles all in one place
 

search text in:





Poll
Which screen resolution do you use?










poll results

Last additions:
using iotop to find disk usage hogs

using iotop to find disk usage hogs

words:

887

views:

193561

userrating:

average rating: 1.7 (102 votes) (1=very good 6=terrible)


May 25th. 2007:
Words

486

Views

251693

why adblockers are bad


Workaround and fixes for the current Core Dump Handling vulnerability affected kernels

Workaround and fixes for the current Core Dump Handling vulnerability affected kernels

words:

161

views:

140568

userrating:

average rating: 1.4 (42 votes) (1=very good 6=terrible)


April, 26th. 2006:

Druckversion
You are here: manpages





SCANELF

Section: Documentation for pax-utils (1)
Updated: 01/24/2017
Index Return to Main Contents
 

NAME

scanelf - user-space utility to scan ELF files  

SYNOPSIS

scanelf [options] ELFs or directories
 

DESCRIPTION

scanelf

is a user-space utility to quickly scan given ELFs, directories, or common system paths for different information. This may include ELF types, their PaX markings, TEXTRELs, etc...  

OPTIONS

-A, --archives

Scan archives (.a files)

-a, --all

Print all useful/simple info

-B, --nobanner

Don't display the header

-b, --bind

Print symbol binding information (lazy or now)

-D, --endian

Print ELF endianness (big/little/...)

-E, --etype ETYPE

Print only ELF files matching specified etype (like ET_DYN, ET_EXEC, etc...)

-e, --header

Print GNU_STACK markings

-F, --format FORMAT

Use specified format for output; see the FORMAT section for more information

-f, --from FILE

Read input stream from specified filename

-g, --gmatch

Use strncmp to match libraries (use with -N). Or regexp with symbol matching

-h, --help

Show condensed usage and exit

-I, --osabi

Print OSABI

-i, --interp

Print the interpreter information (.interp/PT_INTERP)

-k, --section SECTION

Find ELFs with the specified section. May be specified multiple times to match multiple sections simultaneously. See SECTION MATCHING for more info.

-L, --ldcache

Utilize ld.so.cache information (use with -r/-n)

-l, --ldpath

Scan all directories in /etc/ld.so.conf

-M, --bits BITS

Print only ELF files matching specified numeric bits (like 32/64)

-m, --mount

Don't recursively cross mount points

-N, --lib SONAME

Find ELFs that need the specified SONAME. May be specified multiple times to match multiple SONAMEs simultaneously. See SONAME MATCHING for more info.

-n, --needed

Print libraries the ELF is linked against (DT_NEEDED)

-O, --perms PERMS

Print only ELF files with matching specified octal bits (like 755)

-o, --file FILE

Write output stream to specified filename

-p, --path

Scan all directories in PATH environment

-q, --quiet

Only output 'bad' things

-R, --recursive

Scan directories recursively

-r, --rpath

Print runpaths encoded in the ELF (DT_RPATH/DT_RUNPATH)

-S, --soname

Print the ELF's shared library name (DT_SONAME)

-s, --symbol SYMBOL

Find the specified symbol; see SYMBOL MATCHING for more info

-T, --textrels

Locate cause of TEXTRELs via objdump

-t, --textrel

Print TEXTREL information

-V, --version

Print version and exit

-v, --verbose

Be verbose (can be used more than once)

-X, --fix

Try and 'fix' bad things (use with -r/-e)

-x, --pax

Print PaX markings

-Y, --eabi

Print EABI (only matters for a few architectures)

-y, --symlink

Don't scan symlinks

-Z, --size SIZE

Print ELF file size

-z, --setpax FLAGS

Sets EI_PAX/PT_PAX_FLAGS to specified flags (use with -Xx)

--use-ldpath

Use the ld.so.conf paths to find the full path to libraries (use in conjunction with --needed).

--root PATH

Search the specified root tree instead of /. Generally paired with options like -l or -p. This implicitly treats all paths specified on the command line as relative to the root, so be sure to omit it if you are explicitly listing ELFs.
 

FORMAT

The format string is much like a printf string in that it is a literal string with flags requesting different information. For example, you could use a format string and expect the following results.

  # scanelf -BF "file %f needs %n; funky time" /bin/bash
  file bash needs libncurses.so.5,libdl.so.2,libc.so.6; funky time
 

Note that when you use a format string, generally information related flags should be omitted. In other words, you do not want to try and request NEEDED output (-n) and try to specify a format output at the same time as these operations are mutually exclusive. Each information related flag has an equivalent conversion specifier, so use those instead. You can of course continue to use non-information related flags (such as --verbose).

There are three characters that introduce conversion specifiers.

* % - replace with info

*
# - silent boolean match

*
+ - verbose match

And there are a number of conversion specifiers. We try to match up the specifier with corresponding option.

* a - machine (EM) type

*
b - bind flags

*
e - program headers

*
D - endian

*
I - osabi

*
Y - eabi

*
F - long filename

*
f - short filename

*
i - interp

*
k - section

*
M - EI class

*
N - specified needed

*
n - needed libraries

*
p - filename (minus search)

*
o - etype

*
O - perms

*
r - runpaths

*
S - SONAME

*
s - symbol

*
T - all textrels

*
t - textrel status

*
x - pax flags

 

SYMBOL MATCHING

The string specified takes the form [%[modifiers]%][[+-]<symbol name>][,[.....]].

If the symbol name is empty, then all symbols are matched.

If the symbol name is a glob ("*"), then all symbols are dumped in a debug format. Do not rely on the structure of this output as it changes whenever we feel like it.

If the first char of the symbol name is a plus ("+"), then only match defined symbols. If it's a minus ("-"), only match undefined symbols. When we say "defined", we mean the symbol is defined in the ELF vs having an external reference.

Putting modifiers in between the percent signs ("%") allows for more in depth filters. There are groups of modifiers. If you don't specify a member of a group, then all types in that group are matched.

* STT group (symbol type)

*
n - STT_NOTYPE

*
o - STT_OBJECT

*
f - STT_FUNC

*
F - STT_FILE

*
STB group (symbol binding)

*
l - STB_LOCAL

*
g - STB_GLOBAL

*
w - STB_WEAK

*
STV group (symbol visibility)

*
p - STV_DEFAULT

*
i - STV_INTERNAL

*
h - STV_HIDDEN

*
P - STV_PROTECTED

*
SHN group (section header)

*
d - defined

*
u - SHN_UNDEF

*
a - SHN_ABS

*
c - SHN_COMMON

You can search for multiple symbols simultaneously by using a comma (",") to separate different searches. Every symbol that matches will be displayed while unmatched symbols will not.  

ELF ETYPES

You can narrow your search by specifying the ELF object file type (ETYPE). The commandline option takes the numeric value and or symbolic type. Multiple values can be passed comma separated. Example -E ET_EXEC,ET_DYN,1

Here is the normal list available for your pleasure. You of course are free to specify any numeric value you want.

* 0 - ET_NONE - unknown type

*
1 - ET_REL - relocatable file

*
2 - ET_EXEC - executable file

*
3 - ET_DYN - shared object

*
4 - ET_CORE - core file

 

ELF BITS

You can also narrow your search by specifying the ELF bitsize. Again, specify the numeric value or the symbolic define.

* 32 - ELFCLASS32 - 32bit ELFs

*
64 - ELFCLASS64 - 64bit ELFs

 

SECTION MATCHING

A ! prefix will only show ELF's that do not have the specified section.  

NEEDED SONAME MATCHING

A ! prefix will only show ELF's that do not depend on the specified library.  

HOMEPAGE

m[blue]http://hardened.gentoo.org/pax-utils.xmlm[]  

REPORTING BUGS

Please include as much information as possible (using any available debugging options) and send bug reports to the maintainers (see the AUTHORS section). Please use the Gentoo bugzilla at m[blue]http://bugs.gentoo.org/m[] if possible.  

SEE ALSO

chpax(1), dumpelf(1), paxctl(1), pspax(1), readelf(1), scanelf(1), elf(5)  

AUTHORS

Ned Ludd <solar@gentoo.org>

Maintainer

Mike Frysinger <vapier@gentoo.org>

Maintainer

Fabian Groffen <grobian@gentoo.org>

Mach-O Maintainer
 

NOTES

1.
http://hardened.gentoo.org/pax-utils.xml
2.
http://bugs.gentoo.org/


 

Index

NAME
SYNOPSIS
DESCRIPTION
OPTIONS
FORMAT
SYMBOL MATCHING
ELF ETYPES
ELF BITS
SECTION MATCHING
NEEDED SONAME MATCHING
HOMEPAGE
REPORTING BUGS
SEE ALSO
AUTHORS
NOTES





Support us on Content Nation
rdf newsfeed | rss newsfeed | Atom newsfeed
- Powered by LeopardCMS - Running on Gentoo -
Copyright 2004-2020 Sascha Nitsch Unternehmensberatung GmbH
Valid XHTML1.1 : Valid CSS : buttonmaker
- Level Triple-A Conformance to Web Content Accessibility Guidelines 1.0 -
- Copyright and legal notices -
Time to create this page: 15.6 ms