mirror of
https://github.com/golang/go.git
synced 2025-12-08 06:10:04 +00:00
cmd/compile: large ptr literals must escape
They get rewritten to NEWs, and they must be marked as escaping so walk doesn't try to allocate them back onto the stack. Fixes #15733 Change-Id: I433033e737c3de51a9e83a5a273168dbc9110b74 Reviewed-on: https://go-review.googlesource.com/23223 Run-TryBot: Keith Randall <khr@golang.org> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: David Chase <drchase@google.com>
This commit is contained in:
parent
1ab9428eec
commit
d603c27c6b
2 changed files with 24 additions and 1 deletions
|
|
@ -640,7 +640,7 @@ func esc(e *EscState, n *Node, up *Node) {
|
||||||
// "Big" conditions that were scattered around in walk have been gathered here
|
// "Big" conditions that were scattered around in walk have been gathered here
|
||||||
if n.Esc != EscHeap && n.Type != nil &&
|
if n.Esc != EscHeap && n.Type != nil &&
|
||||||
(n.Type.Width > MaxStackVarSize ||
|
(n.Type.Width > MaxStackVarSize ||
|
||||||
n.Op == ONEW && n.Type.Elem().Width >= 1<<16 ||
|
(n.Op == ONEW || n.Op == OPTRLIT) && n.Type.Elem().Width >= 1<<16 ||
|
||||||
n.Op == OMAKESLICE && !isSmallMakeSlice(n)) {
|
n.Op == OMAKESLICE && !isSmallMakeSlice(n)) {
|
||||||
if Debug['m'] > 2 {
|
if Debug['m'] > 2 {
|
||||||
Warnl(n.Lineno, "%v is too large for stack", n)
|
Warnl(n.Lineno, "%v is too large for stack", n)
|
||||||
|
|
|
||||||
23
test/fixedbugs/issue15733.go
Normal file
23
test/fixedbugs/issue15733.go
Normal file
|
|
@ -0,0 +1,23 @@
|
||||||
|
// compile
|
||||||
|
|
||||||
|
// Copyright 2016 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
|
||||||
|
|
||||||
|
type S struct {
|
||||||
|
a [1 << 16]byte
|
||||||
|
}
|
||||||
|
|
||||||
|
func f1() {
|
||||||
|
p := &S{}
|
||||||
|
_ = p
|
||||||
|
}
|
||||||
|
|
||||||
|
type T [1 << 16]byte
|
||||||
|
|
||||||
|
func f2() {
|
||||||
|
p := &T{}
|
||||||
|
_ = p
|
||||||
|
}
|
||||||
Loading…
Add table
Add a link
Reference in a new issue