Sync from SUSE:SLFO:Main go1.20 revision 63fb588c7a23ddb834fe99cd332c1b52
This commit is contained in:
commit
2306dc9a29
23
.gitattributes
vendored
Normal file
23
.gitattributes
vendored
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
## Default LFS
|
||||||
|
*.7z filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.bsp filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.bz2 filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.gem filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.gz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.jar filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.lz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.lzma filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.obscpio filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.oxt filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.pdf filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.png filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.rpm filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.tbz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.tbz2 filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.tgz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.ttf filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.txz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.whl filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.xz filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.zip filter=lfs diff=lfs merge=lfs -text
|
||||||
|
*.zst filter=lfs diff=lfs merge=lfs -text
|
8
README.SUSE
Normal file
8
README.SUSE
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
# Go Programming Language
|
||||||
|
|
||||||
|
OBS: https://build.opensuse.org/project/show/devel:languages:go
|
||||||
|
|
||||||
|
Maintainer: Jeff Kowalczyk
|
||||||
|
|
||||||
|
Wiki: http://en.opensuse.org/Go
|
||||||
|
http://en.opensuse.org/openSUSE:Packaging_Go
|
7
_constraints
Normal file
7
_constraints
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
<constraints>
|
||||||
|
<hardware>
|
||||||
|
<disk>
|
||||||
|
<size unit="G">5</size>
|
||||||
|
</disk>
|
||||||
|
</hardware>
|
||||||
|
</constraints>
|
16
_service
Normal file
16
_service
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
<services>
|
||||||
|
<service name="download_files" mode="disabled"/>
|
||||||
|
<service name="tar_scm" mode="disabled">
|
||||||
|
<param name="url">https://github.com/llvm/llvm-project.git</param>
|
||||||
|
<param name="scm">git</param>
|
||||||
|
<param name="include">compiler-rt</param>
|
||||||
|
<!-- [boo#1052528] Always make sure this is kept up to date with src/runtime/race/README. -->
|
||||||
|
<param name="revision">74c2d4f6024c8f160871a2baa928d0b42415f183</param>
|
||||||
|
<param name="versionformat">%H</param>
|
||||||
|
<param name="filename">llvm</param>
|
||||||
|
</service>
|
||||||
|
<service name="recompress" mode="disabled">
|
||||||
|
<param name="file">llvm-*.tar</param>
|
||||||
|
<param name="compression">xz</param>
|
||||||
|
</service>
|
||||||
|
</services>
|
33
dont-force-gold-on-arm64.patch
Normal file
33
dont-force-gold-on-arm64.patch
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
--- go/src/cmd/link/internal/ld/lib.go
|
||||||
|
+++ go/src/cmd/link/internal/ld/lib.go
|
||||||
|
@@ -1391,30 +1391,6 @@
|
||||||
|
// Use lld to avoid errors from default linker (issue #38838)
|
||||||
|
altLinker = "lld"
|
||||||
|
}
|
||||||
|
-
|
||||||
|
- if ctxt.Arch.InFamily(sys.ARM, sys.ARM64) && buildcfg.GOOS == "linux" {
|
||||||
|
- // On ARM, the GNU linker will generate COPY relocations
|
||||||
|
- // even with -znocopyreloc set.
|
||||||
|
- // https://sourceware.org/bugzilla/show_bug.cgi?id=19962
|
||||||
|
- //
|
||||||
|
- // On ARM64, the GNU linker will fail instead of
|
||||||
|
- // generating COPY relocations.
|
||||||
|
- //
|
||||||
|
- // In both cases, switch to gold.
|
||||||
|
- altLinker = "gold"
|
||||||
|
-
|
||||||
|
- // If gold is not installed, gcc will silently switch
|
||||||
|
- // back to ld.bfd. So we parse the version information
|
||||||
|
- // and provide a useful error if gold is missing.
|
||||||
|
- name, args := flagExtld[0], flagExtld[1:]
|
||||||
|
- args = append(args, "-fuse-ld=gold", "-Wl,--version")
|
||||||
|
- cmd := exec.Command(name, args...)
|
||||||
|
- if out, err := cmd.CombinedOutput(); err == nil {
|
||||||
|
- if !bytes.Contains(out, []byte("GNU gold")) {
|
||||||
|
- log.Fatalf("ARM external linker must be gold (issue #15696), but is not: %s", out)
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
- }
|
||||||
|
}
|
||||||
|
if ctxt.Arch.Family == sys.ARM64 && buildcfg.GOOS == "freebsd" {
|
||||||
|
// Switch to ld.bfd on freebsd/arm64.
|
64
gcc-go.patch
Normal file
64
gcc-go.patch
Normal file
@ -0,0 +1,64 @@
|
|||||||
|
--- go.orig/src/cmd/dist/buildtool.go
|
||||||
|
+++ go/src/cmd/dist/buildtool.go
|
||||||
|
@@ -203,7 +203,7 @@
|
||||||
|
// Use the purego build tag to disable other assembly code,
|
||||||
|
// such as in cmd/internal/notsha256.
|
||||||
|
cmd := []string{
|
||||||
|
- pathf("%s/bin/go", goroot_bootstrap),
|
||||||
|
+ pathf("%s/bin/go-$gcc_go_version", goroot_bootstrap),
|
||||||
|
"install",
|
||||||
|
"-tags=math_big_pure_go compiler_bootstrap purego",
|
||||||
|
}
|
||||||
|
--- go.orig/src/make.bash
|
||||||
|
+++ go/src/make.bash
|
||||||
|
@@ -175,8 +175,8 @@
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
done; unset IFS
|
||||||
|
-if [ ! -x "$GOROOT_BOOTSTRAP/bin/go" ]; then
|
||||||
|
- echo "ERROR: Cannot find $GOROOT_BOOTSTRAP/bin/go." >&2
|
||||||
|
+if [ ! -x "$GOROOT_BOOTSTRAP/bin/go-$gcc_go_version" ]; then
|
||||||
|
+ echo "ERROR: Cannot find $GOROOT_BOOTSTRAP/bin/go-$gcc_go_version." >&2
|
||||||
|
echo "Set \$GOROOT_BOOTSTRAP to a working Go tree >= Go $bootgo." >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
@@ -194,7 +194,7 @@
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
rm -f cmd/dist/dist
|
||||||
|
-GOROOT="$GOROOT_BOOTSTRAP" GOOS="" GOARCH="" GO111MODULE=off GOEXPERIMENT="" GOENV=off GOFLAGS="" "$GOROOT_BOOTSTRAP/bin/go" build -o cmd/dist/dist ./cmd/dist
|
||||||
|
+GOROOT="$GOROOT_BOOTSTRAP" GOOS="" GOARCH="" GO111MODULE=off GOEXPERIMENT="" GOENV=off GOFLAGS="" "$GOROOT_BOOTSTRAP/bin/go-$gcc_go_version" build -o cmd/dist/dist ./cmd/dist
|
||||||
|
|
||||||
|
# -e doesn't propagate out of eval, so check success by hand.
|
||||||
|
eval $(./cmd/dist/dist env -p || echo FAIL=true)
|
||||||
|
--- go.orig/src/make.rc
|
||||||
|
+++ go/src/make.rc
|
||||||
|
@@ -58,7 +58,7 @@
|
||||||
|
GOROOT_BOOTSTRAP = $home/$d
|
||||||
|
}
|
||||||
|
for(p in $path){
|
||||||
|
- if(! test -x $GOROOT_BOOTSTRAP/bin/go){
|
||||||
|
+ if(! test -x $GOROOT_BOOTSTRAP/bin/go-$gcc_go_version){
|
||||||
|
if(go_exe = `{path=$p whatis go}){
|
||||||
|
goroot = `{GOROOT='' $go_exe env GOROOT}
|
||||||
|
if(! ~ $goroot $GOROOT){
|
||||||
|
@@ -71,8 +71,8 @@
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
-if(! test -x $GOROOT_BOOTSTRAP/bin/go){
|
||||||
|
- echo 'ERROR: Cannot find '$GOROOT_BOOTSTRAP'/bin/go.' >[1=2]
|
||||||
|
+if(! test -x $GOROOT_BOOTSTRAP/bin/go-$gcc_go_version){
|
||||||
|
+ echo 'ERROR: Cannot find '$GOROOT_BOOTSTRAP'/bin/go-$gcc_go_version.' >[1=2]
|
||||||
|
echo 'Set $GOROOT_BOOTSTRAP to a working Go tree >= Go '$bootgo'.' >[1=2]
|
||||||
|
exit bootstrap
|
||||||
|
}
|
||||||
|
@@ -89,7 +89,7 @@
|
||||||
|
echo 'Building Go cmd/dist using '$GOROOT_BOOTSTRAP'. ('$"GOROOT_BOOTSTRAP_VERSION')'
|
||||||
|
if(~ $#vflag 1)
|
||||||
|
echo cmd/dist
|
||||||
|
-GOROOT=$GOROOT_BOOTSTRAP GOOS='' GOARCH='' GOEXPERIMENT='' GO111MODULE=off GOENV=off GOFLAGS='' $GOROOT_BOOTSTRAP/bin/go build -o cmd/dist/dist ./cmd/dist
|
||||||
|
+GOROOT=$GOROOT_BOOTSTRAP GOOS='' GOARCH='' GOEXPERIMENT='' GO111MODULE=off GOENV=off GOFLAGS='' $GOROOT_BOOTSTRAP/bin/go-$gcc_go_version build -o cmd/dist/dist ./cmd/dist
|
||||||
|
|
||||||
|
eval `{./cmd/dist/dist env -9}
|
||||||
|
if(~ $#vflag 1)
|
9
go-rpmlintrc
Normal file
9
go-rpmlintrc
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
addFilter("binaryinfo-readelf-failed") # go binaries are suposedly ELF-compliant
|
||||||
|
addFilter("statically-linked-binary") # go doesn't yet support dynamic linking
|
||||||
|
|
||||||
|
# .syso files are special. Note that while they are architecture-dependent,
|
||||||
|
# they are named to avoid conflicts (and we make sure of that in the RPM
|
||||||
|
# through go_arch).
|
||||||
|
addFilter("unstripped-binary-or-object.*\.syso$")
|
||||||
|
addFilter("arch-dependent-file-in-usr-share.*\.syso$")
|
||||||
|
addFilter("W: position-independent-executable-suggested")
|
1
go.gdbinit
Normal file
1
go.gdbinit
Normal file
@ -0,0 +1 @@
|
|||||||
|
add-auto-load-safe-path /usr/lib/go/$go_label/src/runtime/runtime-gdb.py
|
BIN
go1.20.14.src.tar.gz
(Stored with Git LFS)
Normal file
BIN
go1.20.14.src.tar.gz
(Stored with Git LFS)
Normal file
Binary file not shown.
859
go1.20.changes
Normal file
859
go1.20.changes
Normal file
@ -0,0 +1,859 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Feb 6 18:22:28 UTC 2024 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- go1.20.14 (released 2024-02-06) includes fixes to the crypto/x509
|
||||||
|
package.
|
||||||
|
Refs boo#1206346 go1.20 release tracking
|
||||||
|
* go#64760 staticlockranking builders failing on release branches on LUCI
|
||||||
|
* go#65322 crypto: rollback BoringCrypto fips-20220613 update
|
||||||
|
* go#65379 crypto/x509: TestIssue51759 consistently failing on gotip-darwin-amd64_10.15 LUCI builder
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Jan 9 18:40:15 UTC 2024 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- go1.20.13 (released 2024-01-09) includes fixes to the runtime and
|
||||||
|
the crypto/tls package.
|
||||||
|
Refs boo#1206346 go1.20 release tracking
|
||||||
|
* go#63910 x/build,os/signal: TestDetectNohup and TestNohup fail on replacement darwin LUCI builders
|
||||||
|
* go#64409 runtime: ReadMemStats fatal error: mappedReady and other memstats are not equal
|
||||||
|
* go#64718 crypto: upgrade to BoringCrypto fips-20220613 and enable TLS 1.3
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Dec 5 19:03:51 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- go1.20.12 (released 2023-12-05) includes security fixes to the go
|
||||||
|
command, and the net/http and path/filepath packages, as well as
|
||||||
|
bug fixes to the compiler and the go command.
|
||||||
|
Refs boo#1206346 go1.20 release tracking
|
||||||
|
CVE-2023-45285 CVE-2023-45284 CVE-2023-39326
|
||||||
|
* go#63972 go#63845 boo#1217834 security: fix CVE-2023-45285 cmd/go: git VCS qualifier in module path uses git:// scheme
|
||||||
|
* go#64040 go#63713 boo#1216943 security: fix CVE-2023-45284 path/filepath: Clean removes ending slash for volume on Windows in Go 1.21.4
|
||||||
|
* go#64434 go#64433 boo#1217833 security: fix CVE-2023-39326 net/http: limit chunked data overhead
|
||||||
|
* go#63983 cmd/compile: internal compiler error: panic during prove while compiling: unexpected induction with too many parents
|
||||||
|
* go#63988 cmd/go: TestScript/mod_get_direct fails with "Filename too long" on Windows
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Nov 7 19:29:09 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- go1.20.11 (released 2023-11-07) includes security fixes to the
|
||||||
|
path/filepath package, as well as bug fixes to the linker and the
|
||||||
|
net/http package.
|
||||||
|
Refs boo#1206346 go1.20 release tracking
|
||||||
|
CVE-2023-45283 CVE-2023-45284
|
||||||
|
* go#63714 go#63713 boo#1216943 boo#1216944 security: fix CVE-2023-45283 CVE-2023-45284 path/filepath: insecure parsing of Windows paths
|
||||||
|
* go#63316 cmd/link: split text sections for arm 32-bit
|
||||||
|
* go#63740 net/http: http2 page fails on firefox/safari if pushing resources
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Oct 10 18:27:08 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- go1.20.10 (released 2023-10-10) includes a security fix to the
|
||||||
|
net/http package.
|
||||||
|
Refs boo#1206346 go1.20 release tracking
|
||||||
|
CVE-2023-39325 CVE-2023-44487
|
||||||
|
* go#63426 go#63417 boo#1216109 security: fix CVE-2023-39325 CVE-2023-44487 net/http: rapid stream resets can cause excessive work
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Thu Oct 5 20:28:19 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- go1.20.9 (released 2023-10-05) includes one security fixes to the
|
||||||
|
cmd/go package, as well as bug fixes to the go command and the
|
||||||
|
linker.
|
||||||
|
Refs boo#1206346 go1.20 release tracking
|
||||||
|
CVE-2023-39323
|
||||||
|
* go#63213 go#63211 boo#1215985 security: fix CVE-2023-39323 cmd/go: line directives allows arbitrary execution during build
|
||||||
|
* go#62597 cmd/link: issues with Apple's new linker in Xcode 15 beta
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Wed Sep 6 15:08:50 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- go1.20.8 (released 2023-09-06) includes two security fixes to the
|
||||||
|
html/template package, as well as bug fixes to the compiler, the
|
||||||
|
go command, the runtime, and the crypto/tls, go/types, net/http,
|
||||||
|
and path/filepath packages.
|
||||||
|
Refs boo#1206346 go1.20 release tracking
|
||||||
|
CVE-2023-39318 CVE-2023-39319
|
||||||
|
* go#62395 go#62196 boo#1215084 security: fix CVE-2023-39318 html/template: improper handling of HTML-like comments within script contexts
|
||||||
|
* go#62397 go#62197 boo#1215085 security: fix CVE-2023-39319 html/template: improper handling of special tags within script contexts
|
||||||
|
* go#61198 cmd/go: extended forwards compatibility for Go
|
||||||
|
* go#61744 go/types: interface.Complete panics for interfaces with duplicate methods
|
||||||
|
* go#61826 net/http: go 1.20.6 host validation breaks setting Host to a unix socket address
|
||||||
|
* go#61867 path/filepath: Clean on some invalid Windows paths can lose .. components
|
||||||
|
* go#61873 cmd/go: using a module path without dot fails to build after toolchain selection
|
||||||
|
* go#61966 crypto/tls: add GODEBUG to control max RSA key size
|
||||||
|
* go#62018 runtime: execution halts with goroutines stuck in runtime.gopark (protocol error E08 during memory read for packet)
|
||||||
|
* go#62056 cmd/compile: internal compiler error: 'F': func F, startMem[b1] has different values
|
||||||
|
* go#62070 cmd/api: make non-importable
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Sep 5 19:12:05 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- Add missing directory pprof html asset directory to package.
|
||||||
|
Refs boo#1215090
|
||||||
|
* src/cmd/vendor/github.com/google/pprof/internal/driver/html/
|
||||||
|
dir containing html assets is present in upstream Go
|
||||||
|
distribution but missing from SUSE go1.x packages
|
||||||
|
* Go programs importing runtime/pprof may fail with error:
|
||||||
|
/usr/lib64/go/1.21/src/cmd/vendor/github.com/google/pprof/internal/driver/webhtml.go
|
||||||
|
pattern html: no matching files found
|
||||||
|
* Reformat adjacent commment in spec file
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Aug 1 20:35:02 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- go1.20.7 (released 2023-08-01) includes a security fix to the
|
||||||
|
crypto/tls package, as well as bug fixes to the assembler and the
|
||||||
|
compiler.
|
||||||
|
Refs boo#1206346 go1.20 release tracking
|
||||||
|
CVE-2023-29409
|
||||||
|
* go#61580 go#61460 boo#1213880 security: fix CVE-2023-29409 crypto/tls: restrict RSA keys in certificates to <= 8192 bits
|
||||||
|
* go#61320 cmd/compile: ppc64le: sign extension issue in go 1.21rc2
|
||||||
|
* go#61449 net: TestInterfaceArrivalAndDepartureZoneCache is broken on linux-arm64
|
||||||
|
* go#61471 cmd/compile: failed to make Go on riscv64 CPU with numa
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Jul 11 17:50:52 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- go1.20.6 (released 2023-07-11) includes a security fix to the
|
||||||
|
net/http package, as well as bug fixes to the compiler, cgo, the
|
||||||
|
cover tool, the go command, the runtime, and the crypto/ecdsa,
|
||||||
|
go/build, go/printer, net/mail, and text/template packages.
|
||||||
|
Refs boo#1206346 go1.20 release tracking
|
||||||
|
CVE-2023-29406
|
||||||
|
* go#61076 go#60374 boo#1213229 security: fix CVE-2023-29406 net/http: insufficient sanitization of Host header
|
||||||
|
* go#60352 cmd/go: go mod tidy introduces ambiguous imports in pruned modules
|
||||||
|
* go#60535 runtime: TLS slot index over 64 and crash
|
||||||
|
* go#60675 cmd/compile: internal compiler error: out of range for go.shape.int64
|
||||||
|
* go#60698 cmd/go: go list fails with submodules which have test-only dependencies
|
||||||
|
* go#60744 crypto/ecdsa: P521 ecdsa.Verify panics with malformed message
|
||||||
|
* go#60754 cmd/go: panic: LoadImport called with empty package path when listing GOROOT/test/*.go
|
||||||
|
* go#60760 runtime: checkdead fires due to suspected race in the Go runtime when GOMAXPROCS=1 on AWS
|
||||||
|
* go#60802 text/template: key/value assignment is reversed within range loop
|
||||||
|
* go#60845 runtime: SIGSEGV in race + coverage mode
|
||||||
|
* go#60849 cmd/go: go test deadlocked without enforcing timeouts when killed with ^C
|
||||||
|
* go#60874 net/mail: mail.ReadMessage in 1.20 cannot parse mbox headers
|
||||||
|
* go#60875 net/mail: characters allowed in RFC 5322 are invalid while parsing email header
|
||||||
|
* go#60927 x/tools/go/analysis/unitchecker: TestVetStdlib failures
|
||||||
|
* go#60947 crypto/x509: TestSystemVerify/EKULeafValid fails on LUCI
|
||||||
|
* go#60949 runtime: goroutines that stop after calling runtime.RaceDisable break race detector
|
||||||
|
* go#61055 runtime: TestWindowsStackMemory flakes on windows-386-2016
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Jun 6 19:13:57 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- go1.20.5 (released 2023-06-06) includes four security fixes to
|
||||||
|
the cmd/go and runtime packages, as well as bug fixes to the
|
||||||
|
compiler, the go command, the runtime, and the crypto/rsa, net,
|
||||||
|
and os packages.
|
||||||
|
Refs boo#1206346 go1.20 release tracking
|
||||||
|
CVE-2023-29402 CVE-2023-29403 CVE-2023-29404 CVE-2023-29405
|
||||||
|
* go#60516 go#60167 boo#1212073 security: fix CVE-2023-29402 cmd/go: cgo code injection
|
||||||
|
* go#60518 go#60272 boo#1212074 security: fix CVE-2023-29403 runtime: unexpected behavior of setuid/setgid binaries
|
||||||
|
* go#60512 go#60305 boo#1212075 security: fix CVE-2023-29404 cmd/go: improper sanitization of LDFLAGS
|
||||||
|
* go#60514 go#60306 boo#1212076 security: fix CVE-2023-29405 cmd/go: improper sanitization of LDFLAGS
|
||||||
|
* go#58927 crypto/rsa: 4096 bit keys are not generated with BoringCrypto
|
||||||
|
* go#59975 cmd/compile: multiple memories live at block start
|
||||||
|
* go#60001 cmd/go: missing checksums for dependencies of go get arguments and tests of external dependencies
|
||||||
|
* go#60217 os: Read of a device driver fails only with Go 1.20
|
||||||
|
* go#60458 cmd/go: document GOROOT/bin/go PATH entry for go test and go generate
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue May 2 17:24:29 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- go1.20.4 (released 2023-05-02) includes three security fixes to
|
||||||
|
the html/template package, as well as bug fixes to the compiler,
|
||||||
|
the runtime, and the crypto/subtle, crypto/tls, net/http, and
|
||||||
|
syscall packages.
|
||||||
|
Refs boo#1206346 go1.20 release tracking
|
||||||
|
CVE-2023-29400 CVE-2023-24540 CVE-2023-24539
|
||||||
|
* go#59812 go#59720 boo#1211029 security: fix CVE-2023-24539 html/template: improper sanitization of CSS values
|
||||||
|
* go#59814 go#59721 boo#1211030 security: fix CVE-2023-24540 html/template: improper handling of JavaScript whitespace
|
||||||
|
* go#59816 go#59722 boo#1211031 security: fix CVE-2023-29400 html/template: improper handling of empty HTML attributes
|
||||||
|
* go#59064 runtime: automatically bump RLIMIT_NOFILE on Unix
|
||||||
|
* go#59336 crypto/subtle: xor fails when run with race+purego
|
||||||
|
* go#59374 cmd/compile: encoding/binary.PutUint16 sometimes doesn't write
|
||||||
|
* go#59450 cmd/compile: internal compiler error: cannot call SetType(go.shape.int) on v (type int)
|
||||||
|
* go#59468 cmd/compile: miscompilation in star-tex.org/x/cmd/star-tex
|
||||||
|
* go#59469 net/http: FileServer no longer serves content for POST
|
||||||
|
* go#59540 crypto/tls: TLSv1.3 connection fails with invalid PSK binder
|
||||||
|
* go#59580 cmd/compile: incorrect inline function variable
|
||||||
|
* go#59585 cmd/compile: Unified IR exports table is binary unstable in presence of generics
|
||||||
|
* go#59637 go/internal/gcimporter: lookupGorootExport should use the go command from build.Default.GOROOT
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue May 2 17:08:49 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- Packaging revert go1.x Suggests go1.x-race boo#1210963
|
||||||
|
* Upstream go binary distributions do include race detector .syso
|
||||||
|
* Default Recommends for subpackages is best suited in this case
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Fri Apr 28 23:47:22 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- Packaging improvements:
|
||||||
|
* Re-enable binary stripping and debuginfo boo#1210938
|
||||||
|
* go1.x Suggests go1.x-race do not install by default boo#1210963
|
||||||
|
* Use Group: Development/Languages/Go instead of Other
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Apr 4 20:42:31 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- go1.20.3 (released 2023-04-04) includes security fixes to the
|
||||||
|
go/parser, html/template, mime/multipart, net/http, and
|
||||||
|
net/textproto packages, as well as bug fixes to the compiler, the
|
||||||
|
linker, the runtime, and the time package.
|
||||||
|
Refs boo#1206346 go1.20 release tracking
|
||||||
|
CVE-2023-24534 CVE-2023-24536 CVE-2023-24537 CVE-2023-24538
|
||||||
|
* go#59268 go#58975 boo#1210127 security: fix CVE-2023-24534 net/http, net/textproto: denial of service from excessive memory allocation
|
||||||
|
* go#59270 go#59153 boo#1210128 security: fix CVE-2023-24536 net/http, net/textproto, mime/multipart: denial of service from excessive resource consumption
|
||||||
|
* go#59274 go#59180 boo#1210129 security: fix CVE-2023-24537 go/parser: infinite loop in parsing
|
||||||
|
* go#59272 go#59234 boo#1210130 security: fix CVE-2023-24538 html/template: backticks not treated as string delimiters
|
||||||
|
* go#58920 x/text: building as a plugin failure on darwin/arm64
|
||||||
|
* go#58938 cmd/go: timeout on darwin-amd64-race builder
|
||||||
|
* go#58942 internal/testpty: fails on some Linux machines due to incorrect error handling
|
||||||
|
* go#58954 cmd/link: Incorrect symbol linked in darwin/arm64
|
||||||
|
* go#59051 cmd/link: linker fails on linux/amd64 when gcc's lto options are used
|
||||||
|
* go#59059 cmd/link/internal/arm: off-by-one error in trampoline phase call reachability calculation
|
||||||
|
* go#59075 time: time zone lookup using extend string makes wrong start time for non-DST zones
|
||||||
|
* go#59220 runtime: crash on linux-ppc64le
|
||||||
|
* go#59236 cmd/compile: crypto/elliptic build error under -linkshared mode
|
||||||
|
* go#59296 cmd/compile: unsafe.SliceData incoherent resuilt with nil argument
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Apr 4 16:59:57 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- Build subpackage go1.x-libstd compiled shared object libstd.so
|
||||||
|
only on Tumbleweed at this time.
|
||||||
|
Refs jsc#PED-1962
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Thu Mar 9 20:39:23 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- Add subpackage go1.x-libstd for compiled shared object libstd.so.
|
||||||
|
Refs jsc#PED-1962
|
||||||
|
* Main go1.x package included libstd.so in previous versions
|
||||||
|
* Split libstd.so into subpackage that can be installed standalone
|
||||||
|
* Continues the slimming down of main go1.x package by 40 Mb
|
||||||
|
* Experimental and not recommended for general use, Go currently has no ABI
|
||||||
|
* Upstream Go has not committed to support buildmode=shared long-term
|
||||||
|
* Do not use in packaging, build static single binaries (the default)
|
||||||
|
* Upstream Go go1.x binary releases do not include libstd.so
|
||||||
|
* go1.x Suggests go1.x-libstd so not installed by default Recommends
|
||||||
|
* go1.x-libstd does not Require: go1.x so can install standalone
|
||||||
|
* Provides go-libstd unversioned package name
|
||||||
|
* Fix build step -buildmode=shared std to omit -linkshared
|
||||||
|
- Packaging improvements:
|
||||||
|
* go1.x Suggests go1.x-doc so not installed by default Recommends
|
||||||
|
* Use Group: Development/Languages/Go instead of Other
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Mar 7 18:03:10 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- go1.20.2 (released 2023-03-07) includes a security fix to the
|
||||||
|
crypto/elliptic package, as well as bug fixes to the compiler,
|
||||||
|
the covdata command, the linker, the runtime, and the
|
||||||
|
crypto/ecdh, crypto/rsa, crypto/x509, os, and syscall packages.
|
||||||
|
Refs boo#1206346 go1.20 release tracking
|
||||||
|
CVE-2023-24532
|
||||||
|
* go#58720 go#58647 boo#1209030 security: fix CVE-2023-24532 crypto/elliptic: specific unreduced P-256 scalars produce incorrect results
|
||||||
|
* go#58427 cmd/covdata: short read on string table when merging coverage counters
|
||||||
|
* go#58442 runtime: some linkname signatures do not match
|
||||||
|
* go#58444 cmd/compile: inline static init cause compile time error
|
||||||
|
* go#58467 cmd/compile: internal compiler error: '(*Tree[go.shape.int]).RemoveParent.func1': value .dict (nil) incorrectly live at entry
|
||||||
|
* go#58498 crypto/ecdh: ECDH method doesn't check curve
|
||||||
|
* go#58503 cmd/link: relocation truncated to fit: R_ARM_CALL against `runtime.duffcopy'
|
||||||
|
* go#58505 crypto/internal/bigmod: flag amd64 assembly as noescape
|
||||||
|
* go#58531 runtime: endless traceback when panic in generics funtion
|
||||||
|
* go#58536 runtime: long latency of sweep assists
|
||||||
|
* go#58624 syscall.Faccessat and os.LookPath regression in Go 1.20
|
||||||
|
* go#58627 os: cmd/go gets error "copy_file_range: function not implemented"
|
||||||
|
* go#58717 net: TestTCPSelfConnect failures due to unexpected connections
|
||||||
|
* go#58774 syscall: Environ uses an invalid unsafe.Pointer conversion on Windows
|
||||||
|
* go#58776 cmd/compile: ICE on method value involving imported anonymous interface
|
||||||
|
* go#58793 crypto/x509: Incorrect documentation for ParsePKCS8PrivateKey
|
||||||
|
* go#58811 crypto/x509: TestSystemVerify consistently failing
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Fri Feb 17 07:26:36 UTC 2023 - Dirk Müller <dmueller@suse.com>
|
||||||
|
|
||||||
|
- Improvements to go1.x packaging spec:
|
||||||
|
* On Tumbleweed bootstrap with current default gcc13 and gccgo118
|
||||||
|
* On SLE-12 aarch64 ppc64le ppc64 remove overrides to bootstrap
|
||||||
|
using go1.x package (%bcond_without gccgo). This is no longer
|
||||||
|
needed on current SLE-12:Update and removing will consolidate
|
||||||
|
the build configurations used.
|
||||||
|
* Change source URLs to go.dev as per Go upstream
|
||||||
|
* On x86_64 export GOAMD64=v1 as per the current baseline.
|
||||||
|
At this time forgo GOAMD64=v3 option for x86_64_v3 support.
|
||||||
|
* On x86_64 %define go_amd64=v1 as current instruction baseline
|
||||||
|
* In %check on x86_64 use value %go_amd64=v1 as GOAMD64=v1 to
|
||||||
|
grep correct TSAN version is checked out from LLVM with new
|
||||||
|
spelling for internal/amd64v1/race_linux.syso
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Feb 14 18:28:32 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- go1.20.1 (released 2023-02-14) includes security fixes to the
|
||||||
|
crypto/tls, mime/multipart, net/http, and path/filepath packages,
|
||||||
|
as well as bug fixes to the compiler, the go command, the linker,
|
||||||
|
the runtime, and the time package.
|
||||||
|
Refs boo#1206346 go1.20 release tracking
|
||||||
|
CVE-2022-41722 CVE-2022-41723 CVE-2022-41724 CVE-2022-41725
|
||||||
|
* go#57276 boo#1208269 security: fix CVE-2022-41722 path/filepath: path traversal in filepath.Clean on Windows
|
||||||
|
* go#58356 boo#1208270 security: fix CVE-2022-41723 net/http: avoid quadratic complexity in HPACK decoding
|
||||||
|
* go#58359 boo#1208271 security: fix CVE-2022-41724 crypto/tls: large handshake records may cause panics
|
||||||
|
* go#58363 boo#1208272 security: fix CVE-2022-41725 net/http, mime/multipart: denial of service from excessive resource consumption
|
||||||
|
* go#58117 time: update zoneinfo_abbrs on Windows
|
||||||
|
* go#58224 cmd/link: .go.buildinfo is gc'ed by --gc-sections
|
||||||
|
* go#58309 cmd/compile/internal/pgo: Detect sample value position instead of hard-coding
|
||||||
|
* go#58319 cmd/compile: constant overflows when assigned to package level var (Go 1.20 regression)
|
||||||
|
* go#58335 cmd/compile: internal compiler error: panic: interface conversion: ir.Node is *ir.CompLitExpr, not *ir.Name
|
||||||
|
* go#58413 cmd/compile: internal compiler error: Type.Elem UNION
|
||||||
|
* go#58419 runtime: GOOS=ios fails Apple's app validation due to use of private API
|
||||||
|
* go#58421 cmd/go/internal/test: stale flagdefs.go not detected by tests
|
||||||
|
* go#58431 all: test failures with ETXTBSY
|
||||||
|
* go#58450 cmd/go/internal/modfetch: TestCodeRepo/gopkg.in_natefinch_lumberjack.v2/latest failing
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Wed Feb 1 20:18:59 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- go1.20 (released 2023-02-01) is a major release of Go.
|
||||||
|
go1.20.x minor releases will be provided through February 2024.
|
||||||
|
https://github.com/golang/go/wiki/Go-Release-Cycle
|
||||||
|
go1.20 arrives six months after go1.19. Most of its changes are
|
||||||
|
in the implementation of the toolchain, runtime, and libraries.
|
||||||
|
As always, the release maintains the Go 1 promise of
|
||||||
|
compatibility. We expect almost all Go programs to continue to
|
||||||
|
compile and run as before.
|
||||||
|
Refs boo#1206346 go1.20 release tracking
|
||||||
|
Refs jsc#PED-1962
|
||||||
|
* Go 1.20 includes four changes to the language
|
||||||
|
* Language change: Go 1.17 added conversions from slice to an
|
||||||
|
array pointer. Go 1.20 extends this to allow conversions from a
|
||||||
|
slice to an array
|
||||||
|
* Language change: The unsafe package defines three new functions
|
||||||
|
SliceData, String, and StringData. Along with Go 1.17's Slice,
|
||||||
|
these functions now provide the complete ability to construct
|
||||||
|
and deconstruct slice and string values, without depending on
|
||||||
|
their exact representation.
|
||||||
|
* Language change: The specification now defines that struct
|
||||||
|
values are compared one field at a time, considering fields in
|
||||||
|
the order they appear in the struct type definition, and
|
||||||
|
stopping at the first mismatch. The specification could
|
||||||
|
previously have been read as if all fields needed to be
|
||||||
|
compared beyond the first mismatch. Similarly, the
|
||||||
|
specification now defines that array values are compared one
|
||||||
|
element at a time, in increasing index order. In both cases,
|
||||||
|
the difference affects whether certain comparisons must
|
||||||
|
panic. Existing programs are unchanged: the new spec wording
|
||||||
|
describes what the implementations have always done.
|
||||||
|
* Language change: Comparable types (such as ordinary interfaces)
|
||||||
|
may now satisfy comparable constraints, even if the type
|
||||||
|
arguments are not strictly comparable (comparison may panic at
|
||||||
|
runtime). This makes it possible to instantiate a type
|
||||||
|
parameter constrained by comparable (e.g., a type parameter for
|
||||||
|
a user-defined generic map key) with a non-strictly comparable
|
||||||
|
type argument such as an interface type, or a composite type
|
||||||
|
containing an interface type.
|
||||||
|
* go command: The directory $GOROOT/pkg no longer stores
|
||||||
|
pre-compiled package archives for the standard library: go
|
||||||
|
install no longer writes them, the go build no longer checks
|
||||||
|
for them, and the Go distribution no longer ships
|
||||||
|
them. Instead, packages in the standard library are built as
|
||||||
|
needed and cached in the build cache, just like packages
|
||||||
|
outside GOROOT. This change reduces the size of the Go
|
||||||
|
distribution and also avoids C toolchain skew for packages that
|
||||||
|
use cgo. Refs jsc#PED-1962
|
||||||
|
* go command: The implementation of go test -json has been
|
||||||
|
improved to make it more robust. Programs that run go test
|
||||||
|
-json do not need any updates. Programs that invoke go tool
|
||||||
|
test2json directly should now run the test binary with
|
||||||
|
-v=test2json (for example, go test -v=test2json or ./pkg.test
|
||||||
|
-test.v=test2json) instead of plain -v.
|
||||||
|
* go command: A related change to go test -json is the addition
|
||||||
|
of an event with Action set to start at the beginning of each
|
||||||
|
test program's execution. When running multiple tests using the
|
||||||
|
go command, these start events are guaranteed to be emitted in
|
||||||
|
the same order as the packages named on the command line.
|
||||||
|
* go command: The go command now defines architecture feature
|
||||||
|
build tags, such as amd64.v2, to allow selecting a package
|
||||||
|
implementation file based on the presence or absence of a
|
||||||
|
particular architecture feature. See go help buildconstraint
|
||||||
|
for details.
|
||||||
|
* go command: The go subcommands now accept -C <dir> to change
|
||||||
|
directory to <dir> before performing the command, which may be
|
||||||
|
useful for scripts that need to execute commands in multiple
|
||||||
|
different modules.
|
||||||
|
* go command: The go build and go test commands no longer accept
|
||||||
|
the -i flag, which has been deprecated since Go 1.16.
|
||||||
|
* go command: The go generate command now accepts -skip <pattern>
|
||||||
|
to skip //go:generate directives matching <pattern>.
|
||||||
|
* go command: The go test command now accepts -skip <pattern> to
|
||||||
|
skip tests, subtests, or examples matching <pattern>.
|
||||||
|
* go command: When the main module is located within GOPATH/src,
|
||||||
|
go install no longer installs libraries for non-main packages
|
||||||
|
to GOPATH/pkg, and go list no longer reports a Target field for
|
||||||
|
such packages. (In module mode, compiled packages are stored in
|
||||||
|
the build cache only, but a bug had caused the GOPATH install
|
||||||
|
targets to unexpectedly remain in effect.)
|
||||||
|
* go command: The go build, go install, and other build-related
|
||||||
|
commands now support a -pgo flag that enables profile-guided
|
||||||
|
optimization, which is described in more detail in the Compiler
|
||||||
|
section below. The -pgo flag specifies the file path of the
|
||||||
|
profile. Specifying -pgo=auto causes the go command to search
|
||||||
|
for a file named default.pgo in the main package's directory
|
||||||
|
and use it if present. This mode currently requires a single
|
||||||
|
main package to be specified on the command line, but we plan
|
||||||
|
to lift this restriction in a future release. Specifying
|
||||||
|
-pgo=off turns off profile-guided optimization.
|
||||||
|
* go command: The go build, go install, and other build-related
|
||||||
|
commands now support a -cover flag that builds the specified
|
||||||
|
target with code coverage instrumentation. This is described in
|
||||||
|
more detail in the Cover section below.
|
||||||
|
* go version: The go version -m command now supports reading more
|
||||||
|
types of Go binaries, most notably, Windows DLLs built with go
|
||||||
|
build -buildmode=c-shared and Linux binaries without execute
|
||||||
|
permission.
|
||||||
|
* Cgo: The go command now disables cgo by default on systems
|
||||||
|
without a C toolchain. More specifically, when the CGO_ENABLED
|
||||||
|
environment variable is unset, the CC environment variable is
|
||||||
|
unset, and the default C compiler (typically clang or gcc) is
|
||||||
|
not found in the path, CGO_ENABLED defaults to 0. As always,
|
||||||
|
you can override the default by setting CGO_ENABLED explicitly.
|
||||||
|
The most important effect of the default change is that when Go
|
||||||
|
is installed on a system without a C compiler, it will now use
|
||||||
|
pure Go builds for packages in the standard library that use
|
||||||
|
cgo, instead of using pre-distributed package archives (which
|
||||||
|
have been removed, as noted above) or attempting to use cgo and
|
||||||
|
failing. This makes Go work better in some minimal container
|
||||||
|
environments as well as on macOS, where pre-distributed package
|
||||||
|
archives have not been used for cgo-based packages since Go
|
||||||
|
1.16.
|
||||||
|
The packages in the standard library that use cgo are net,
|
||||||
|
os/user, and plugin. On macOS, the net and os/user packages
|
||||||
|
have been rewritten not to use cgo: the same code is now used
|
||||||
|
for cgo and non-cgo builds as well as cross-compiled builds. On
|
||||||
|
Windows, the net and os/user packages have never used cgo. On
|
||||||
|
other systems, builds with cgo disabled will use a pure Go
|
||||||
|
version of these packages.
|
||||||
|
On macOS, the race detector has been rewritten not to use cgo:
|
||||||
|
race-detector-enabled programs can be built and run without
|
||||||
|
Xcode. On Linux and other Unix systems, and on Windows, a host
|
||||||
|
C toolchain is required to use the race detector.
|
||||||
|
* go cover: Go 1.20 supports collecting code coverage profiles
|
||||||
|
for programs (applications and integration tests), as opposed
|
||||||
|
to just unit tests. To collect coverage data for a program,
|
||||||
|
build it with go build's -cover flag, then run the resulting
|
||||||
|
binary with the environment variable GOCOVERDIR set to an
|
||||||
|
output directory for coverage profiles. See the 'coverage for
|
||||||
|
integration tests' landing page for more on how to get
|
||||||
|
started. For details on the design and implementation, see the
|
||||||
|
proposal.
|
||||||
|
* go vet: Improved detection of loop variable capture by nested
|
||||||
|
functions. The vet tool now reports references to loop
|
||||||
|
variables following a call to T.Parallel() within subtest
|
||||||
|
function bodies. Such references may observe the value of the
|
||||||
|
variable from a different iteration (typically causing test
|
||||||
|
cases to be skipped) or an invalid state due to unsynchronized
|
||||||
|
concurrent access.
|
||||||
|
* go vet: The tool also detects reference mistakes in more
|
||||||
|
places. Previously it would only consider the last statement
|
||||||
|
of the loop body, but now it recursively inspects the last
|
||||||
|
statements within if, switch, and select statements.
|
||||||
|
* go vet: New diagnostic for incorrect time formats. The vet tool
|
||||||
|
now reports use of the time format 2006-02-01 (yyyy-dd-mm) with
|
||||||
|
Time.Format and time.Parse. This format does not appear in
|
||||||
|
common date standards, but is frequently used by mistake when
|
||||||
|
attempting to use the ISO 8601 date format (yyyy-mm-dd).
|
||||||
|
* Runtime: Some of the garbage collector's internal data
|
||||||
|
structures were reorganized to be both more space and CPU
|
||||||
|
efficient. This change reduces memory overheads and improves
|
||||||
|
overall CPU performance by up to 2%.
|
||||||
|
* Runtime: The garbage collector behaves less erratically with
|
||||||
|
respect to goroutine assists in some circumstances.
|
||||||
|
* Runtime: Go 1.20 adds a new runtime/coverage package containing
|
||||||
|
APIs for writing coverage profile data at runtime from
|
||||||
|
long-running and/or server programs that do not terminate via
|
||||||
|
os.Exit().
|
||||||
|
* Compiler: Go 1.20 adds preview support for profile-guided
|
||||||
|
optimization (PGO). PGO enables the toolchain to perform
|
||||||
|
application- and workload-specific optimizations based on
|
||||||
|
run-time profile information. Currently, the compiler supports
|
||||||
|
pprof CPU profiles, which can be collected through usual means,
|
||||||
|
such as the runtime/pprof or net/http/pprof packages. To enable
|
||||||
|
PGO, pass the path of a pprof profile file via the -pgo flag to
|
||||||
|
go build, as mentioned above. Go 1.20 uses PGO to more
|
||||||
|
aggressively inline functions at hot call sites. Benchmarks for
|
||||||
|
a representative set of Go programs show enabling
|
||||||
|
profile-guided inlining optimization improves performance about
|
||||||
|
3–4%. See the PGO user guide for detailed documentation. We
|
||||||
|
plan to add more profile-guided optimizations in future
|
||||||
|
releases. Note that profile-guided optimization is a preview,
|
||||||
|
so please use it with appropriate caution.
|
||||||
|
* Compiler: The Go 1.20 compiler upgraded its front-end to use a
|
||||||
|
new way of handling the compiler's internal data, which fixes
|
||||||
|
several generic-types issues and enables type declarations
|
||||||
|
within generic functions and methods.
|
||||||
|
* Compiler: The compiler now rejects anonymous interface cycles
|
||||||
|
with a compiler error by default. These arise from tricky uses
|
||||||
|
of embedded interfaces and have always had subtle correctness
|
||||||
|
issues, yet we have no evidence that they're actually used in
|
||||||
|
practice. Assuming no reports from users adversely affected by
|
||||||
|
this change, we plan to update the language specification for
|
||||||
|
Go 1.22 to formally disallow them so tools authors can stop
|
||||||
|
supporting them too.
|
||||||
|
* Compiler: Go 1.18 and 1.19 saw regressions in build speed,
|
||||||
|
largely due to the addition of support for generics and
|
||||||
|
follow-on work. Go 1.20 improves build speeds by up to 10%,
|
||||||
|
bringing it back in line with Go 1.17. Relative to Go 1.19,
|
||||||
|
generated code performance is also generally slightly improved.
|
||||||
|
* Linker: On Linux, the linker now selects the dynamic
|
||||||
|
interpreter for glibc or musl at link time.
|
||||||
|
* Linker: On Windows, the Go linker now supports modern
|
||||||
|
LLVM-based C toolchains.
|
||||||
|
* Linker: Go 1.20 uses go: and type: prefixes for
|
||||||
|
compiler-generated symbols rather than go. and type.. This
|
||||||
|
avoids confusion for user packages whose name starts with
|
||||||
|
go.. The debug/gosym package understands this new naming
|
||||||
|
convention for binaries built with Go 1.20 and newer.
|
||||||
|
* Bootstrap: When building a Go release from source and
|
||||||
|
GOROOT_BOOTSTRAP is not set, previous versions of Go looked for
|
||||||
|
a Go 1.4 or later bootstrap toolchain in the directory
|
||||||
|
$HOME/go1.4 (%HOMEDRIVE%%HOMEPATH%\go1.4 on Windows). Go 1.18
|
||||||
|
and Go 1.19 looked first for $HOME/go1.17 or $HOME/sdk/go1.17
|
||||||
|
before falling back to $HOME/go1.4, in anticipation of
|
||||||
|
requiring Go 1.17 for use when bootstrapping Go 1.20. Go 1.20
|
||||||
|
does require a Go 1.17 release for bootstrapping, but we
|
||||||
|
realized that we should adopt the latest point release of the
|
||||||
|
bootstrap toolchain, so it requires Go 1.17.13. Go 1.20 looks
|
||||||
|
for $HOME/go1.17.13 or $HOME/sdk/go1.17.13 before falling back
|
||||||
|
to $HOME/go1.4 (to support systems that hard-coded the path
|
||||||
|
$HOME/go1.4 but have installed a newer Go toolchain there). In
|
||||||
|
the future, we plan to move the bootstrap toolchain forward
|
||||||
|
approximately once a year, and in particular we expect that Go
|
||||||
|
1.22 will require the final point release of Go 1.20 for
|
||||||
|
bootstrap.
|
||||||
|
* Library: Go 1.20 adds a new crypto/ecdh package to provide
|
||||||
|
explicit support for Elliptic Curve Diffie-Hellman key
|
||||||
|
exchanges over NIST curves and Curve25519. Programs should use
|
||||||
|
crypto/ecdh instead of the lower-level functionality in
|
||||||
|
crypto/elliptic for ECDH, and third-party modules for more
|
||||||
|
advanced use cases.
|
||||||
|
* Error handling: Go 1.20 expands support for error wrapping to
|
||||||
|
permit an error to wrap multiple other errors.
|
||||||
|
* Error handling: An error e can wrap more than one error by
|
||||||
|
providing an Unwrap method that returns a []error.
|
||||||
|
* Error handling: The errors.Is and errors.As functions have been
|
||||||
|
updated to inspect multiply wrapped errors.
|
||||||
|
* Error handling: The fmt.Errorf function now supports multiple
|
||||||
|
occurrences of the %w format verb, which will cause it to
|
||||||
|
return an error that wraps all of those error operands.
|
||||||
|
* Error handling: The new function errors.Join returns an error
|
||||||
|
wrapping a list of errors.
|
||||||
|
* HTTP ResponseController: The new "net/http".ResponseController
|
||||||
|
type provides access to extended per-request functionality not
|
||||||
|
handled by the "net/http".ResponseWriter interface. The
|
||||||
|
ResponseController type provides a clearer, more discoverable
|
||||||
|
way to add per-handler controls. Two such controls also added
|
||||||
|
in Go 1.20 are SetReadDeadline and SetWriteDeadline, which
|
||||||
|
allow setting per-request read and write deadlines.
|
||||||
|
* New ReverseProxy Rewrite hook: The httputil.ReverseProxy
|
||||||
|
forwarding proxy includes a new Rewrite hook function,
|
||||||
|
superseding the previous Director hook.
|
||||||
|
* archive/tar: When the GODEBUG=tarinsecurepath=0 environment
|
||||||
|
variable is set, Reader.Next method will now return the error
|
||||||
|
ErrInsecurePath for an entry with a file name that is an
|
||||||
|
absolute path, refers to a location outside the current
|
||||||
|
directory, contains invalid characters, or (on Windows) is a
|
||||||
|
reserved name such as NUL. A future version of Go may disable
|
||||||
|
insecure paths by default.
|
||||||
|
* archive/zip: When the GODEBUG=zipinsecurepath=0 environment
|
||||||
|
variable is set, NewReader will now return the error
|
||||||
|
ErrInsecurePath when opening an archive which contains any file
|
||||||
|
name that is an absolute path, refers to a location outside the
|
||||||
|
current directory, contains invalid characters, or (on Windows)
|
||||||
|
is a reserved names such as NUL. A future version of Go may
|
||||||
|
disable insecure paths by default.
|
||||||
|
* archive/zip: Reading from a directory file that contains file
|
||||||
|
data will now return an error. The zip specification does not
|
||||||
|
permit directory files to contain file data, so this change
|
||||||
|
only affects reading from invalid archives.
|
||||||
|
* bytes: The new CutPrefix and CutSuffix functions are like
|
||||||
|
TrimPrefix and TrimSuffix but also report whether the string
|
||||||
|
was trimmed.
|
||||||
|
* bytes: The new Clone function allocates a copy of a byte slice.
|
||||||
|
* context: The new WithCancelCause function provides a way to
|
||||||
|
cancel a context with a given error. That error can be
|
||||||
|
retrieved by calling the new Cause function.
|
||||||
|
* crypto/ecdsa: When using supported curves, all operations are
|
||||||
|
now implemented in constant time. This led to an increase in
|
||||||
|
CPU time between 5% and 30%, mostly affecting P-384 and P-521.
|
||||||
|
* crypto/ecdsa: The new PrivateKey.ECDH method converts an
|
||||||
|
ecdsa.PrivateKey to an ecdh.PrivateKey.
|
||||||
|
* crypto/ed25519: The PrivateKey.Sign method and the
|
||||||
|
VerifyWithOptions function now support signing pre-hashed
|
||||||
|
messages with Ed25519ph, indicated by an Options.HashFunc that
|
||||||
|
returns crypto.SHA512. They also now support Ed25519ctx and
|
||||||
|
Ed25519ph with context, indicated by setting the new
|
||||||
|
Options.Context field.
|
||||||
|
* crypto/rsa: The new field OAEPOptions.MGFHash allows
|
||||||
|
configuring the MGF1 hash separately for OAEP decryption.
|
||||||
|
* crypto/rsa: crypto/rsa now uses a new, safer, constant-time
|
||||||
|
backend. This causes a CPU runtime increase for decryption
|
||||||
|
operations between approximately 15% (RSA-2048 on amd64) and
|
||||||
|
45% (RSA-4096 on arm64), and more on 32-bit
|
||||||
|
architectures. Encryption operations are approximately 20x
|
||||||
|
slower than before (but still 5-10x faster than
|
||||||
|
decryption). Performance is expected to improve in future
|
||||||
|
releases. Programs must not modify or manually generate the
|
||||||
|
fields of PrecomputedValues.
|
||||||
|
* crypto/subtle: The new function XORBytes XORs two byte slices
|
||||||
|
together.
|
||||||
|
* crypto/tls: Parsed certificates are now shared across all
|
||||||
|
clients actively using that certificate. The memory savings can
|
||||||
|
be significant in programs that make many concurrent
|
||||||
|
connections to a server or collection of servers sharing any
|
||||||
|
part of their certificate chains.
|
||||||
|
* crypto/tls: For a handshake failure due to a certificate
|
||||||
|
verification failure, the TLS client and server now return an
|
||||||
|
error of the new type CertificateVerificationError, which
|
||||||
|
includes the presented certificates.
|
||||||
|
* crypto/x509: ParsePKCS8PrivateKey and MarshalPKCS8PrivateKey
|
||||||
|
now support keys of type *crypto/ecdh.PrivateKey.
|
||||||
|
ParsePKIXPublicKey and MarshalPKIXPublicKey now support keys of
|
||||||
|
type *crypto/ecdh.PublicKey. Parsing NIST curve keys still
|
||||||
|
returns values of type *ecdsa.PublicKey and *ecdsa.PrivateKey.
|
||||||
|
Use their new ECDH methods to convert to the crypto/ecdh types.
|
||||||
|
* crypto/x509: The new SetFallbackRoots function allows a program
|
||||||
|
to define a set of fallback root certificates in case an
|
||||||
|
operating system verifier or standard platform root bundle is
|
||||||
|
unavailable at runtime. It will most commonly be used with a
|
||||||
|
new package, golang.org/x/crypto/x509roots/fallback, which will
|
||||||
|
provide an up to date root bundle.
|
||||||
|
* debug/elf: Attempts to read from a SHT_NOBITS section using
|
||||||
|
Section.Data or the reader returned by Section.Open now return
|
||||||
|
an error.
|
||||||
|
* debug/elf: Additional R_LARCH_* constants are defined for use
|
||||||
|
with LoongArch systems.
|
||||||
|
* debug/elf: Additional R_PPC64_* constants are defined for use
|
||||||
|
with PPC64 ELFv2 relocations.
|
||||||
|
* debug/elf: The constant value for R_PPC64_SECTOFF_LO_DS is
|
||||||
|
corrected, from 61 to 62.
|
||||||
|
* debug/gosym: Due to a change of Go's symbol naming conventions,
|
||||||
|
tools that process Go binaries should use Go 1.20's debug/gosym
|
||||||
|
package to transparently handle both old and new binaries.
|
||||||
|
* debug/pe: Additional IMAGE_FILE_MACHINE_RISCV* constants are
|
||||||
|
defined for use with RISC-V systems.
|
||||||
|
* encoding/binary: The ReadVarint and ReadUvarint functions will
|
||||||
|
now return io.ErrUnexpectedEOF after reading a partial value,
|
||||||
|
rather than io.EOF.
|
||||||
|
* encoding/xml: The new Encoder.Close method can be used to check
|
||||||
|
for unclosed elements when finished encoding.
|
||||||
|
* encoding/xml: The decoder now rejects element and attribute
|
||||||
|
names with more than one colon, such as <a:b:c>, as well as
|
||||||
|
namespaces that resolve to an empty string, such as xmlns:a="".
|
||||||
|
* encoding/xml: The decoder now rejects elements that use
|
||||||
|
different namespace prefixes in the opening and closing tag,
|
||||||
|
even if those prefixes both denote the same namespace.
|
||||||
|
* errors: The new Join function returns an error wrapping a list
|
||||||
|
of errors.
|
||||||
|
* fmt: The Errorf function supports multiple occurrences of the
|
||||||
|
%w format verb, returning an error that unwraps to the list of
|
||||||
|
all arguments to %w.
|
||||||
|
* fmt: The new FormatString function recovers the formatting
|
||||||
|
directive corresponding to a State, which can be useful in
|
||||||
|
Formatter. implementations.
|
||||||
|
* go/ast: The new RangeStmt.Range field records the position of
|
||||||
|
the range keyword in a range statement.
|
||||||
|
* go/ast: The new File.FileStart and File.FileEnd fields record
|
||||||
|
the position of the start and end of the entire source file.
|
||||||
|
* go/token: The new FileSet.RemoveFile method removes a file from
|
||||||
|
a FileSet. Long-running programs can use this to release memory
|
||||||
|
associated with files they no longer need.
|
||||||
|
* go/types: The new Satisfies function reports whether a type
|
||||||
|
satisfies a constraint. This change aligns with the new
|
||||||
|
language semantics that distinguish satisfying a constraint
|
||||||
|
from implementing an interface.
|
||||||
|
* io: The new OffsetWriter wraps an underlying WriterAt and
|
||||||
|
provides Seek, Write, and WriteAt methods that adjust their
|
||||||
|
effective file offset position by a fixed amount.
|
||||||
|
* io/fs: The new error SkipAll terminates a WalkDir immediately
|
||||||
|
but successfully.
|
||||||
|
* math/big: The math/big package's wide scope and input-dependent
|
||||||
|
timing make it ill-suited for implementing cryptography. The
|
||||||
|
cryptography packages in the standard library no longer call
|
||||||
|
non-trivial Int methods on attacker-controlled inputs. In the
|
||||||
|
future, the determination of whether a bug in math/big is
|
||||||
|
considered a security vulnerability will depend on its wider
|
||||||
|
impact on the standard library.
|
||||||
|
* math/rand: The math/rand package now automatically seeds the
|
||||||
|
global random number generator (used by top-level functions
|
||||||
|
like Float64 and Int) with a random value, and the top-level
|
||||||
|
Seed function has been deprecated. Programs that need a
|
||||||
|
reproducible sequence of random numbers should prefer to
|
||||||
|
allocate their own random source, using
|
||||||
|
rand.New(rand.NewSource(seed)).
|
||||||
|
* math/rand: Programs that need the earlier consistent global
|
||||||
|
seeding behavior can set GODEBUG=randautoseed=0 in their
|
||||||
|
environment.
|
||||||
|
* math/rand: The top-level Read function has been deprecated. In
|
||||||
|
almost all cases, crypto/rand.Read is more appropriate.
|
||||||
|
* mime: The ParseMediaType function now allows duplicate
|
||||||
|
parameter names, so long as the values of the names are the
|
||||||
|
same.
|
||||||
|
* mime/multipart: Methods of the Reader type now wrap errors
|
||||||
|
returned by the underlying io.Reader.
|
||||||
|
* net: The LookupCNAME function now consistently returns the
|
||||||
|
contents of a CNAME record when one exists. Previously on Unix
|
||||||
|
systems and when using the pure Go resolver, LookupCNAME would
|
||||||
|
return an error if a CNAME record referred to a name that with
|
||||||
|
no A, AAAA, or CNAME record. This change modifies LookupCNAME
|
||||||
|
to match the previous behavior on Windows, allowing LookupCNAME
|
||||||
|
to succeed whenever a CNAME exists.
|
||||||
|
* net: Interface.Flags now includes the new flag FlagRunning,
|
||||||
|
indicating an operationally active interface. An interface
|
||||||
|
which is administratively configured but not active (for
|
||||||
|
example, because the network cable is not connected) will have
|
||||||
|
FlagUp set but not FlagRunning.
|
||||||
|
* net: The new Dialer.ControlContext field contains a callback
|
||||||
|
function similar to the existing Dialer.Control hook, that
|
||||||
|
additionally accepts the dial context as a parameter. Control
|
||||||
|
is ignored when ControlContext is not nil.
|
||||||
|
* net: The Go DNS resolver recognizes the trust-ad resolver
|
||||||
|
option. When options trust-ad is set in resolv.conf, the Go
|
||||||
|
resolver will set the AD bit in DNS queries. The resolver does
|
||||||
|
not make use of the AD bit in responses.
|
||||||
|
* net: DNS resolution will detect changes to /etc/nsswitch.conf
|
||||||
|
and reload the file when it changes. Checks are made at most
|
||||||
|
once every five seconds, matching the previous handling of
|
||||||
|
/etc/hosts and /etc/resolv.conf.
|
||||||
|
* net/http: The ResponseWriter.WriteHeader function now supports
|
||||||
|
sending 1xx status codes.
|
||||||
|
* net/http: The new Server.DisableGeneralOptionsHandler
|
||||||
|
configuration setting allows disabling the default OPTIONS *
|
||||||
|
handler.
|
||||||
|
* net/http: The new Transport.OnProxyConnectResponse hook is
|
||||||
|
called when a Transport receives an HTTP response from a proxy
|
||||||
|
for a CONNECT request.
|
||||||
|
* net/http: The HTTP server now accepts HEAD requests containing
|
||||||
|
a body, rather than rejecting them as invalid.
|
||||||
|
* net/http: HTTP/2 stream errors returned by net/http functions
|
||||||
|
may be converted to a golang.org/x/net/http2.StreamError using
|
||||||
|
errors.As.
|
||||||
|
* net/http: Leading and trailing spaces are trimmed from cookie
|
||||||
|
names, rather than being rejected as invalid. For example, a
|
||||||
|
cookie setting of "name =value" is now accepted as setting the
|
||||||
|
cookie "name".
|
||||||
|
* net/netip: The new IPv6LinkLocalAllRouters and IPv6Loopback
|
||||||
|
functions are the net/netip equivalents of net.IPv6loopback and
|
||||||
|
net.IPv6linklocalallrouters.
|
||||||
|
* os: On Windows, the name NUL is no longer treated as a special
|
||||||
|
case in Mkdir and Stat.
|
||||||
|
* os: On Windows, File.Stat now uses the file handle to retrieve
|
||||||
|
attributes when the file is a directory. Previously it would
|
||||||
|
use the path passed to Open, which may no longer be the file
|
||||||
|
represented by the file handle if the file has been moved or
|
||||||
|
replaced. This change modifies Open to open directories without
|
||||||
|
the FILE_SHARE_DELETE access, which match the behavior of
|
||||||
|
regular files.
|
||||||
|
* os: On Windows, File.Seek now supports seeking to the beginning
|
||||||
|
of a directory.
|
||||||
|
* os/exec: The new Cmd fields Cancel and WaitDelay specify the
|
||||||
|
behavior of the Cmd when its associated Context is canceled or
|
||||||
|
its process exits with I/O pipes still held open by a child
|
||||||
|
process.
|
||||||
|
* path/filepath: The new error SkipAll terminates a Walk
|
||||||
|
immediately but successfully.
|
||||||
|
* path/filepath: The new IsLocal function reports whether a path
|
||||||
|
is lexically local to a directory. For example, if IsLocal(p)
|
||||||
|
is true, then Open(p) will refer to a file that is lexically
|
||||||
|
within the subtree rooted at the current directory.
|
||||||
|
* reflect: The new Value.Comparable and Value.Equal methods can
|
||||||
|
be used to compare two Values for equality. Comparable reports
|
||||||
|
whether Equal is a valid operation for a given Value receiver.
|
||||||
|
* reflect: The new Value.Grow method extends a slice to guarantee
|
||||||
|
space for another n elements.
|
||||||
|
* reflect: The new Value.SetZero method sets a value to be the
|
||||||
|
zero value for its type.
|
||||||
|
* reflect: Go 1.18 introduced Value.SetIterKey and
|
||||||
|
Value.SetIterValue methods. These are optimizations:
|
||||||
|
v.SetIterKey(it) is meant to be equivalent to
|
||||||
|
v.Set(it.Key()). The implementations incorrectly omitted a
|
||||||
|
check for use of unexported fields that was present in the
|
||||||
|
unoptimized forms. Go 1.20 corrects these methods to include
|
||||||
|
the unexported field check.
|
||||||
|
* regexp: Go 1.19.2 and Go 1.18.7 included a security fix to the
|
||||||
|
regular expression parser, making it reject very large
|
||||||
|
expressions that would consume too much memory. Because Go
|
||||||
|
patch releases do not introduce new API, the parser returned
|
||||||
|
syntax.ErrInternalError in this case. Go 1.20 adds a more
|
||||||
|
specific error, syntax.ErrLarge, which the parser now returns
|
||||||
|
instead.
|
||||||
|
* runtime/cgo: Go 1.20 adds new Incomplete marker type. Code
|
||||||
|
generated by cgo will use cgo.Incomplete to mark an incomplete
|
||||||
|
C type.
|
||||||
|
* runtime/metrics: Go 1.20 adds new supported metrics, including
|
||||||
|
the current GOMAXPROCS setting (/sched/gomaxprocs:threads), the
|
||||||
|
number of cgo calls executed (/cgo/go-to-c-calls:calls), total
|
||||||
|
mutex block time (/sync/mutex/wait/total:seconds), and various
|
||||||
|
measures of time spent in garbage collection.
|
||||||
|
* runtime/metrics: Time-based histogram metrics are now less
|
||||||
|
precise, but take up much less memory.
|
||||||
|
* runtime/pprof: Mutex profile samples are now pre-scaled, fixing
|
||||||
|
an issue where old mutex profile samples would be scaled
|
||||||
|
incorrectly if the sampling rate changed during execution.
|
||||||
|
* runtime/pprof: Profiles collected on Windows now include memory
|
||||||
|
mapping information that fixes symbolization issues for
|
||||||
|
position-independent binaries.
|
||||||
|
* runtime/trace: The garbage collector's background sweeper now
|
||||||
|
yields less frequently, resulting in many fewer extraneous
|
||||||
|
events in execution traces.
|
||||||
|
* strings: The new CutPrefix and CutSuffix functions are like
|
||||||
|
TrimPrefix and TrimSuffix but also report whether the string
|
||||||
|
was trimmed.
|
||||||
|
* sync: The new Map methods Swap, CompareAndSwap, and
|
||||||
|
CompareAndDelete allow existing map entries to be updated
|
||||||
|
atomically.
|
||||||
|
* syscall: On FreeBSD, compatibility shims needed for FreeBSD 11
|
||||||
|
and earlier have been removed.
|
||||||
|
* syscall: On Linux, additional CLONE_* constants are defined for
|
||||||
|
use with the SysProcAttr.Cloneflags field.
|
||||||
|
* syscall: On Linux, the new SysProcAttr.CgroupFD and
|
||||||
|
SysProcAttr.UseCgroupFD fields provide a way to place a child
|
||||||
|
process into a specific cgroup.
|
||||||
|
* testing: The new method B.Elapsed reports the current elapsed
|
||||||
|
time of the benchmark, which may be useful for calculating
|
||||||
|
rates to report with ReportMetric.
|
||||||
|
* time: The new time layout constants DateTime, DateOnly, and
|
||||||
|
TimeOnly provide names for three of the most common layout
|
||||||
|
strings used in a survey of public Go source code.
|
||||||
|
* time: The new Time.Compare method compares two times.
|
||||||
|
* time: Parse now ignores sub-nanosecond precision in its input,
|
||||||
|
instead of reporting those digits as an error.
|
||||||
|
* time: The Time.MarshalJSON method is now more strict about
|
||||||
|
adherence to RFC 3339.
|
||||||
|
* unicode/utf16: The new AppendRune function appends the UTF-16
|
||||||
|
encoding of a given rune to a uint16 slice, analogous to
|
||||||
|
utf8.AppendRune.
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Thu Jan 12 18:02:43 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
- go1.20rc3 (released 2023-01-12) is a release candidate version of
|
||||||
|
go1.20 cut from the master branch at the revision tagged
|
||||||
|
go1.20rc3.
|
||||||
|
Refs boo#1206346 go1.20 release tracking
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Wed Jan 4 18:16:56 UTC 2023 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
- go1.20rc2 (released 2023-01-04) is a release candidate version of
|
||||||
|
go1.20 cut from the master branch at the revision tagged
|
||||||
|
go1.20rc2.
|
||||||
|
Refs boo#1206346 go1.20 release tracking
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Thu Dec 8 17:00:19 UTC 2022 - Jeff Kowalczyk <jkowalczyk@suse.com>
|
||||||
|
|
||||||
|
- go1.20rc1 (released 2022-12-08) is a release candidate version of
|
||||||
|
go1.20 cut from the master branch at the revision tagged
|
||||||
|
go1.20rc1.
|
||||||
|
Refs boo#1206346 go1.20 release tracking
|
479
go1.20.spec
Normal file
479
go1.20.spec
Normal file
@ -0,0 +1,479 @@
|
|||||||
|
#
|
||||||
|
# spec file for package go1.20
|
||||||
|
#
|
||||||
|
# Copyright (c) 2024 SUSE LLC
|
||||||
|
#
|
||||||
|
# All modifications and additions to the file contributed by third parties
|
||||||
|
# remain the property of their copyright owners, unless otherwise agreed
|
||||||
|
# upon. The license for this file, and modifications and additions to the
|
||||||
|
# file, is the same license as for the pristine package itself (unless the
|
||||||
|
# license for the pristine package is not an Open Source License, in which
|
||||||
|
# case the license is the MIT License). An "Open Source License" is a
|
||||||
|
# license that conforms to the Open Source Definition (Version 1.9)
|
||||||
|
# published by the Open Source Initiative.
|
||||||
|
|
||||||
|
# Please submit bugfixes or comments via https://bugs.opensuse.org/
|
||||||
|
#
|
||||||
|
|
||||||
|
|
||||||
|
# Specify Go toolchain version used to bootstrap this package's Go toolchain
|
||||||
|
# go_bootstrap_version bootstrap go toolchain with specific existing go1.x package
|
||||||
|
# gcc_go_version bootstrap go toolchain with specific version of gcc-go
|
||||||
|
%if 0%{?suse_version} > 1500
|
||||||
|
# openSUSE Tumbleweed
|
||||||
|
# Usually ahead of bootstrap version specified by upstream Go
|
||||||
|
# Use Tumbleweed default gccgo and N-1 go1.x for testing
|
||||||
|
%define gcc_go_version 13
|
||||||
|
%define go_bootstrap_version go1.18
|
||||||
|
%else
|
||||||
|
# Use gccgo and go1.x specified by upstream Go
|
||||||
|
%define gcc_go_version 11
|
||||||
|
%define go_bootstrap_version go1.17
|
||||||
|
%endif
|
||||||
|
|
||||||
|
# Bootstrap go toolchain using existing go package go_bootstrap_version
|
||||||
|
# To bootstrap using gccgo use '--with gccgo'
|
||||||
|
%bcond_with gccgo
|
||||||
|
|
||||||
|
# gccgo on ppc64le with default PIE enabled fails with:
|
||||||
|
# error while loading shared libraries:
|
||||||
|
# R_PPC64_ADDR16_HA re10143fb0c for symbol `' out of range
|
||||||
|
# track https://github.com/golang/go/issues/28531
|
||||||
|
# linuxppc-dev discussion:
|
||||||
|
# "PIE binaries are no longer mapped below 4 GiB on ppc64le"
|
||||||
|
# https://lists.ozlabs.org/pipermail/linuxppc-dev/2018-November/180862.html
|
||||||
|
%ifarch ppc64le
|
||||||
|
#!BuildIgnore: gcc-PIE
|
||||||
|
%endif
|
||||||
|
|
||||||
|
# Build go-race only on platforms where C++14 is supported (SLE-15)
|
||||||
|
%if 0%{?suse_version} >= 1500 || 0%{?sle_version} >= 150000
|
||||||
|
%define tsan_arch x86_64 aarch64 s390x ppc64le
|
||||||
|
%else
|
||||||
|
# Cannot use {nil} here (ifarch doesn't like it) so just make up a fake
|
||||||
|
# architecture that no build will ever match.
|
||||||
|
%define tsan_arch openSUSE_FAKE_ARCH
|
||||||
|
%endif
|
||||||
|
|
||||||
|
# Go has precompiled versions of LLVM's compiler-rt inside their source code.
|
||||||
|
# We cannot ship pre-compiled binaries so we have to recompile said source,
|
||||||
|
# however they vendor specific commits from upstream. This value comes from
|
||||||
|
# src/runtime/race/README (and we verify that it matches in check).
|
||||||
|
#
|
||||||
|
# In order to update the TSAN version, modify _service. See boo#1052528 for
|
||||||
|
# more details.
|
||||||
|
%ifarch x86_64 %{?x86_64}
|
||||||
|
%define tsan_commit 74c2d4f6024c8f160871a2baa928d0b42415f183
|
||||||
|
%else
|
||||||
|
%define tsan_commit 41cb504b7c4b18ac15830107431a0c1eec73a6b2
|
||||||
|
%endif
|
||||||
|
|
||||||
|
# go_api is the major version of Go.
|
||||||
|
# Used by go1.x packages and go metapackage for:
|
||||||
|
# RPM Provides: golang(API), RPM Requires: and rpm_vercmp
|
||||||
|
# as well as derived variables such as go_label.
|
||||||
|
%define go_api 1.20
|
||||||
|
|
||||||
|
# go_label is the configurable Go toolchain directory name.
|
||||||
|
# Used for packaging multiple Go toolchains with the same go_api.
|
||||||
|
# go_label should be defined as go_api with optional suffix, e.g.
|
||||||
|
# go_api or go_api-foo
|
||||||
|
%define go_label %{go_api}
|
||||||
|
|
||||||
|
# shared library support
|
||||||
|
%if "%{rpm_vercmp %{go_api} 1.5}" > "0"
|
||||||
|
%if %{with gccgo}
|
||||||
|
%define with_shared 1
|
||||||
|
%else
|
||||||
|
%ifarch %ix86 %arm x86_64 aarch64
|
||||||
|
%define with_shared 1
|
||||||
|
%else
|
||||||
|
%define with_shared 0
|
||||||
|
%endif
|
||||||
|
%endif
|
||||||
|
%else
|
||||||
|
%define with_shared 0
|
||||||
|
%endif
|
||||||
|
%ifarch ppc64
|
||||||
|
%define with_shared 0
|
||||||
|
%endif
|
||||||
|
# setup go_arch (BSD-like scheme)
|
||||||
|
%ifarch %ix86
|
||||||
|
%define go_arch 386
|
||||||
|
%endif
|
||||||
|
%ifarch x86_64
|
||||||
|
%define go_arch amd64
|
||||||
|
# set GOAMD64 consistently
|
||||||
|
%define go_amd64 v1
|
||||||
|
%endif
|
||||||
|
%ifarch aarch64
|
||||||
|
%define go_arch arm64
|
||||||
|
%endif
|
||||||
|
%ifarch %arm
|
||||||
|
%define go_arch arm
|
||||||
|
%endif
|
||||||
|
%ifarch ppc64
|
||||||
|
%define go_arch ppc64
|
||||||
|
%endif
|
||||||
|
%ifarch ppc64le
|
||||||
|
%define go_arch ppc64le
|
||||||
|
%endif
|
||||||
|
%ifarch s390x
|
||||||
|
%define go_arch s390x
|
||||||
|
%endif
|
||||||
|
%ifarch riscv64
|
||||||
|
%define go_arch riscv64
|
||||||
|
%endif
|
||||||
|
|
||||||
|
Name: go1.20
|
||||||
|
Version: 1.20.14
|
||||||
|
Release: 0
|
||||||
|
Summary: A compiled, garbage-collected, concurrent programming language
|
||||||
|
License: BSD-3-Clause
|
||||||
|
Group: Development/Languages/Go
|
||||||
|
URL: https://go.dev/
|
||||||
|
Source: https://go.dev/dl/go%{version}.src.tar.gz
|
||||||
|
Source1: go-rpmlintrc
|
||||||
|
Source4: README.SUSE
|
||||||
|
Source6: go.gdbinit
|
||||||
|
# We have to compile TSAN ourselves. boo#1052528
|
||||||
|
# Preferred form when all arches share llvm race version
|
||||||
|
# Source100: llvm-%{tsan_commit}.tar.xz
|
||||||
|
Source100: llvm-74c2d4f6024c8f160871a2baa928d0b42415f183.tar.xz
|
||||||
|
Source101: llvm-41cb504b7c4b18ac15830107431a0c1eec73a6b2.tar.xz
|
||||||
|
# PATCH-FIX-OPENSUSE: https://go-review.googlesource.com/c/go/+/391115
|
||||||
|
Patch7: dont-force-gold-on-arm64.patch
|
||||||
|
# PATCH-FIX-UPSTREAM marguerite@opensuse.org - find /usr/bin/go-8 when bootstrapping with gcc8-go
|
||||||
|
Patch8: gcc-go.patch
|
||||||
|
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
||||||
|
# boostrap
|
||||||
|
%if %{with gccgo}
|
||||||
|
BuildRequires: gcc%{gcc_go_version}-go
|
||||||
|
%else
|
||||||
|
# no gcc-go
|
||||||
|
BuildRequires: %{go_bootstrap_version}
|
||||||
|
%endif
|
||||||
|
BuildRequires: fdupes
|
||||||
|
Suggests: %{name}-doc = %{version}
|
||||||
|
%if 0%{?suse_version} > 1500
|
||||||
|
# openSUSE Tumbleweed
|
||||||
|
Suggests: %{name}-libstd = %{version}
|
||||||
|
%endif
|
||||||
|
%ifarch %{tsan_arch}
|
||||||
|
# Needed to compile compiler-rt/TSAN.
|
||||||
|
BuildRequires: gcc-c++
|
||||||
|
%endif
|
||||||
|
#BNC#818502 debug edit tool of rpm fails on i586 builds
|
||||||
|
BuildRequires: rpm >= 4.11.1
|
||||||
|
Requires(post): update-alternatives
|
||||||
|
Requires(postun): update-alternatives
|
||||||
|
Requires: gcc
|
||||||
|
Provides: go = %{version}
|
||||||
|
Provides: go-devel = go%{version}
|
||||||
|
Provides: go-devel-static = go%{version}
|
||||||
|
Provides: golang(API) = %{go_api}
|
||||||
|
Obsoletes: go-devel < go%{version}
|
||||||
|
# go-vim/emacs were separate projects starting from 1.4
|
||||||
|
Obsoletes: go-emacs <= 1.3.3
|
||||||
|
Obsoletes: go-vim <= 1.3.3
|
||||||
|
ExclusiveArch: %ix86 x86_64 %arm aarch64 ppc64 ppc64le s390x riscv64
|
||||||
|
|
||||||
|
%description
|
||||||
|
Go is an expressive, concurrent, garbage collected systems programming language
|
||||||
|
that is type safe and memory safe. It has pointers but no pointer arithmetic.
|
||||||
|
Go has fast builds, clean syntax, garbage collection, methods for any type, and
|
||||||
|
run-time reflection. It feels like a dynamic language but has the speed and
|
||||||
|
safety of a static language.
|
||||||
|
|
||||||
|
%package doc
|
||||||
|
Summary: Go documentation
|
||||||
|
Group: Documentation/Other
|
||||||
|
Provides: go-doc = %{version}
|
||||||
|
|
||||||
|
%description doc
|
||||||
|
Go examples and documentation.
|
||||||
|
|
||||||
|
%ifarch %{tsan_arch}
|
||||||
|
# boo#1052528
|
||||||
|
%package race
|
||||||
|
Summary: Go runtime race detector
|
||||||
|
Group: Development/Languages/Go
|
||||||
|
URL: https://compiler-rt.llvm.org/
|
||||||
|
Requires: %{name} = %{version}
|
||||||
|
Supplements: %{name} = %{version}
|
||||||
|
ExclusiveArch: %{tsan_arch}
|
||||||
|
|
||||||
|
%description race
|
||||||
|
Go runtime race detector libraries. Install this package if you wish to use the
|
||||||
|
-race option, in order to detect race conditions present in your Go programs.
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%if %{with_shared}
|
||||||
|
%if 0%{?suse_version} > 1500
|
||||||
|
# openSUSE Tumbleweed
|
||||||
|
%package libstd
|
||||||
|
Summary: Go compiled shared library libstd.so
|
||||||
|
Group: Development/Languages/Go
|
||||||
|
Provides: go-libstd = %{version}
|
||||||
|
|
||||||
|
%description libstd
|
||||||
|
Go standard library compiled to a dynamically loadable shared object libstd.so
|
||||||
|
%endif
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%prep
|
||||||
|
%ifarch %{tsan_arch}
|
||||||
|
# compiler-rt (from LLVM)
|
||||||
|
%ifarch x86_64
|
||||||
|
%setup -q -T -b 100 -n llvm-%{tsan_commit}
|
||||||
|
%else
|
||||||
|
%setup -q -T -b 101 -n llvm-%{tsan_commit}
|
||||||
|
%endif
|
||||||
|
%endif
|
||||||
|
|
||||||
|
# go
|
||||||
|
%setup -q -n go
|
||||||
|
%patch7 -p1
|
||||||
|
%if %{with gccgo}
|
||||||
|
# Currently gcc-go does not manage an update-alternatives entry and will
|
||||||
|
# never be symlinked as "go", even if gcc-go is the only installed go toolchain.
|
||||||
|
# Patch go bootstrap scripts to find hardcoded go-(gcc-go-version) e.g. go-8
|
||||||
|
# Substitute defined gcc_go_version into gcc-go.patch
|
||||||
|
sed -i "s/\$gcc_go_version/%{gcc_go_version}/" $RPM_SOURCE_DIR/gcc-go.patch
|
||||||
|
%patch8 -p1
|
||||||
|
%endif
|
||||||
|
|
||||||
|
cp %{SOURCE4} .
|
||||||
|
|
||||||
|
%build
|
||||||
|
# Remove the pre-included .sysos, to avoid shipping things we didn't compile
|
||||||
|
# (which is against the openSUSE guidelines for packaging).
|
||||||
|
find . -type f -name '*.syso' -print -delete
|
||||||
|
|
||||||
|
# First, compile LLVM's TSAN, and replace the built-in with it. We can only do
|
||||||
|
# this for amd64.
|
||||||
|
%ifarch %{tsan_arch}
|
||||||
|
TSAN_DIR="../llvm-%{tsan_commit}/compiler-rt/lib/tsan/go"
|
||||||
|
pushd "$TSAN_DIR"
|
||||||
|
./buildgo.sh
|
||||||
|
popd
|
||||||
|
cp -v "$TSAN_DIR/race_linux_%{go_arch}.syso" src/runtime/race/
|
||||||
|
%endif
|
||||||
|
|
||||||
|
# Now, compile Go.
|
||||||
|
%if %{with gccgo}
|
||||||
|
export GOROOT_BOOTSTRAP=%{_prefix}
|
||||||
|
%else
|
||||||
|
export GOROOT_BOOTSTRAP=%{_libdir}/%{go_bootstrap_version}
|
||||||
|
%endif
|
||||||
|
# Ensure ARM arch is set properly - boo#1169832
|
||||||
|
%ifarch armv6l armv6hl
|
||||||
|
export GOARCH=arm
|
||||||
|
export GOARM=6
|
||||||
|
%endif
|
||||||
|
%ifarch armv7l armv7hl
|
||||||
|
export GOARCH=arm
|
||||||
|
export GOARM=7
|
||||||
|
%endif
|
||||||
|
%ifarch x86_64 %{?x86_64}
|
||||||
|
# use the baseline defined above. Other option is GOAMD64=v3 for x86_64_v3 support
|
||||||
|
export GOAMD64=%go_amd64
|
||||||
|
%endif
|
||||||
|
export GOROOT="`pwd`"
|
||||||
|
export GOROOT_FINAL=%{_libdir}/go/%{go_label}
|
||||||
|
export GOBIN="$GOROOT/bin"
|
||||||
|
mkdir -p "$GOBIN"
|
||||||
|
cd src
|
||||||
|
HOST_EXTRA_CFLAGS="%{optflags} -Wno-error" ./make.bash -v
|
||||||
|
|
||||||
|
cd ../
|
||||||
|
%ifarch %{tsan_arch}
|
||||||
|
# Install TSAN-friendly version of the std libraries.
|
||||||
|
bin/go install -race std
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%if %{with_shared}
|
||||||
|
%if 0%{?suse_version} > 1500
|
||||||
|
# openSUSE Tumbleweed
|
||||||
|
# Compile Go standard library as a dynamically loaded shared object libstd.so
|
||||||
|
# for inclusion in a subpackage which can be installed standalone.
|
||||||
|
# Upstream Go binary releases do not ship a compiled libstd.so.
|
||||||
|
# Standard practice is to build Go binaries as a single executable.
|
||||||
|
# Upstream Go discussed removing this feature, opted to fix current support:
|
||||||
|
# Relevant upstream comments on: https://github.com/golang/go/issues/47788
|
||||||
|
#
|
||||||
|
# -buildmode=shared
|
||||||
|
# Combine all the listed non-main packages into a single shared
|
||||||
|
# library that will be used when building with the -linkshared
|
||||||
|
# option. Packages named main are ignored.
|
||||||
|
#
|
||||||
|
# -linkshared
|
||||||
|
# build code that will be linked against shared libraries previously
|
||||||
|
# created with -buildmode=shared.
|
||||||
|
bin/go install -buildmode=shared std
|
||||||
|
%endif
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%check
|
||||||
|
%ifarch %{tsan_arch}
|
||||||
|
# Make sure that we have the right TSAN checked out.
|
||||||
|
# As of go1.20, README x86_64 race_linux.syso
|
||||||
|
# includes path prefix and omits arch in filename e.g.
|
||||||
|
# internal/amd64v1/race_linux.syso
|
||||||
|
%ifarch x86_64 %{?x86_64}
|
||||||
|
grep "^internal/amd64%{go_amd64}/race_linux.syso built with LLVM %{tsan_commit}" src/runtime/race/README
|
||||||
|
%else
|
||||||
|
grep "^race_linux_%{go_arch}.syso built with LLVM %{tsan_commit}" src/runtime/race/README
|
||||||
|
%endif
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%install
|
||||||
|
export GOROOT="%{buildroot}%{_libdir}/go/%{go_label}"
|
||||||
|
|
||||||
|
# remove pre-compiled .a package archives no longer used as of go1.20
|
||||||
|
# find %{_builddir}/go/pkg -name "*.a" -type f |wc -l
|
||||||
|
# 259
|
||||||
|
# TODO isolate the build step where .a files are created and delete then
|
||||||
|
find %{_builddir}/go/pkg -name "*.a" -type f -delete
|
||||||
|
|
||||||
|
# locations for third party libraries, see README-openSUSE for info about locations.
|
||||||
|
install -d %{buildroot}%{_datadir}/go/%{go_label}/contrib
|
||||||
|
install -d $GOROOT/contrib/pkg/linux_%{go_arch}
|
||||||
|
ln -s %{_libdir}/go/%{go_label}/contrib/pkg/ %{buildroot}%{_datadir}/go/%{go_label}/contrib/pkg
|
||||||
|
install -d %{buildroot}%{_datadir}/go/%{go_label}/contrib/cmd
|
||||||
|
install -d %{buildroot}%{_datadir}/go/%{go_label}/contrib/src
|
||||||
|
ln -s %{_datadir}/go/%{go_label}/contrib/src/ %{buildroot}%{_libdir}/go/%{go_label}/contrib/src
|
||||||
|
install -Dm644 README.SUSE $GOROOT/contrib/
|
||||||
|
ln -s %{_libdir}/go/%{go_label}/contrib/README.SUSE %{buildroot}%{_datadir}/go/%{go_label}/contrib/README.SUSE
|
||||||
|
|
||||||
|
# source files for go install, godoc, etc
|
||||||
|
install -d %{buildroot}%{_datadir}/go/%{go_label}
|
||||||
|
for ext in *.{go,c,h,s,S,py,syso,bin}; do
|
||||||
|
find src -name ${ext} -exec install -Dm644 \{\} %{buildroot}%{_datadir}/go/%{go_label}/\{\} \;
|
||||||
|
done
|
||||||
|
# executable bash scripts called by go tool, etc
|
||||||
|
find src -name "*.bash" -exec install -Dm655 \{\} %{buildroot}%{_datadir}/go/%{go_label}/\{\} \;
|
||||||
|
# Trace viewer html and javascript files moved from misc/trace in
|
||||||
|
# previous versions to src/cmd/trace/static in go1.19.
|
||||||
|
# static contains pprof trace viewer html javascript and markdown
|
||||||
|
install -d %{buildroot}%{_datadir}/go/%{go_label}/src/cmd/trace/static
|
||||||
|
install -Dm644 src/cmd/trace/static/* %{buildroot}%{_datadir}/go/%{go_label}/src/cmd/trace/static
|
||||||
|
# pprof viewer html templates are needed for import runtime/pprof
|
||||||
|
install -d %{buildroot}%{_datadir}/go/%{go_label}/src/cmd/vendor/github.com/google/pprof/internal/driver/html
|
||||||
|
install -Dm644 src/cmd/vendor/github.com/google/pprof/internal/driver/html/* %{buildroot}%{_datadir}/go/%{go_label}/src/cmd/vendor/github.com/google/pprof/internal/driver/html
|
||||||
|
|
||||||
|
mkdir -p $GOROOT/src
|
||||||
|
for i in $(ls %{buildroot}/usr/share/go/%{go_label}/src);do
|
||||||
|
ln -s /usr/share/go/%{go_label}/src/$i $GOROOT/src/$i
|
||||||
|
done
|
||||||
|
# add lib files that are needed (such as the timezone database).
|
||||||
|
install -d $GOROOT/lib
|
||||||
|
find lib -type f -exec install -D -m644 {} $GOROOT/{} \;
|
||||||
|
|
||||||
|
# copy document templates, packages, obj libs and command utilities
|
||||||
|
mkdir -p $GOROOT/bin
|
||||||
|
# remove bootstrap
|
||||||
|
rm -rf pkg/bootstrap
|
||||||
|
mv pkg $GOROOT
|
||||||
|
mv bin/* $GOROOT/bin
|
||||||
|
# add wasm (Web Assembly) boo#1139210
|
||||||
|
mkdir -p $GOROOT/misc/wasm
|
||||||
|
mv misc/wasm/* $GOROOT/misc/wasm
|
||||||
|
rm -f %{buildroot}%{_bindir}/{hgpatch,quietgcc}
|
||||||
|
|
||||||
|
# gdbinit
|
||||||
|
install -Dm644 %{SOURCE6} $GOROOT/bin/gdbinit.d/go.gdb
|
||||||
|
%if "%{_lib}" == "lib64"
|
||||||
|
sed -i "s/lib/lib64/" $GOROOT/bin/gdbinit.d/go.gdb
|
||||||
|
sed -i "s/\$go_label/%{go_label}/" $GOROOT/bin/gdbinit.d/go.gdb
|
||||||
|
%endif
|
||||||
|
|
||||||
|
# update-alternatives
|
||||||
|
mkdir -p %{buildroot}%{_sysconfdir}/alternatives
|
||||||
|
mkdir -p %{buildroot}%{_bindir}
|
||||||
|
mkdir -p %{buildroot}%{_sysconfdir}/profile.d
|
||||||
|
mkdir -p %{buildroot}%{_sysconfdir}/gdbinit.d
|
||||||
|
touch %{buildroot}%{_sysconfdir}/alternatives/{go,gofmt,go.gdb}
|
||||||
|
ln -sf %{_sysconfdir}/alternatives/go %{buildroot}%{_bindir}/go
|
||||||
|
ln -sf %{_sysconfdir}/alternatives/gofmt %{buildroot}%{_bindir}/gofmt
|
||||||
|
ln -sf %{_sysconfdir}/alternatives/go.gdb %{buildroot}%{_sysconfdir}/gdbinit.d/go.gdb
|
||||||
|
|
||||||
|
# documentation and examples
|
||||||
|
# fix documetation permissions (rpmlint warning)
|
||||||
|
find doc/ misc/ -type f -exec chmod 0644 '{}' +
|
||||||
|
# remove unwanted arch-dependant binaries (rpmlint warning)
|
||||||
|
rm -rf misc/cgo/test/{_*,*.o,*.out,*.6,*.8}
|
||||||
|
# prepare go-doc
|
||||||
|
mkdir -p %{buildroot}%{_docdir}/go/%{go_label}
|
||||||
|
cp -r CONTRIBUTING.md LICENSE PATENTS README.md README.SUSE %{buildroot}%{_docdir}/go/%{go_label}
|
||||||
|
cp -r doc/* %{buildroot}%{_docdir}/go/%{go_label}
|
||||||
|
|
||||||
|
%fdupes -s %{buildroot}%{_prefix}
|
||||||
|
|
||||||
|
%post
|
||||||
|
|
||||||
|
update-alternatives \
|
||||||
|
--install %{_bindir}/go go %{_libdir}/go/%{go_label}/bin/go $((20+$(echo %{go_label} | cut -d. -f2))) \
|
||||||
|
--slave %{_bindir}/gofmt gofmt %{_libdir}/go/%{go_label}/bin/gofmt \
|
||||||
|
--slave %{_sysconfdir}/gdbinit.d/go.gdb go.gdb %{_libdir}/go/%{go_label}/bin/gdbinit.d/go.gdb
|
||||||
|
|
||||||
|
%postun
|
||||||
|
if [ $1 -eq 0 ] ; then
|
||||||
|
update-alternatives --remove go %{_libdir}/go/%{go_label}/bin/go
|
||||||
|
fi
|
||||||
|
|
||||||
|
%files
|
||||||
|
%{_bindir}/go
|
||||||
|
%{_bindir}/gofmt
|
||||||
|
%dir %{_libdir}/go
|
||||||
|
%{_libdir}/go/%{go_label}
|
||||||
|
%dir %{_datadir}/go
|
||||||
|
%{_datadir}/go/%{go_label}
|
||||||
|
%dir %{_sysconfdir}/gdbinit.d/
|
||||||
|
%config %{_sysconfdir}/gdbinit.d/go.gdb
|
||||||
|
%ghost %{_sysconfdir}/alternatives/go
|
||||||
|
%ghost %{_sysconfdir}/alternatives/gofmt
|
||||||
|
%ghost %{_sysconfdir}/alternatives/go.gdb
|
||||||
|
%dir %{_docdir}/go
|
||||||
|
%dir %{_docdir}/go/%{go_label}
|
||||||
|
%doc %{_docdir}/go/%{go_label}/CONTRIBUTING.md
|
||||||
|
%doc %{_docdir}/go/%{go_label}/PATENTS
|
||||||
|
%doc %{_docdir}/go/%{go_label}/README.md
|
||||||
|
%doc %{_docdir}/go/%{go_label}/README.SUSE
|
||||||
|
%if 0%{?suse_version} < 1500
|
||||||
|
%doc %{_docdir}/go/%{go_label}/LICENSE
|
||||||
|
%else
|
||||||
|
%license %{_docdir}/go/%{go_label}/LICENSE
|
||||||
|
%endif
|
||||||
|
|
||||||
|
# We don't include TSAN in the main Go package.
|
||||||
|
%ifarch %{tsan_arch}
|
||||||
|
%exclude %{_datadir}/go/%{go_label}/src/runtime/race/race_linux_%{go_arch}.syso
|
||||||
|
%endif
|
||||||
|
|
||||||
|
# We don't include libstd.so in the main Go package.
|
||||||
|
%if %{with_shared}
|
||||||
|
%if 0%{?suse_version} > 1500
|
||||||
|
# openSUSE Tumbleweed
|
||||||
|
# ./go/1.20/pkg/linux_amd64_dynlink/libstd.so
|
||||||
|
%exclude %{_libdir}/go/%{go_label}/pkg/linux_%{go_arch}_dynlink/libstd.so
|
||||||
|
%endif
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%files doc
|
||||||
|
%doc %{_docdir}/go/%{go_label}/*.html
|
||||||
|
|
||||||
|
%ifarch %{tsan_arch}
|
||||||
|
%files race
|
||||||
|
%{_datadir}/go/%{go_label}/src/runtime/race/race_linux_%{go_arch}.syso
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%if %{with_shared}
|
||||||
|
%if 0%{?suse_version} > 1500
|
||||||
|
# openSUSE Tumbleweed
|
||||||
|
%files libstd
|
||||||
|
%{_libdir}/go/%{go_label}/pkg/linux_%{go_arch}_dynlink/libstd.so
|
||||||
|
%endif
|
||||||
|
%endif
|
||||||
|
|
||||||
|
%changelog
|
BIN
llvm-41cb504b7c4b18ac15830107431a0c1eec73a6b2.tar.xz
(Stored with Git LFS)
Normal file
BIN
llvm-41cb504b7c4b18ac15830107431a0c1eec73a6b2.tar.xz
(Stored with Git LFS)
Normal file
Binary file not shown.
BIN
llvm-74c2d4f6024c8f160871a2baa928d0b42415f183.tar.xz
(Stored with Git LFS)
Normal file
BIN
llvm-74c2d4f6024c8f160871a2baa928d0b42415f183.tar.xz
(Stored with Git LFS)
Normal file
Binary file not shown.
Loading…
Reference in New Issue
Block a user