source: chapter08/strippingagain.xml@ 5287d52

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 5287d52 was de28837, checked in by Xi Ruoyao <xry111@…>, 3 years ago

Hopefully, complete strip workaround

In stripping, /usr/bin/bash, /usr/bin/find, and /usr/bin/strip are
running. Strip them, and all libraries used by them in /tmp, then
install them back.

We can't use this for all libraries or binaries: the process above
discouples hard links (for example /usr/bin/perl and perl5.34.0). So
unfortunately the stripping instruction is now a stupidly long bash
script...

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