ubuntuusers.de

Sehr unterschiedlich großes Kompilat

Status: Gelöst | Ubuntu-Version: Ubuntu 24.04 (Noble Numbat)
Antworten |

UlfZibis

Anmeldungsdatum:
13. Juli 2011

Beiträge: 3162

Wohnort: Köln

Hallo,

wenn ich dieses Projekt mit den MAKE-Werkzeugen baue, erhalte ich eine 121 kB große .so-Library.

autoreconf -i -s
./configure --prefix=/usr
make 

Verwende ich aber einfach nur:

cc -s -fPIC -shared media.c -o libmedia.so 

, dann erhalte ich eine 50 kB große .so-Library. Beide funktionieren ohne Probleme.

Aber wie kommt es zu diesem großen Unterschied? Was kann ich evtl. an den Configure- / Make-Files ändern, damit der Build kleiner wird?

trollsportverein

Avatar von trollsportverein

Anmeldungsdatum:
21. Oktober 2010

Beiträge: 4672

Guck doch mal rein, ob das Binary stripped ist, oder nicht.

UlfZibis

(Themenstarter)

Anmeldungsdatum:
13. Juli 2011

Beiträge: 3162

Wohnort: Köln

trollsportverein schrieb:

Guck doch mal rein, ob das Binary stripped ist, oder nicht.

Was bedeutet das und wie prüfe ich das?

trollsportverein

Avatar von trollsportverein

Anmeldungsdatum:
21. Oktober 2010

Beiträge: 4672

Im Wiki file.

file /PFAD/zum/libmedia.so 

Das configure Script sollte eigentlich auch ausgeben können, was es für Optionen gibt, etwa bei FFmpeg wird zum Beispiel --enable-stripping als configure Option angeboten.

Wenn es das nicht gibt, dann kann man nach installieren strip verwenden.

strip --strip-unneeded ZIELBINARIES

UlfZibis

(Themenstarter)

Anmeldungsdatum:
13. Juli 2011

Beiträge: 3162

Wohnort: Köln

trollsportverein schrieb:

Im Wiki file.

file /PFAD/zum/libmedia.so 

Das configure Script sollte eigentlich auch ausgeben können, was es für Optionen gibt, etwa bei FFmpeg wird zum Beispiel --enable-stripping als configure Option angeboten.

Wenn es das nicht gibt, dann kann man nach installieren strip verwenden.

strip --strip-unneeded ZIELBINARIES

Das hilft tatsächlich. Da kommen dann sogar nur 44 kB bei raus. --strip-unneeded scheint aber überflüssig zu sein, denn laut man gibt es die Option gar nicht.

$ ls -l .libs/libmedia.so
-rwxrwxr-x 1 ich ich 120960 Mär  3 23:03 .libs/libmedia.so
$ file .libs/libmedia.so
.libs/libmedia.so: ELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, BuildID[sha1]=b3b06313c520cbcd59291708f7a992e8804b7094, with debug_info, not stripped
$ strip .libs/libmedia.so
$ ls -l .libs/libmedia.so
-rwxrwxr-x 1 ich ich 44264 Mär  3 23:05 .libs/libmedia.so
$ file .libs/libmedia.so
.libs/libmedia.so: ELF 64-bit LSB shared object, x86-64, version 1 (SYSV), dynamically linked, BuildID[sha1]=b3b06313c520cbcd59291708f7a992e8804b7094, stripped

So verstehe ich jetzt auch, was die cc-Option -s bedeutet, die habe ich im man nämlich nicht gefunden (hatte das Muster nur von woanders übernommen).

Das configure gibt die Option leider nicht her:

$ ./configure --help
`configure' configures Media 1.1 to adapt to many kinds of systems.

Usage: ./configure [OPTION]... [VAR=VALUE]...

To assign environment variables (e.g., CC, CFLAGS...), specify them as
VAR=VALUE.  See below for descriptions of some of the useful variables.

Defaults for the options are specified in brackets.

Configuration:
  -h, --help              display this help and exit
      --help=short        display options specific to this package
      --help=recursive    display the short help of all the included packages
  -V, --version           display version information and exit
  -q, --quiet, --silent   do not print `checking ...' messages
      --cache-file=FILE   cache test results in FILE [disabled]
  -C, --config-cache      alias for `--cache-file=config.cache'
  -n, --no-create         do not create output files
      --srcdir=DIR        find the sources in DIR [configure dir or `..']

Installation directories:
  --prefix=PREFIX         install architecture-independent files in PREFIX
                          [/usr/local]
  --exec-prefix=EPREFIX   install architecture-dependent files in EPREFIX
                          [PREFIX]

