aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorIskander Sharipov <quasilyte@gmail.com>2018-12-28 21:40:04 +0300
committerBrad Fitzpatrick <bradfitz@golang.org>2019-02-26 23:08:15 +0000
commitc1050a8e54e1e1c06aa02ccf2b36c13a95666121 (patch)
tree395ae7452f2fdca55743b0bd0049be1fad280f04 /src
parent3a9037368e28e3c5cf587d8780af6b0b8659f91e (diff)
downloadgo-c1050a8e54e1e1c06aa02ccf2b36c13a95666121.tar.xz
cmd/compile: don't generate newobject call for 0-sized types
Emit &runtime.zerobase instead of a call to newobject for allocations of zero sized objects in walk.go. Fixes #29446 Change-Id: I11b67981d55009726a17c2e582c12ce0c258682e Reviewed-on: https://go-review.googlesource.com/c/155840 Run-TryBot: Iskander Sharipov <quasilyte@gmail.com> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Cherry Zhang <cherryyz@google.com> Reviewed-by: Keith Randall <khr@golang.org>
Diffstat (limited to 'src')
-rw-r--r--src/cmd/compile/internal/gc/walk.go10
1 files changed, 10 insertions, 0 deletions
diff --git a/src/cmd/compile/internal/gc/walk.go b/src/cmd/compile/internal/gc/walk.go
index 57bf8a1e0e..1d6321212e 100644
--- a/src/cmd/compile/internal/gc/walk.go
+++ b/src/cmd/compile/internal/gc/walk.go
@@ -1940,6 +1940,16 @@ func callnew(t *types.Type) *Node {
yyerror("%v is go:notinheap; heap allocation disallowed", t)
}
dowidth(t)
+
+ if t.Size() == 0 {
+ // Return &runtime.zerobase if we know that the requested size is 0.
+ // This is what runtime.mallocgc would return.
+ z := newname(Runtimepkg.Lookup("zerobase"))
+ z.SetClass(PEXTERN)
+ z.Type = t
+ return typecheck(nod(OADDR, z, nil), ctxExpr)
+ }
+
fn := syslook("newobject")
fn = substArgTypes(fn, t)
v := mkcall1(fn, types.NewPtr(t), nil, typename(t))