pkgsrc-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[pkgsrc/trunk]: pkgsrc/lang/gcc9 gcc9: start fixing gccgo build under NetBSD.



details:   https://anonhg.NetBSD.org/pkgsrc/rev/3d77c5d58279
branches:  trunk
changeset: 427775:3d77c5d58279
user:      bsiegert <bsiegert%pkgsrc.org@localhost>
date:      Mon Apr 20 14:25:52 2020 +0000

description:
gcc9: start fixing gccgo build under NetBSD.

This fixes the build of the "runtime" package, now the compilation is
stuck in the "syscall" package instead.

Submitted upstream as https://go-review.googlesource.com/c/gofrontend/+/228918/.
Upstream bug report at https://github.com/golang/go/issues/38538.

diffstat:

 lang/gcc9/Makefile                                        |   3 +-
 lang/gcc9/distinfo                                        |   6 +-
 lang/gcc9/patches/patch-libgo_go_runtime_os__netbsd.go    |  55 +++++++++++++++
 lang/gcc9/patches/patch-libgo_go_runtime_signal__gccgo.go |  15 ++++
 lang/gcc9/patches/patch-libgo_go_runtime_stubs.go         |  17 ++++
 lang/gcc9/patches/patch-libgo_runtime_go-signal.c         |  25 ++++++
 6 files changed, 119 insertions(+), 2 deletions(-)

diffs (158 lines):

diff -r adf81722a0f1 -r 3d77c5d58279 lang/gcc9/Makefile
--- a/lang/gcc9/Makefile        Mon Apr 20 14:10:19 2020 +0000
+++ b/lang/gcc9/Makefile        Mon Apr 20 14:25:52 2020 +0000
@@ -1,6 +1,7 @@
-# $NetBSD: Makefile,v 1.17 2020/04/08 16:35:59 wiz Exp $
+# $NetBSD: Makefile,v 1.18 2020/04/20 14:25:52 bsiegert Exp $
 
 GCC9_VERSION=  9.3.0
+PKGREVISION=   1
 
 DISTNAME=      gcc-${GCC9_VERSION}
 PKGNAME=       gcc9-${GCC9_VERSION}
diff -r adf81722a0f1 -r 3d77c5d58279 lang/gcc9/distinfo
--- a/lang/gcc9/distinfo        Mon Apr 20 14:10:19 2020 +0000
+++ b/lang/gcc9/distinfo        Mon Apr 20 14:25:52 2020 +0000
@@ -1,9 +1,13 @@
-$NetBSD: distinfo,v 1.3 2020/04/08 16:35:59 wiz Exp $
+$NetBSD: distinfo,v 1.4 2020/04/20 14:25:52 bsiegert Exp $
 
 SHA1 (gcc-9.3.0.tar.xz) = b746688bf045a316fc92c3528138ad10d0822b6b
 RMD160 (gcc-9.3.0.tar.xz) = e0ade31726b8fbb1eb308e2b1383a79633aef996
 SHA512 (gcc-9.3.0.tar.xz) = 4b9e3639eef6e623747a22c37a904b4750c93b6da77cf3958d5047e9b5ebddb7eebe091cc16ca0a227c0ecbd2bf3b984b221130f269a97ee4cc18f9cf6c444de
 Size (gcc-9.3.0.tar.xz) = 70533868 bytes
 SHA1 (patch-gcc_gimplify.c) = f933a033d4a6c11fa82c8c9c6785842ba7993862
+SHA1 (patch-libgo_go_runtime_os__netbsd.go) = 357c62afe017a5ca3d7138abb2c19dc10bc5cd3d
+SHA1 (patch-libgo_go_runtime_signal__gccgo.go) = 51b632c1c827f6d99fc2d7803294a0b7a64514a1
+SHA1 (patch-libgo_go_runtime_stubs.go) = f4753765eb7ee9a933f2bb3a05f27c487a1d51ef
+SHA1 (patch-libgo_runtime_go-signal.c) = 6121b041cdd850adeea943f385d52b65d6bfe249
 SHA1 (patch-libstdc++-v3_config_os_bsd_netbsd_ctype__base.h) = f12f6a97f94d13efa73a2500411bc77b27887edd
 SHA1 (patch-libstdc++-v3_config_os_bsd_netbsd_ctype__configure__char.cc) = 007bce70f75deace18f60924b5a3f94bf7a0af2f
