From: Michael Anthony Knyszek Date: Thu, 1 Apr 2021 15:02:11 +0000 (+0000) Subject: reflect,runtime: assume register ABI with GOEXPERIMENT=regabiargs X-Git-Tag: go1.17beta1~890 X-Git-Url: http://www.git.cypherpunks.su/?a=commitdiff_plain;h=27d306281c54a89ff00e3dad6f4cea790a2f2f2d;p=gostls13.git reflect,runtime: assume register ABI with GOEXPERIMENT=regabiargs This change causes finalizers, reflect calls, and Windows syscall callbacks to assume the register ABI when GOEXPERIMENT=regabiargs is set. That is, when all Go functions are using the new ABI by default, these features should assume the new ABI too. For #40724. Change-Id: Ie4ee66b8085b692e1ff675f01134c9a4703ae1b9 Reviewed-on: https://go-review.googlesource.com/c/go/+/306571 Trust: Michael Knyszek Run-TryBot: Michael Knyszek Reviewed-by: Austin Clements Reviewed-by: Cherry Zhang Reviewed-by: Than McIntosh TryBot-Result: Go Bot --- diff --git a/src/reflect/abi.go b/src/reflect/abi.go index 002e4598b9..ab19695edc 100644 --- a/src/reflect/abi.go +++ b/src/reflect/abi.go @@ -28,9 +28,9 @@ import ( // commented out there should be the actual values once // we're ready to use the register ABI everywhere. var ( - intArgRegs = 0 // abi.IntArgRegs - floatArgRegs = 0 // abi.FloatArgRegs - floatRegSize = uintptr(0) // uintptr(abi.EffectiveFloatRegSize) + intArgRegs = abi.IntArgRegs * experimentRegabiArgs + floatArgRegs = abi.FloatArgRegs * experimentRegabiArgs + floatRegSize = uintptr(abi.EffectiveFloatRegSize * experimentRegabiArgs) ) // abiStep represents an ABI "instruction." Each instruction diff --git a/src/reflect/regabiargs_off.go b/src/reflect/regabiargs_off.go new file mode 100644 index 0000000000..655e955474 --- /dev/null +++ b/src/reflect/regabiargs_off.go @@ -0,0 +1,10 @@ +// Copyright 2021 The Go Authors. All rights reserved. +// Use of this source code is governed by a BSD-style +// license that can be found in the LICENSE file. + +//go:build !goexperiment.regabiargs +// +build !goexperiment.regabiargs + +package reflect + +const experimentRegabiArgs = 0 diff --git a/src/reflect/regabiargs_on.go b/src/reflect/regabiargs_on.go new file mode 100644 index 0000000000..0f33b22ff9 --- /dev/null +++ b/src/reflect/regabiargs_on.go @@ -0,0 +1,10 @@ +// Copyright 2021 The Go Authors. All rights reserved. +// Use of this source code is governed by a BSD-style +// license that can be found in the LICENSE file. + +//go:build goexperiment.regabiargs +// +build goexperiment.regabiargs + +package reflect + +const experimentRegabiArgs = 1 diff --git a/src/runtime/regabiargs_off.go b/src/runtime/regabiargs_off.go new file mode 100644 index 0000000000..49d7bcc28d --- /dev/null +++ b/src/runtime/regabiargs_off.go @@ -0,0 +1,10 @@ +// Copyright 2021 The Go Authors. All rights reserved. +// Use of this source code is governed by a BSD-style +// license that can be found in the LICENSE file. + +//go:build !goexperiment.regabiargs +// +build !goexperiment.regabiargs + +package runtime + +const experimentRegabiArgs = 0 diff --git a/src/runtime/regabiargs_on.go b/src/runtime/regabiargs_on.go new file mode 100644 index 0000000000..935d3ec24b --- /dev/null +++ b/src/runtime/regabiargs_on.go @@ -0,0 +1,10 @@ +// Copyright 2021 The Go Authors. All rights reserved. +// Use of this source code is governed by a BSD-style +// license that can be found in the LICENSE file. + +//go:build goexperiment.regabiargs +// +build goexperiment.regabiargs + +package runtime + +const experimentRegabiArgs = 1 diff --git a/src/runtime/stubs.go b/src/runtime/stubs.go index a2e04a64a5..e2d4f0da3b 100644 --- a/src/runtime/stubs.go +++ b/src/runtime/stubs.go @@ -423,4 +423,4 @@ func sigpanic0() // everywhere. // // Protected by finlock. -var intArgRegs = 0 // abi.IntArgRegs +var intArgRegs = abi.IntArgRegs * experimentRegabiArgs