aboutsummaryrefslogtreecommitdiff
path: root/src/cmd/compile/internal/walk/expr.go
diff options
context:
space:
mode:
authorKeith Randall <khr@golang.org>2023-09-18 13:31:49 -0700
committerKeith Randall <khr@golang.org>2023-10-06 17:02:53 +0000
commitcbcf8efa5f749b4e5bceda8682070cd9cf84bee5 (patch)
tree0e8f56257343458b5ee320a146f27ed001d9fbf8 /src/cmd/compile/internal/walk/expr.go
parentb455e239aeeeb1d33eaa34e62c397f3408245a0c (diff)
downloadgo-cbcf8efa5f749b4e5bceda8682070cd9cf84bee5.tar.xz
cmd/compile: use cache in front of type assert runtime call
That way we don't need to call into the runtime for every type assertion (to an interface type). name old time/op new time/op delta TypeAssert-24 3.78ns ± 3% 1.00ns ± 1% -73.53% (p=0.000 n=10+8) Change-Id: I0ba308aaf0f24a5495b4e13c814d35af0c58bfde Reviewed-on: https://go-review.googlesource.com/c/go/+/529316 LUCI-TryBot-Result: Go LUCI <golang-scoped@luci-project-accounts.iam.gserviceaccount.com> Reviewed-by: Keith Randall <khr@google.com> Reviewed-by: Matthew Dempsky <mdempsky@google.com> Reviewed-by: Cuong Manh Le <cuong.manhle.vn@gmail.com>
Diffstat (limited to 'src/cmd/compile/internal/walk/expr.go')
-rw-r--r--src/cmd/compile/internal/walk/expr.go7
1 files changed, 6 insertions, 1 deletions
diff --git a/src/cmd/compile/internal/walk/expr.go b/src/cmd/compile/internal/walk/expr.go
index a3caa4db36..914011d135 100644
--- a/src/cmd/compile/internal/walk/expr.go
+++ b/src/cmd/compile/internal/walk/expr.go
@@ -731,10 +731,15 @@ func walkDotType(n *ir.TypeAssertExpr, init *ir.Nodes) ir.Node {
lsym := types.LocalPkg.Lookup(fmt.Sprintf(".typeAssert.%d", typeAssertGen)).LinksymABI(obj.ABI0)
typeAssertGen++
off := 0
+ off = objw.SymPtr(lsym, off, typecheck.LookupRuntimeVar("emptyTypeAssertCache"), 0)
off = objw.SymPtr(lsym, off, reflectdata.TypeSym(n.Type()).Linksym(), 0)
off = objw.Bool(lsym, off, n.Op() == ir.ODOTTYPE2) // CanFail
off += types.PtrSize - 1
- objw.Global(lsym, int32(off), obj.LOCAL|obj.NOPTR)
+ objw.Global(lsym, int32(off), obj.LOCAL)
+ // Set the type to be just a single pointer, as the cache pointer is the
+ // only one that GC needs to see.
+ lsym.Gotype = reflectdata.TypeLinksym(types.Types[types.TUINT8].PtrTo())
+
n.Descriptor = lsym
}
return n