blob: 06b00b3cc2d2f9bc447c5ee3b5f95aceb0343f85 [file] [log] [blame]
Brad Bishop316dfdd2018-06-25 12:45:53 -04001From f575d85c4bd9b2903223d6c0dcc38a12775d582f Mon Sep 17 00:00:00 2001
2From: Matt Madison <matt@madison.systems>
3Date: Sun, 18 Feb 2018 08:24:05 -0800
4Subject: [PATCH 9/9] ld: replace glibc dynamic linker with musl
5
6Rework of patch by Khem Raj <raj.khem@gmail.com>
7for go 1.10. Should be applied conditionally on
8musl being the system C library.
9
10Upstream-Status: Inappropriate [Real fix should be portable across libcs]
11
12Signed-off-by: Matt Madison <matt@madison.systems>
13---
14 src/cmd/link/internal/amd64/obj.go | 2 +-
15 src/cmd/link/internal/arm/obj.go | 2 +-
16 src/cmd/link/internal/arm64/obj.go | 2 +-
17 src/cmd/link/internal/mips/obj.go | 2 +-
18 src/cmd/link/internal/mips64/obj.go | 2 +-
19 src/cmd/link/internal/ppc64/obj.go | 2 +-
20 src/cmd/link/internal/s390x/obj.go | 2 +-
21 src/cmd/link/internal/x86/obj.go | 2 +-
22 8 files changed, 8 insertions(+), 8 deletions(-)
23
24diff --git a/src/cmd/link/internal/amd64/obj.go b/src/cmd/link/internal/amd64/obj.go
25index 87e809166a..f522a63034 100644
26--- a/src/cmd/link/internal/amd64/obj.go
27+++ b/src/cmd/link/internal/amd64/obj.go
28@@ -62,7 +62,7 @@ func Init() (*sys.Arch, ld.Arch) {
29 PEreloc1: pereloc1,
30 TLSIEtoLE: tlsIEtoLE,
31
32- Linuxdynld: "/lib64/ld-linux-x86-64.so.2",
33+ Linuxdynld: "/lib64/ld-musl-x86-64.so.1",
34 Freebsddynld: "/libexec/ld-elf.so.1",
35 Openbsddynld: "/usr/libexec/ld.so",
36 Netbsddynld: "/libexec/ld.elf_so",
37diff --git a/src/cmd/link/internal/arm/obj.go b/src/cmd/link/internal/arm/obj.go
38index da16f92345..fd14940ede 100644
39--- a/src/cmd/link/internal/arm/obj.go
40+++ b/src/cmd/link/internal/arm/obj.go
41@@ -58,7 +58,7 @@ func Init() (*sys.Arch, ld.Arch) {
42 Gentext: gentext,
43 Machoreloc1: machoreloc1,
44
45- Linuxdynld: "/lib/ld-linux.so.3", // 2 for OABI, 3 for EABI
46+ Linuxdynld: "/lib/ld-musl-armhf.so.1",
47 Freebsddynld: "/usr/libexec/ld-elf.so.1",
48 Openbsddynld: "/usr/libexec/ld.so",
49 Netbsddynld: "/libexec/ld.elf_so",
50diff --git a/src/cmd/link/internal/arm64/obj.go b/src/cmd/link/internal/arm64/obj.go
51index 6b386ad737..99863712cc 100644
52--- a/src/cmd/link/internal/arm64/obj.go
53+++ b/src/cmd/link/internal/arm64/obj.go
54@@ -57,7 +57,7 @@ func Init() (*sys.Arch, ld.Arch) {
55 Gentext: gentext,
56 Machoreloc1: machoreloc1,
57
58- Linuxdynld: "/lib/ld-linux-aarch64.so.1",
59+ Linuxdynld: "/lib/ld-musl-aarch64.so.1",
60
61 Freebsddynld: "XXX",
62 Openbsddynld: "XXX",
63diff --git a/src/cmd/link/internal/mips/obj.go b/src/cmd/link/internal/mips/obj.go
64index c5d3451c39..fd85e6368d 100644
65--- a/src/cmd/link/internal/mips/obj.go
66+++ b/src/cmd/link/internal/mips/obj.go
67@@ -60,7 +60,7 @@ func Init() (*sys.Arch, ld.Arch) {
68 Gentext: gentext,
69 Machoreloc1: machoreloc1,
70
71- Linuxdynld: "/lib/ld.so.1",
72+ Linuxdynld: "/lib/ld-musl-mipsle.so.1",
73
74 Freebsddynld: "XXX",
75 Openbsddynld: "XXX",
76diff --git a/src/cmd/link/internal/mips64/obj.go b/src/cmd/link/internal/mips64/obj.go
77index 83974e5b56..097224f6da 100644
78--- a/src/cmd/link/internal/mips64/obj.go
79+++ b/src/cmd/link/internal/mips64/obj.go
80@@ -59,7 +59,7 @@ func Init() (*sys.Arch, ld.Arch) {
81 Gentext: gentext,
82 Machoreloc1: machoreloc1,
83
84- Linuxdynld: "/lib64/ld64.so.1",
85+ Linuxdynld: "/lib64/ld-musl-mips64le.so.1",
86 Freebsddynld: "XXX",
87 Openbsddynld: "XXX",
88 Netbsddynld: "XXX",
89diff --git a/src/cmd/link/internal/ppc64/obj.go b/src/cmd/link/internal/ppc64/obj.go
90index 273d9b42cb..a503abe8ea 100644
91--- a/src/cmd/link/internal/ppc64/obj.go
92+++ b/src/cmd/link/internal/ppc64/obj.go
93@@ -62,7 +62,7 @@ func Init() (*sys.Arch, ld.Arch) {
94 Machoreloc1: machoreloc1,
95
96 // TODO(austin): ABI v1 uses /usr/lib/ld.so.1,
97- Linuxdynld: "/lib64/ld64.so.1",
98+ Linuxdynld: "/lib64/ld-musl-powerpc64le.so.1",
99
100 Freebsddynld: "XXX",
101 Openbsddynld: "XXX",
102diff --git a/src/cmd/link/internal/s390x/obj.go b/src/cmd/link/internal/s390x/obj.go
103index 9ac7eb8217..3825ff7abe 100644
104--- a/src/cmd/link/internal/s390x/obj.go
105+++ b/src/cmd/link/internal/s390x/obj.go
106@@ -57,7 +57,7 @@ func Init() (*sys.Arch, ld.Arch) {
107 Gentext: gentext,
108 Machoreloc1: machoreloc1,
109
110- Linuxdynld: "/lib64/ld64.so.1",
111+ Linuxdynld: "/lib64/ld-musl-s390x.so.1",
112
113 // not relevant for s390x
114 Freebsddynld: "XXX",
115diff --git a/src/cmd/link/internal/x86/obj.go b/src/cmd/link/internal/x86/obj.go
116index 6a744dc04e..d81f392549 100644
117--- a/src/cmd/link/internal/x86/obj.go
118+++ b/src/cmd/link/internal/x86/obj.go
119@@ -58,7 +58,7 @@ func Init() (*sys.Arch, ld.Arch) {
120 Machoreloc1: machoreloc1,
121 PEreloc1: pereloc1,
122
123- Linuxdynld: "/lib/ld-linux.so.2",
124+ Linuxdynld: "/lib/ld-musl-i386.so.1",
125 Freebsddynld: "/usr/libexec/ld-elf.so.1",
126 Openbsddynld: "/usr/libexec/ld.so",
127 Netbsddynld: "/usr/libexec/ld.elf_so",
128--
1292.14.1
130