Commit f1e4ee3f authored by Daniel Morsing's avatar Daniel Morsing

cmd/5g, cmd/6g, cmd/8g: flush return parameters in case of panic.

Fixes #4066.

R=rsc, minux.ma
CC=golang-dev
https://golang.org/cl/7040044
parent 62dfa9c4
...@@ -1075,8 +1075,12 @@ prop(Reg *r, Bits ref, Bits cal) ...@@ -1075,8 +1075,12 @@ prop(Reg *r, Bits ref, Bits cal)
default: default:
// Work around for issue 1304: // Work around for issue 1304:
// flush modified globals before each instruction. // flush modified globals before each instruction.
for(z=0; z<BITS; z++) for(z=0; z<BITS; z++) {
cal.b[z] |= externs.b[z]; cal.b[z] |= externs.b[z];
// issue 4066: flush modified return variables in case of panic
if(hasdefer)
cal.b[z] |= ovar.b[z];
}
break; break;
} }
for(z=0; z<BITS; z++) { for(z=0; z<BITS; z++) {
......
...@@ -1121,8 +1121,12 @@ prop(Reg *r, Bits ref, Bits cal) ...@@ -1121,8 +1121,12 @@ prop(Reg *r, Bits ref, Bits cal)
default: default:
// Work around for issue 1304: // Work around for issue 1304:
// flush modified globals before each instruction. // flush modified globals before each instruction.
for(z=0; z<BITS; z++) for(z=0; z<BITS; z++) {
cal.b[z] |= externs.b[z]; cal.b[z] |= externs.b[z];
// issue 4066: flush modified return variables in case of panic
if(hasdefer)
cal.b[z] |= ovar.b[z];
}
break; break;
} }
for(z=0; z<BITS; z++) { for(z=0; z<BITS; z++) {
......
...@@ -1048,8 +1048,12 @@ prop(Reg *r, Bits ref, Bits cal) ...@@ -1048,8 +1048,12 @@ prop(Reg *r, Bits ref, Bits cal)
default: default:
// Work around for issue 1304: // Work around for issue 1304:
// flush modified globals before each instruction. // flush modified globals before each instruction.
for(z=0; z<BITS; z++) for(z=0; z<BITS; z++) {
cal.b[z] |= externs.b[z]; cal.b[z] |= externs.b[z];
// issue 4066: flush modified return variables in case of panic
if(hasdefer)
cal.b[z] |= ovar.b[z];
}
break; break;
} }
for(z=0; z<BITS; z++) { for(z=0; z<BITS; z++) {
......
// run
// Copyright 2012 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.
// issue 4066: return values not being spilled eagerly enough
package main
func main() {
n := foo()
if n != 2 {
println(n)
panic("wrong return value")
}
}
type terr struct{}
func foo() (val int) {
val = 0
defer func() {
if x := recover(); x != nil {
_ = x.(terr)
}
}()
for {
val = 2
foo1()
}
panic("unreachable")
}
func foo1() {
panic(terr{})
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment