source: chapter08/strippingagain.xml@ 08f72423

11.0 11.0-rc1 11.0-rc2 11.0-rc3 11.1 11.1-rc1 11.2 11.2-rc1 11.3 11.3-rc1 12.0 12.0-rc1 12.1 12.1-rc1 arm bdubbs/gcc13 ml-11.0 multilib renodr/libudev-from-systemd s6-init trunk xry111/arm64 xry111/arm64-12.0 xry111/clfs-ng xry111/lfs-next xry111/loongarch xry111/loongarch-12.0 xry111/loongarch-12.1 xry111/mips64el xry111/pip3 xry111/rust-wip-20221008 xry111/update-glibc
Last change on this file since 08f72423 was 08f72423, checked in by Xi Ruoyao <xry111@…>, 3 years ago

always use --strip-unneeded for stripping

The behavior of --strip-unneeded and --strip-all are same for
executables and shared libraries. For static libraries,
--strip-unneeded keeps the symbols needed for relocation processing so
it won't break static archives.

  • Property mode set to 100644
File size: 4.0 KB
RevLine 
[3c928f1]1<?xml version="1.0" encoding="ISO-8859-1"?>
[b06ca36]2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3 "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
[81fd230]4 <!ENTITY % general-entities SYSTEM "../general.ent">
5 %general-entities;
6]>
[ddd5542]7
[3c928f1]8<sect1 id="ch-system-strippingagain">
[ddd5542]9 <?dbhtml filename="strippingagain.html"?>
10
11 <title>Stripping Again</title>
12
[c32384e]13 <para>This section is optional. If the intended user is not a
14 programmer and does not plan to do
[ddd5542]15 any debugging on the system software, the system size can be decreased
[ad15abd]16 by about 2 GB by removing the debugging symbols from binaries and
[ddd5542]17 libraries. This causes no inconvenience other than not being able to
18 debug the software fully anymore.</para>
19
[826bbcc]20 <para>Most people who use the commands mentioned below do not
[ddd5542]21 experience any difficulties. However, it is easy to make a typo and
22 render the new system unusable, so before running the
[826bbcc]23 <command>strip</command> commands, it is a good idea to make a
[ddd5542]24 backup of the LFS system in its current state.</para>
25
[de28837]26 <para>The debugging symbols for selected libraries are placed
[11d5dee]27 in separate files. This debugging information is needed if running
[c32384e]28 regression tests that use <ulink
[826bbcc]29 url='&blfs-book;/general/valgrind.html'>valgrind</ulink> or <ulink
30 url='&blfs-book;/general/gdb.html'>gdb</ulink> later in BLFS.
[c32384e]31 </para>
[6c8a79a]32
[11d5dee]33 <para>Note that <command>strip</command> will overwrite the binary or library
34 file it is processing. This may crash the processes using code or data from
35 the file. If the process running <command>strip</command> itself is
36 affected, the binary or library being stripped may be destroyed. This may
37 make the system completely unusable. To avoid it, we'll copy some libraries
38 and binaries into <filename class="directory">/tmp</filename>, strip them
[de28837]39 there, and install them back with the <command>install</command> command.
40 Read the related entry in <xref linkend="pkgmgmt-upgrade-issues"/> for the
41 rationale to use the <command>install</command> command here.</para>
42
[77d2cd8d]43<!-- also of interest are libgfortan, libgo, libgomp, and libobjc from GCC -->
[6c8a79a]44
[00abb8f]45<!--<screen><userinput>save_lib="ld-2.25.so libc-2.25.so libpthread-2.25.so libthread_db-1.0.so"-->
[d7a9421]46<screen><userinput>save_usrlib="ld-&glibc-version;.so libc-&glibc-version;.so libpthread-&glibc-version;.so libthread_db-&libthread_db-version;.so
[de28837]47 libquadmath.so.&libquadmath-version; libstdc++.so.&libstdcpp-version;
[8ab05f2]48 libitm.so.&libitm-version; libatomic.so.&libatomic-version;" <!-- libcilkrts.so.&libcilkrts-version;-->
[c32384e]49
50cd /usr/lib
51
52for LIB in $save_usrlib; do
53 objcopy --only-keep-debug $LIB $LIB.dbg
[ff96923]54 cp $LIB /tmp/$LIB
55 strip --strip-unneeded /tmp/$LIB
56 objcopy --add-gnu-debuglink=$LIB.dbg /tmp/$LIB
57 install -vm755 /tmp/$LIB /usr/lib
58 rm /tmp/$LIB
[c32384e]59done
60
[de28837]61online_usrbin="bash find strip"
62online_usrlib="libbfd-&binutils-version;.so libdl-&glibc-version;.so
63 libhistory.so.&readline-version; libncursesw.so.&ncurses-version;
64 libm-&glibc-version;.so libreadline.so.&readline-version;
[d1592b9]65 libz.so.&zlib-version;
66 $(cd /usr/lib; find libnss*.so* -type f)"
[de28837]67
68for BIN in $online_usrbin; do
69 cp /usr/bin/$BIN /tmp/$BIN
[08f72423]70 strip --strip-unneeded /tmp/$BIN
[de28837]71 install -vm755 /tmp/$BIN /usr/bin
72 rm /tmp/$BIN
73done
[6c8a79a]74
[de28837]75for LIB in $online_usrlib; do
76 cp /usr/lib/$LIB /tmp/$LIB
77 strip --strip-unneeded /tmp/$LIB
78 install -vm755 /tmp/$LIB /usr/lib
79 rm /tmp/$LIB
80done
[658dcab]81
[08f72423]82for i in $(find /usr/lib -type f -name \*.so* ! -name \*dbg) \
83 $(find /usr/lib -type f -name \*.a) \
84 $(find /usr/{bin,sbin,libexec} -type f); do
85 case "$online_usrbin $online_usrlib $save_usrlib" in
[11d5dee]86 *$(basename $i)* )
87 ;;
88 * ) strip --strip-unneeded $i
89 ;;
[de28837]90 esac
91done
92
93unset BIN LIB save_usrlib online_usrbin online_usrlib
94</userinput></screen>
[3c928f1]95
[ddd5542]96 <para>A large number of files will be reported as having their file
97 format not recognized. These warnings can be safely ignored. These
98 warnings indicate that those files are scripts instead of
99 binaries.</para>
[6c8a79a]100
[3c928f1]101</sect1>
Note: See TracBrowser for help on using the repository browser.