1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
|
From effd0097f1b34616b410473493bd8eeb388835d8 Mon Sep 17 00:00:00 2001
From: Oliver Reiche <oliver.reiche@huawei.com>
Date: Mon, 21 Aug 2023 18:03:56 +0200
Subject: [PATCH 2/2] Compute reproducible checksums
... for variable toolchain paths:
* remove linker path from gcc's checksum-options
* disable thin archives (for stripping libbackend.a)
* strip debug info before computing checksums
For removing the linker path, the user needs to set
"BUILD_ROOT_DIR" before building.
---
gcc/Makefile.in | 3 ++-
gcc/c/Make-lang.in | 6 +++++-
gcc/cp/Make-lang.in | 6 +++++-
3 files changed, 12 insertions(+), 3 deletions(-)
diff --git a/gcc/Makefile.in b/gcc/Makefile.in
index 5d05e8e0d..1346bbe72 100644
--- a/gcc/Makefile.in
+++ b/gcc/Makefile.in
@@ -284,7 +284,7 @@ USE_THIN_ARCHIVES = no
ifeq ($(THIN_ARCHIVE_SUPPORT),yes)
ifeq ($(AR_FLAGS),rc)
ifeq ($(RANLIB_FLAGS),)
-USE_THIN_ARCHIVES = yes
+#USE_THIN_ARCHIVES = yes
endif
endif
endif
@@ -2075,6 +2075,7 @@ gcc-cross$(exeext): xgcc$(exeext)
checksum-options:
echo "$(LINKER) $(ALL_LINKERFLAGS) $(LDFLAGS)" > checksum-options.tmp \
+ && sed -i 's|'$${BUILD_ROOT_DIR:-/nonexistent}'|/build|g' checksum-options.tmp \
&& $(srcdir)/../move-if-change checksum-options.tmp checksum-options
#
diff --git a/gcc/c/Make-lang.in b/gcc/c/Make-lang.in
index 8944b9b9f..7ed444c5f 100644
--- a/gcc/c/Make-lang.in
+++ b/gcc/c/Make-lang.in
@@ -76,7 +76,11 @@ cc1-checksum.c : build/genchecksum$(build_exeext) checksum-options \
&& cmp -s ../stage_current ../stage_final; then \
cp ../prev-gcc/cc1-checksum.c cc1-checksum.c; \
else \
- build/genchecksum$(build_exeext) $(C_OBJS) $(BACKEND) $(LIBDEPS) \
+ rm -rf stripped_c_checksum_inputs; \
+ mkdir stripped_c_checksum_inputs; \
+ cp $(C_OBJS) $(BACKEND) $(LIBDEPS) stripped_c_checksum_inputs/; \
+ $(STRIP_FOR_TARGET) -g stripped_c_checksum_inputs/*; \
+ build/genchecksum$(build_exeext) $$(ls stripped_c_checksum_inputs/* | LC_ALL=C sort) \
checksum-options > cc1-checksum.c.tmp && \
$(srcdir)/../move-if-change cc1-checksum.c.tmp cc1-checksum.c; \
fi
diff --git a/gcc/cp/Make-lang.in b/gcc/cp/Make-lang.in
index 7896591dd..c65afcb85 100644
--- a/gcc/cp/Make-lang.in
+++ b/gcc/cp/Make-lang.in
@@ -111,7 +111,11 @@ cc1plus-checksum.c : build/genchecksum$(build_exeext) checksum-options \
&& cmp -s ../stage_current ../stage_final; then \
cp ../prev-gcc/cc1plus-checksum.c cc1plus-checksum.c; \
else \
- build/genchecksum$(build_exeext) $(CXX_OBJS) $(BACKEND) $(LIBDEPS) \
+ rm -rf stripped_cp_checksum_inputs; \
+ mkdir stripped_cp_checksum_inputs; \
+ cp $(CXX_OBJS) $(BACKEND) $(CODYLIB) $(LIBDEPS) stripped_cp_checksum_inputs; \
+ $(STRIP_FOR_TARGET) -g stripped_cp_checksum_inputs/*; \
+ build/genchecksum$(build_exeext) $$(ls stripped_cp_checksum_inputs/* | LC_ALL=C sort) \
checksum-options > cc1plus-checksum.c.tmp && \
$(srcdir)/../move-if-change cc1plus-checksum.c.tmp cc1plus-checksum.c; \
fi
--
2.30.2
|