diff -r adf81722a0f1 -r 3d77c5d58279 lang/gcc9/patches/patch-libgo_go_runtime_os__netbsd.go
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/lang/gcc9/patches/patch-libgo_go_runtime_os__netbsd.go    Mon Apr 20 14:25:52 2020 +0000
@@ -0,0 +1,55 @@
+$NetBSD: patch-libgo_go_runtime_os__netbsd.go,v 1.1 2020/04/20 14:25:52 bsiegert Exp $
+
+Fix compilation errors under NetBSD. Taken from upstream Go 1.14 sources.
+
+--- libgo/go/runtime/os_netbsd.go.orig 2020-03-12 11:07:24.000000000 +0000
++++ libgo/go/runtime/os_netbsd.go
+@@ -52,11 +52,11 @@ func semasleep(ns int64) int32 {
+                               return -1
+                       }
+                       var nsec int32
+-                      ts.set_sec(timediv(wait, 1000000000, &nsec))
++                      ts.set_sec(int64(timediv(wait, 1000000000, &nsec)))
+                       ts.set_nsec(nsec)
+                       tsp = &ts
+               }
+-              ret := lwp_park(_CLOCK_MONOTONIC, _TIMER_RELTIME, tsp, 0, unsafe.Pointer(&_g_.m.waitsemacount), nil)
++              ret := lwp_park(_CLOCK_MONOTONIC, _TIMER_RELTIME, tsp, 0, unsafe.Pointer(&_g_.m.mos.waitsemacount), nil)
+               if ret == _ETIMEDOUT {
+                       return -1
+               }
+@@ -77,3 +77,34 @@ func semawakeup(mp *m) {
+               })
+       }
+ }
++
++func sysargs(argc int32, argv **byte) {
++      n := argc + 1
++
++      // skip over argv, envp to get to auxv
++      for argv_index(argv, n) != nil {
++              n++
++      }
++
++      // skip NULL separator
++      n++
++
++      // now argv+n is auxv
++      auxv := (*[1 << 28]uintptr)(add(unsafe.Pointer(argv), uintptr(n)*sys.PtrSize))
++      sysauxv(auxv[:])
++}
++
++const (
++      _AT_NULL   = 0 // Terminates the vector
++      _AT_PAGESZ = 6 // Page size in bytes
++)
++
++func sysauxv(auxv []uintptr) {
++      for i := 0; auxv[i] != _AT_NULL; i += 2 {
++              tag, val := auxv[i], auxv[i+1]
++              switch tag {
++              case _AT_PAGESZ:
++                      physPageSize = val
++              }
++      }
++}
diff -r adf81722a0f1 -r 3d77c5d58279 lang/gcc9/patches/patch-libgo_go_runtime_signal__gccgo.go
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/lang/gcc9/patches/patch-libgo_go_runtime_signal__gccgo.go Mon Apr 20 14:25:52 2020 +0000
@@ -0,0 +1,15 @@
+$NetBSD: patch-libgo_go_runtime_signal__gccgo.go,v 1.1 2020/04/20 14:25:52 bsiegert Exp $
+
+si_code is a macro on NetBSD, add a C trampoline function.
+
+--- libgo/go/runtime/signal_gccgo.go.orig      2020-04-18 16:53:50.092569597 +0000
++++ libgo/go/runtime/signal_gccgo.go
+@@ -65,7 +65,7 @@ func (c *sigctxt) sigcode() uint64 {
+               // code, just avoid a misleading value.
+               return _SI_USER + 1
+       }
+-      return uint64(c.info.si_code)
++      return uint64(getSiginfoCode(c.info))
+ }
+ 
+ //go:nosplit
diff -r adf81722a0f1 -r 3d77c5d58279 lang/gcc9/patches/patch-libgo_go_runtime_stubs.go
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/lang/gcc9/patches/patch-libgo_go_runtime_stubs.go Mon Apr 20 14:25:52 2020 +0000
@@ -0,0 +1,17 @@
+$NetBSD: patch-libgo_go_runtime_stubs.go,v 1.1 2020/04/20 14:25:52 bsiegert Exp $
+
+si_code is a macro on NetBSD, add a C trampoline function.
+
+--- libgo/go/runtime/stubs.go.orig     2020-03-12 11:07:24.000000000 +0000
++++ libgo/go/runtime/stubs.go
+@@ -326,6 +326,10 @@ func getSigactionHandler(*_sigaction) ui
+ //go:noescape
+ func setSigactionHandler(*_sigaction, uintptr)
+ 
++// Get signal code, written in C.
++//go:noescape
++func getSiginfoCode(*_siginfo_t) uintptr
++
+ // Retrieve fields from the siginfo_t and ucontext_t pointers passed
+ // to a signal handler using C, as they are often hidden in a union.
+ // Returns  and, if available, PC where signal occurred.
diff -r adf81722a0f1 -r 3d77c5d58279 lang/gcc9/patches/patch-libgo_runtime_go-signal.c
--- /dev/null   Thu Jan 01 00:00:00 1970 +0000
+++ b/lang/gcc9/patches/patch-libgo_runtime_go-signal.c Mon Apr 20 14:25:52 2020 +0000
@@ -0,0 +1,25 @@
+$NetBSD: patch-libgo_runtime_go-signal.c,v 1.1 2020/04/20 14:25:52 bsiegert Exp $
+
+si_code is a macro on NetBSD, add a C trampoline function.
+
+--- libgo/runtime/go-signal.c.orig     2020-03-12 11:07:24.000000000 +0000
++++ libgo/runtime/go-signal.c
+@@ -179,6 +179,18 @@ setSigactionHandler(struct sigaction* sa
+ // C code to fetch values from the siginfo_t and ucontext_t pointers
+ // passed to a signal handler.
+ 
++uintptr getSiginfoCode(siginfo_t *)
++      __attribute__ ((no_split_stack));
++
++uintptr getSiginfoCode(siginfo_t *)
++      __asm__ (GOSYM_PREFIX "runtime.getSiginfoCode");
++
++uintptr
++getSiginfoCode(siginfo_t *info)
++{
++      return (uintptr)(info->si_code);
++}
++
+ struct getSiginfoRet {
+       uintptr sigaddr;
+       uintptr sigpc;



Home | Main Index | Thread Index | Old Index