mirror of
git://git.yoctoproject.org/meta-virtualization.git
synced 2025-07-19 12:50:22 +02:00
go: add go-cross 1.6
Introduce the 1.6 go release, and port patches to apply to this version. Existing versions (1.5) are not removed, so this is not a forced update. Signed-off-by: Bruce Ashfield <bruce.ashfield@windriver.com>
This commit is contained in:
parent
5dedd395f4
commit
79654fc6a1
19
recipes-devtools/go-cross/go-1.6.inc
Normal file
19
recipes-devtools/go-cross/go-1.6.inc
Normal file
|
@ -0,0 +1,19 @@
|
|||
require go-common.inc
|
||||
|
||||
PV = "1.6.2"
|
||||
GO_BASEVERSION = "1.6"
|
||||
FILESEXTRAPATHS_prepend := "${FILE_DIRNAME}/go-${GO_BASEVERSION}:"
|
||||
|
||||
|
||||
SRC_URI += "\
|
||||
file://armhf-elf-header.patch \
|
||||
file://syslog.patch \
|
||||
file://fix-target-cc-for-build.patch \
|
||||
file://fix-cc-handling.patch \
|
||||
file://split-host-and-target-build.patch \
|
||||
file://gotooldir.patch \
|
||||
"
|
||||
|
||||
LIC_FILES_CHKSUM = "file://LICENSE;md5=591778525c869cdde0ab5a1bf283cd81"
|
||||
SRC_URI[md5sum] = "d1b50fa98d9a71eeee829051411e6207"
|
||||
SRC_URI[sha256sum] = "787b0b750d037016a30c6ed05a8a70a91b2e9db4bd9b1a2453aa502a63f1bccc"
|
19
recipes-devtools/go-cross/go-1.6/armhf-elf-header.patch
Normal file
19
recipes-devtools/go-cross/go-1.6/armhf-elf-header.patch
Normal file
|
@ -0,0 +1,19 @@
|
|||
Index: go/src/cmd/link/internal/ld/elf.go
|
||||
===================================================================
|
||||
--- go.orig/src/cmd/link/internal/ld/elf.go
|
||||
+++ go/src/cmd/link/internal/ld/elf.go
|
||||
@@ -827,7 +827,13 @@
|
||||
// 32-bit architectures
|
||||
case '5':
|
||||
// we use EABI on both linux/arm and freebsd/arm.
|
||||
- if HEADTYPE == obj.Hlinux || HEADTYPE == obj.Hfreebsd {
|
||||
+ if HEADTYPE == obj.Hlinux {
|
||||
+ if Ctxt.Goarm == 7 {
|
||||
+ ehdr.flags = 0x5000402 // has entry point, Version5 EABI, hard float
|
||||
+ } else {
|
||||
+ ehdr.flags = 0x5000202 // has entry point, Version5 EABI, soft float
|
||||
+ }
|
||||
+ } else if HEADTYPE == obj.Hfreebsd {
|
||||
// We set a value here that makes no indication of which
|
||||
// float ABI the object uses, because this is information
|
||||
// used by the dynamic linker to compare executables and
|
46
recipes-devtools/go-cross/go-1.6/fix-cc-handling.patch
Normal file
46
recipes-devtools/go-cross/go-1.6/fix-cc-handling.patch
Normal file
|
@ -0,0 +1,46 @@
|
|||
Index: go/src/cmd/go/build.go
|
||||
===================================================================
|
||||
--- go.orig/src/cmd/go/build.go 2015-07-29 14:48:40.323185807 -0700
|
||||
+++ go/src/cmd/go/build.go 2015-07-30 07:37:40.529818586 -0700
|
||||
@@ -2805,12 +2805,24 @@
|
||||
return b.ccompilerCmd("CC", defaultCC, objdir)
|
||||
}
|
||||
|
||||
+// gccCmd returns a gcc command line prefix
|
||||
+// defaultCC is defined in zdefaultcc.go, written by cmd/dist.
|
||||
+func (b *builder) gccCmdForReal() []string {
|
||||
+ return envList("CC", defaultCC)
|
||||
+}
|
||||
+
|
||||
// gxxCmd returns a g++ command line prefix
|
||||
// defaultCXX is defined in zdefaultcc.go, written by cmd/dist.
|
||||
func (b *builder) gxxCmd(objdir string) []string {
|
||||
return b.ccompilerCmd("CXX", defaultCXX, objdir)
|
||||
}
|
||||
|
||||
+// gxxCmd returns a g++ command line prefix
|
||||
+// defaultCXX is defined in zdefaultcc.go, written by cmd/dist.
|
||||
+func (b *builder) gxxCmdForReal() []string {
|
||||
+ return envList("CXX", defaultCXX)
|
||||
+}
|
||||
+
|
||||
// ccompilerCmd returns a command line prefix for the given environment
|
||||
// variable and using the default command when the variable is empty.
|
||||
func (b *builder) ccompilerCmd(envvar, defcmd, objdir string) []string {
|
||||
Index: go/src/cmd/go/env.go
|
||||
===================================================================
|
||||
--- go.orig/src/cmd/go/env.go 2015-07-29 14:48:40.323185807 -0700
|
||||
+++ go/src/cmd/go/env.go 2015-07-30 07:40:54.461655721 -0700
|
||||
@@ -52,10 +52,9 @@
|
||||
|
||||
if goos != "plan9" {
|
||||
cmd := b.gccCmd(".")
|
||||
- env = append(env, envVar{"CC", cmd[0]})
|
||||
+ env = append(env, envVar{"CC", strings.Join(b.gccCmdForReal(), " ")})
|
||||
env = append(env, envVar{"GOGCCFLAGS", strings.Join(cmd[3:], " ")})
|
||||
- cmd = b.gxxCmd(".")
|
||||
- env = append(env, envVar{"CXX", cmd[0]})
|
||||
+ env = append(env, envVar{"CXX", strings.Join(b.gxxCmdForReal(), " ")})
|
||||
}
|
||||
|
||||
if buildContext.CgoEnabled {
|
|
@ -0,0 +1,13 @@
|
|||
Index: go/src/make.bash
|
||||
===================================================================
|
||||
--- go.orig/src/make.bash 2015-07-29 13:28:11.334031696 -0700
|
||||
+++ go/src/make.bash 2015-07-29 13:36:55.814465630 -0700
|
||||
@@ -158,7 +158,7 @@
|
||||
fi
|
||||
|
||||
echo "##### Building packages and commands for $GOOS/$GOARCH."
|
||||
-CC=$CC_FOR_TARGET "$GOTOOLDIR"/go_bootstrap install $GO_FLAGS -gcflags "$GO_GCFLAGS" -ldflags "$GO_LDFLAGS" -v std cmd
|
||||
+CC="$CC_FOR_TARGET" "$GOTOOLDIR"/go_bootstrap install $GO_FLAGS -gcflags "$GO_GCFLAGS" -ldflags "$GO_LDFLAGS" -v std cmd
|
||||
echo
|
||||
|
||||
rm -f "$GOTOOLDIR"/go_bootstrap
|
26
recipes-devtools/go-cross/go-1.6/gotooldir.patch
Normal file
26
recipes-devtools/go-cross/go-1.6/gotooldir.patch
Normal file
|
@ -0,0 +1,26 @@
|
|||
Index: go/src/go/build/build.go
|
||||
===================================================================
|
||||
--- go.orig/src/go/build/build.go
|
||||
+++ go/src/go/build/build.go
|
||||
@@ -1388,7 +1388,7 @@ func init() {
|
||||
}
|
||||
|
||||
// ToolDir is the directory containing build tools.
|
||||
-var ToolDir = filepath.Join(runtime.GOROOT(), "pkg/tool/"+runtime.GOOS+"_"+runtime.GOARCH)
|
||||
+var ToolDir = envOr("GOTOOLDIR", filepath.Join(runtime.GOROOT(), "pkg/tool/"+runtime.GOOS+"_"+runtime.GOARCH))
|
||||
|
||||
// IsLocalImport reports whether the import path is
|
||||
// a local import path, like ".", "..", "./foo", or "../foo".
|
||||
Index: go/src/cmd/go/build.go
|
||||
===================================================================
|
||||
--- go.orig/src/cmd/go/build.go
|
||||
+++ go/src/cmd/go/build.go
|
||||
@@ -1312,7 +1312,7 @@ func (b *builder) build(a *action) (err
|
||||
}
|
||||
|
||||
cgoExe := tool("cgo")
|
||||
- if a.cgo != nil && a.cgo.target != "" {
|
||||
+ if a.cgo != nil && a.cgo.target != "" && os.Getenv("GOTOOLDIR") == "" {
|
||||
cgoExe = a.cgo.target
|
||||
}
|
||||
outGo, outObj, err := b.cgo(a.p, cgoExe, obj, pcCFLAGS, pcLDFLAGS, cgofiles, gccfiles, cxxfiles, a.p.MFiles)
|
|
@ -0,0 +1,58 @@
|
|||
Index: go/src/make.bash
|
||||
===================================================================
|
||||
--- go.orig/src/make.bash
|
||||
+++ go/src/make.bash
|
||||
@@ -143,12 +143,23 @@ if [ "$1" = "--no-clean" ]; then
|
||||
buildall=""
|
||||
shift
|
||||
fi
|
||||
-./cmd/dist/dist bootstrap $buildall $GO_DISTFLAGS -v # builds go_bootstrap
|
||||
-# Delay move of dist tool to now, because bootstrap may clear tool directory.
|
||||
-mv cmd/dist/dist "$GOTOOLDIR"/dist
|
||||
-echo
|
||||
|
||||
-if [ "$GOHOSTARCH" != "$GOARCH" -o "$GOHOSTOS" != "$GOOS" ]; then
|
||||
+do_host_build="yes"
|
||||
+do_target_build="yes"
|
||||
+if [ "$1" = "--target-only" ]; then
|
||||
+ do_host_build="no"
|
||||
+ shift
|
||||
+elif [ "$1" = "--host-only" ]; then
|
||||
+ do_target_build="no"
|
||||
+ shift
|
||||
+fi
|
||||
+
|
||||
+if [ "$do_host_build" = "yes" ]; then
|
||||
+ ./cmd/dist/dist bootstrap $buildall $GO_DISTFLAGS -v # builds go_bootstrap
|
||||
+ # Delay move of dist tool to now, because bootstrap may clear tool directory.
|
||||
+ mv cmd/dist/dist "$GOTOOLDIR"/dist
|
||||
+ echo
|
||||
+
|
||||
echo "##### Building packages and commands for host, $GOHOSTOS/$GOHOSTARCH."
|
||||
# CC_FOR_TARGET is recorded as the default compiler for the go tool. When building for the host, however,
|
||||
# use the host compiler, CC, from `cmd/dist/dist env` instead.
|
||||
@@ -157,11 +168,20 @@ if [ "$GOHOSTARCH" != "$GOARCH" -o "$GOH
|
||||
echo
|
||||
fi
|
||||
|
||||
-echo "##### Building packages and commands for $GOOS/$GOARCH."
|
||||
-CC="$CC_FOR_TARGET" "$GOTOOLDIR"/go_bootstrap install $GO_FLAGS -gcflags "$GO_GCFLAGS" -ldflags "$GO_LDFLAGS" -v std cmd
|
||||
-echo
|
||||
+if [ "$do_target_build" = "yes" ]; then
|
||||
+ GO_INSTALL="${GO_TARGET_INSTALL:-std cmd}"
|
||||
+ echo "##### Building packages and commands for $GOOS/$GOARCH."
|
||||
+ if [ "$GOHOSTOS" = "$GOOS" -a "$GOHOSTARCH" = "$GOARCH" -a "$do_host_build" = "yes" ]; then
|
||||
+ rm -rf ./host-tools
|
||||
+ mkdir ./host-tools
|
||||
+ mv "$GOTOOLDIR"/* ./host-tools
|
||||
+ GOTOOLDIR="$PWD/host-tools"
|
||||
+ fi
|
||||
+ GOTOOLDIR="$GOTOOLDIR" CC="$CC_FOR_TARGET" "$GOTOOLDIR"/go_bootstrap install $GO_FLAGS -gcflags "$GO_GCFLAGS" -ldflags "$GO_LDFLAGS" -v ${GO_INSTALL}
|
||||
+ echo
|
||||
|
||||
-rm -f "$GOTOOLDIR"/go_bootstrap
|
||||
+ rm -f "$GOTOOLDIR"/go_bootstrap
|
||||
+fi
|
||||
|
||||
if [ "$1" != "--no-banner" ]; then
|
||||
"$GOTOOLDIR"/dist banner
|
57
recipes-devtools/go-cross/go-1.6/syslog.patch
Normal file
57
recipes-devtools/go-cross/go-1.6/syslog.patch
Normal file
|
@ -0,0 +1,57 @@
|
|||
diff -r -u go/src/log/syslog/syslog.go /home/achang/GOCOPY/go/src/log/syslog/syslog.go
|
||||
--- go/src/log/syslog/syslog.go 2013-11-28 13:38:28.000000000 -0800
|
||||
+++ /home/achang/GOCOPY/go/src/log/syslog/syslog.go 2014-10-03 11:44:37.710403200 -0700
|
||||
@@ -33,6 +33,9 @@
|
||||
const severityMask = 0x07
|
||||
const facilityMask = 0xf8
|
||||
|
||||
+var writeTimeout = 1 * time.Second
|
||||
+var connectTimeout = 1 * time.Second
|
||||
+
|
||||
const (
|
||||
// Severity.
|
||||
|
||||
@@ -100,6 +103,7 @@
|
||||
type serverConn interface {
|
||||
writeString(p Priority, hostname, tag, s, nl string) error
|
||||
close() error
|
||||
+ setWriteDeadline(t time.Time) error
|
||||
}
|
||||
|
||||
type netConn struct {
|
||||
@@ -273,7 +277,11 @@
|
||||
nl = "\n"
|
||||
}
|
||||
|
||||
- err := w.conn.writeString(p, w.hostname, w.tag, msg, nl)
|
||||
+ err := w.conn.setWriteDeadline(time.Now().Add(writeTimeout))
|
||||
+ if err != nil {
|
||||
+ return 0, err
|
||||
+ }
|
||||
+ err = w.conn.writeString(p, w.hostname, w.tag, msg, nl)
|
||||
if err != nil {
|
||||
return 0, err
|
||||
}
|
||||
@@ -305,6 +313,10 @@
|
||||
return n.conn.Close()
|
||||
}
|
||||
|
||||
+func (n *netConn) setWriteDeadline(t time.Time) error {
|
||||
+ return n.conn.SetWriteDeadline(t)
|
||||
+}
|
||||
+
|
||||
// NewLogger creates a log.Logger whose output is written to
|
||||
// the system log service with the specified priority. The logFlag
|
||||
// argument is the flag set passed through to log.New to create
|
||||
diff -r -u go/src/log/syslog/syslog_unix.go /home/achang/GOCOPY/go/src/log/syslog/syslog_unix.go
|
||||
--- go/src/log/syslog/syslog_unix.go 2013-11-28 13:38:28.000000000 -0800
|
||||
+++ /home/achang/GOCOPY/go/src/log/syslog/syslog_unix.go 2014-10-03 11:44:39.010403175 -0700
|
||||
@@ -19,7 +19,7 @@
|
||||
logPaths := []string{"/dev/log", "/var/run/syslog"}
|
||||
for _, network := range logTypes {
|
||||
for _, path := range logPaths {
|
||||
- conn, err := net.Dial(network, path)
|
||||
+ conn, err := net.DialTimeout(network, path, connectTimeout)
|
||||
if err != nil {
|
||||
continue
|
||||
} else {
|
2
recipes-devtools/go-cross/go-cross_1.6.bb
Normal file
2
recipes-devtools/go-cross/go-cross_1.6.bb
Normal file
|
@ -0,0 +1,2 @@
|
|||
require go-cross.inc
|
||||
require go-${PV}.inc
|
Loading…
Reference in New Issue
Block a user