By default, `make install' will install all the files in
`/usr/local/bin', `/usr/local/lib' etc.  You can specify
an installation prefix other than `/usr/local' using `--prefix',
for instance `--prefix=$HOME'.

For better control, use the options below.

Fine tuning of the installation directories:
  --bindir=DIR            user executables [EPREFIX/bin]
  --sbindir=DIR           system admin executables [EPREFIX/sbin]
  --libexecdir=DIR        program executables [EPREFIX/libexec]
  --sysconfdir=DIR        read-only single-machine data [PREFIX/etc]
  --sharedstatedir=DIR    modifiable architecture-independent data [PREFIX/com]
  --localstatedir=DIR     modifiable single-machine data [PREFIX/var]
  --runstatedir=DIR       modifiable per-process data [LOCALSTATEDIR/run]
  --libdir=DIR            object code libraries [EPREFIX/lib]
  --includedir=DIR        C header files [PREFIX/include]
  --oldincludedir=DIR     C header files for non-gcc [/usr/include]
  --datarootdir=DIR       read-only arch.-independent data root [PREFIX/share]
  --datadir=DIR           read-only architecture-independent data [DATAROOTDIR]
  --infodir=DIR           info documentation [DATAROOTDIR/info]
  --localedir=DIR         locale-dependent data [DATAROOTDIR/locale]
  --mandir=DIR            man documentation [DATAROOTDIR/man]
  --docdir=DIR            documentation root [DATAROOTDIR/doc/media]
  --htmldir=DIR           html documentation [DOCDIR]
  --dvidir=DIR            dvi documentation [DOCDIR]
  --pdfdir=DIR            pdf documentation [DOCDIR]
  --psdir=DIR             ps documentation [DOCDIR]

Program names:
  --program-prefix=PREFIX            prepend PREFIX to installed program names
  --program-suffix=SUFFIX            append SUFFIX to installed program names
  --program-transform-name=PROGRAM   run sed PROGRAM on installed program names

System types:
  --build=BUILD     configure for building on BUILD [guessed]
  --host=HOST       cross-compile to build programs to run on HOST [BUILD]

Optional Features:
  --disable-option-checking  ignore unrecognized --enable/--with options
  --disable-FEATURE       do not include FEATURE (same as --enable-FEATURE=no)
  --enable-FEATURE[=ARG]  include FEATURE [ARG=yes]
  --enable-silent-rules   less verbose build output (undo: "make V=1")
  --disable-silent-rules  verbose build output (undo: "make V=0")
  --enable-dependency-tracking
                          do not reject slow dependency extractors
  --disable-dependency-tracking
                          speeds up one-time build
  --enable-static[=PKGS]  build static libraries [default=no]
  --enable-shared[=PKGS]  build shared libraries [default=yes]
  --enable-fast-install[=PKGS]
                          optimize for fast installation [default=yes]
  --disable-libtool-lock  avoid locking (might break parallel builds)

Optional Packages:
  --with-PACKAGE[=ARG]    use PACKAGE [ARG=yes]
  --without-PACKAGE       do not use PACKAGE (same as --with-PACKAGE=no)
  --with-pic[=PKGS]       try to use only PIC/non-PIC objects [default=use
                          both]
  --with-aix-soname=aix|svr4|both
                          shared library versioning (aka "SONAME") variant to
                          provide on AIX, [default=aix].
  --with-gnu-ld           assume the C compiler uses GNU ld [default=no]
  --with-sysroot[=DIR]    Search for dependent libraries within DIR (or the
                          compiler's sysroot if not specified).
  --with-pilot-prefix=PFX Prefix to top level of pilot-link files (e.g., =
                          /usr/local if the pilot-link includes are in
                          /usr/local/include and libs are in /usr/local/lib)

Some influential environment variables:
  CC          C compiler command
  CFLAGS      C compiler flags
  LDFLAGS     linker flags, e.g. -L<lib dir> if you have libraries in a
              nonstandard directory <lib dir>
  LIBS        libraries to pass to the linker, e.g. -l<library>
  CPPFLAGS    (Objective) C/C++ preprocessor flags, e.g. -I<include dir> if
              you have headers in a nonstandard directory <include dir>
  LT_SYS_LIBRARY_PATH
              User-defined run-time library search path.

Use these variables to override the choices made by `configure' or to help
it to find libraries and programs with nonstandard names/locations.

Report bugs to the package provider.

Wie könnte ich die denn erzeugen, z.B. mittels passender Parameter in configure.ac oder.Makefile.am?

Die configure-Datei ist übrigens 458 kB groß, was da wohl alles drinsteht.

trollsportverein

Avatar von trollsportverein

Anmeldungsdatum:
21. Oktober 2010

Beiträge: 4672

UlfZibis schrieb:

Das hilft tatsächlich. Da kommen dann sogar nur 44 kB bei raus. --strip-unneeded scheint aber überflüssig zu sein, denn laut man gibt es die Option gar nicht.

Dann ist die Ubuntu Manual Page wohl leider unvollständig:

schollsky

Avatar von schollsky

Anmeldungsdatum:
3. Dezember 2012

Beiträge: 1712

Wohnort: Ruhrgebeat

Yep, in der manpage von strip taucht --strip-unneeded nicht auf. Die Option wird allerdings angezeigt, wenn man z.B. strip ohne Parameter aufruft...

UlfZibis

(Themenstarter)

Anmeldungsdatum:
13. Juli 2011

Beiträge: 3162

Wohnort: Köln

schollsky schrieb:

Yep, in der manpage von strip taucht --strip-unneeded nicht auf. Die Option wird allerdings angezeigt, wenn man z.B. strip ohne Parameter aufruft...

Sie taucht sowohl mit man strip als auch mit strip --help auf, nur eben nicht online auf https://manpages.ubuntu.com/manpages/noble/en/man1/strip.1posix.html

Hier allerdings schon: https://manpages.ubuntu.com/manpages/noble/en/man1/strip.1.html (unter OPTIONS)

Antworten |