1
0
mirror of https://github.com/golang/go synced 2024-11-24 22:10:02 -07:00
go/test/fixedbugs/issue4518.go
Todd Neal e3e0122ae2 test: use go:noinline consistently
Replace various implementations of inlining prevention with
"go:noinline"

Change-Id: Iac90895c3a62d6f4b7a6c72e11e165d15a0abfa4
Reviewed-on: https://go-review.googlesource.com/16510
Reviewed-by: Keith Randall <khr@golang.org>
Run-TryBot: Todd Neal <todd@tneal.org>
TryBot-Result: Gobot Gobot <gobot@golang.org>
2015-11-03 02:01:34 +00:00

66 lines
943 B
Go

// 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 4518. In some circumstances "return F(...)"
// where F has multiple returns is miscompiled by 6g due to
// bold assumptions in componentgen.
package main
//go:noinline
func F(e interface{}) (int, int) {
return 3, 7
}
//go:noinline
func G() (int, int) {
return 3, 7
}
func bogus1(d interface{}) (int, int) {
switch {
default:
return F(d)
}
return 0, 0
}
func bogus2() (int, int) {
switch {
default:
return F(3)
}
return 0, 0
}
func bogus3(d interface{}) (int, int) {
switch {
default:
return G()
}
return 0, 0
}
func bogus4() (int, int) {
switch {
default:
return G()
}
return 0, 0
}
func check(a, b int) {
if a != 3 || b != 7 {
println(a, b)
panic("a != 3 || b != 7")
}
}
func main() {
check(bogus1(42))
check(bogus2())
}