1
0
mirror of https://github.com/golang/go synced 2024-11-26 19:41:19 -07:00

cmd/compile: builtins may be in the unsafe package

Now that unsafe.Sizeof and friends can operate on generic parameters,
and evaluate to non-constants, we need to export/import them correctly.

Fixes #48094

Change-Id: If3ebf77255385cd5462e13fb7ced8b157ba3cf5b
Reviewed-on: https://go-review.googlesource.com/c/go/+/346469
Trust: Keith Randall <khr@golang.org>
Run-TryBot: Keith Randall <khr@golang.org>
TryBot-Result: Go Bot <gobot@golang.org>
Reviewed-by: Robert Griesemer <gri@golang.org>
Reviewed-by: Cuong Manh Le <cuong.manhle.vn@gmail.com>
This commit is contained in:
Keith Randall 2021-08-31 09:31:56 -07:00
parent 68152359fd
commit f27d6a23b0
5 changed files with 59 additions and 1 deletions

View File

@ -1692,6 +1692,7 @@ func (w *exportWriter) expr(n ir.Node) {
isBuiltin := n.BuiltinOp != ir.OXXX isBuiltin := n.BuiltinOp != ir.OXXX
w.bool(isBuiltin) w.bool(isBuiltin)
if isBuiltin { if isBuiltin {
w.bool(n.Sym().Pkg == types.UnsafePkg)
w.string(n.Sym().Name) w.string(n.Sym().Name)
break break
} }

View File

@ -1269,7 +1269,11 @@ func (r *importReader) node() ir.Node {
case ir.ONAME: case ir.ONAME:
isBuiltin := r.bool() isBuiltin := r.bool()
if isBuiltin { if isBuiltin {
return types.BuiltinPkg.Lookup(r.string()).Def.(*ir.Name) pkg := types.BuiltinPkg
if r.bool() {
pkg = types.UnsafePkg
}
return pkg.Lookup(r.string()).Def.(*ir.Name)
} }
return r.localName() return r.localName()

View File

@ -0,0 +1,26 @@
// 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.
package a
import "unsafe"
func F[T any]() uintptr {
var t T
return unsafe.Sizeof(t)
}
func G[T any]() uintptr {
var t T
return unsafe.Alignof(t)
}
//func H[T any]() uintptr {
// type S struct {
// a T
// b T
// }
// var s S
// return unsafe.Offsetof(s.b)
//}

View File

@ -0,0 +1,20 @@
// 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.
package main
import "a"
func main() {
if a.F[int64]() != 8 {
panic("bad")
}
if a.G[int8]() != 1 {
panic("bad")
}
// TODO: enable once 47631 is fixed.
//if a.H[int64]() != 8 {
// panic("bad")
//}
}

View File

@ -0,0 +1,7 @@
// rundir -G=3
// 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.
package ignored