@@ -135,7 +135,7 @@ tasks:
135
135
PLATFORM_DIR : " {{ .PROJECT_NAME }}_linux_arm_7"
136
136
BUILD_COMMAND : " go build -o {{ .DIST_DIR }}/{{ .PLATFORM_DIR }}/{{ .PROJECT_NAME }} {{ .LDFLAGS }}"
137
137
BUILD_PLATFORM : " linux/armv7"
138
- CONTAINER_TAG : " {{ .GO_VERSION }}-arm "
138
+ CONTAINER_TAG : " {{ .GO_VERSION }}-armhf "
139
139
PACKAGE_PLATFORM : " Linux_ARMv7"
140
140
PACKAGE_NAME : " {{ .PROJECT_NAME }}_{{ .VERSION }}_{{ .PACKAGE_PLATFORM }}.tar.gz"
141
141
@@ -157,7 +157,35 @@ tasks:
157
157
PLATFORM_DIR : " {{ .PROJECT_NAME }}_linux_arm_6"
158
158
BUILD_COMMAND : " go build -o {{ .DIST_DIR }}/{{ .PLATFORM_DIR }}/{{ .PROJECT_NAME }} {{ .LDFLAGS }}"
159
159
BUILD_PLATFORM : " linux/armv6"
160
- CONTAINER_TAG : " {{ .GO_VERSION }}-arm"
160
+ # We are experiencing the following error with ARMv6 build:
161
+ #
162
+ # # github.com/arduino/arduino-cli
163
+ # net(.text): unexpected relocation type 296 (R_ARM_V4BX)
164
+ # panic: runtime error: invalid memory address or nil pointer dereference
165
+ # [signal SIGSEGV: segmentation violation code=0x1 addr=0x0 pc=0x51ae53]
166
+ #
167
+ # goroutine 1 [running]:
168
+ # cmd/link/internal/loader.(*Loader).SymName(0xc000095c00, 0x0, 0xc0000958d8, 0x5a0ac)
169
+ # /usr/local/go/src/cmd/link/internal/loader/loader.go:684 +0x53
170
+ # cmd/link/internal/ld.dynrelocsym2(0xc000095880, 0x5a0ac)
171
+ # /usr/local/go/src/cmd/link/internal/ld/data.go:777 +0x295
172
+ # cmd/link/internal/ld.(*dodataState).dynreloc2(0xc007df9800, 0xc000095880)
173
+ # /usr/local/go/src/cmd/link/internal/ld/data.go:794 +0x89
174
+ # cmd/link/internal/ld.(*Link).dodata2(0xc000095880, 0xc007d00000, 0x60518, 0x60518)
175
+ # /usr/local/go/src/cmd/link/internal/ld/data.go:1434 +0x4d4
176
+ # cmd/link/internal/ld.Main(0x8729a0, 0x4, 0x8, 0x1, 0xd, 0xe, 0x0, 0x0, 0x6d7737, 0x12, ...)
177
+ # /usr/local/go/src/cmd/link/internal/ld/main.go:302 +0x123a
178
+ # main.main()
179
+ # /usr/local/go/src/cmd/link/main.go:68 +0x1dc
180
+ # Error: failed building for linux/armv6: exit status 2
181
+ #
182
+ # This seems to be a problem in the go builder 1.16.x that removed support for the R_ARM_V4BX instruction:
183
+ # https://github.com/golang/go/pull/44998
184
+ # https://groups.google.com/g/golang-codereviews/c/yzN80xxwu2E
185
+ #
186
+ # Until there is a fix released we must use a recent gcc for Linux_ARMv6 build, so for this
187
+ # build we select the debian10 based container.
188
+ CONTAINER_TAG : " {{ .GO_VERSION }}-armel-debian10"
161
189
PACKAGE_PLATFORM : " Linux_ARMv6"
162
190
PACKAGE_NAME : " {{ .PROJECT_NAME }}_{{ .VERSION }}_{{ .PACKAGE_PLATFORM }}.tar.gz"
163
191
@@ -201,11 +229,24 @@ tasks:
201
229
PLATFORM_DIR : " {{ .PROJECT_NAME }}_osx_darwin_amd64"
202
230
BUILD_COMMAND : " go build -o {{ .DIST_DIR }}/{{ .PLATFORM_DIR }}/{{ .PROJECT_NAME }} {{ .LDFLAGS }}"
203
231
BUILD_PLATFORM : " darwin/amd64"
204
- CONTAINER_TAG : " {{ .GO_VERSION }}-darwin"
232
+ # We are experiencing the following error with macOS_64bit build:
233
+ #
234
+ # Undefined symbols for architecture x86_64:
235
+ # "_clock_gettime", referenced from:
236
+ # _runtime.walltime_trampoline in go.o
237
+ # ld: symbol(s) not found for architecture x86_64
238
+ # clang: error: linker command failed with exit code 1 (use -v to see invocation)
239
+ #
240
+ # The reason seems that go 1.16.x use a macos API which is available since 10.12
241
+ # https://github.com/techknowlogick/xgo/issues/100#issuecomment-780894190
242
+ #
243
+ # To compile it we need an SDK >=10.12 so we use the debian10 based container that
244
+ # has the SDK 10.14 installed.
245
+ CONTAINER_TAG : " {{ .GO_VERSION }}-darwin-debian10"
205
246
PACKAGE_PLATFORM : " macOS_64bit"
206
247
PACKAGE_NAME : " {{ .PROJECT_NAME }}_{{ .VERSION }}_{{ .PACKAGE_PLATFORM }}.tar.gz"
207
248
208
249
vars :
209
250
CONTAINER : " docker.elastic.co/beats-dev/golang-crossbuild"
210
- GO_VERSION : " 1.14.7 "
251
+ GO_VERSION : " 1.16.4 "
211
252
CHECKSUM_FILE : " {{ .VERSION }}-checksums.txt"
0 commit comments