mirror of
https://github.com/golang/go
synced 2024-11-11 18:21:40 -07:00
[release-branch.go1.10] cmd/compile/internal/gc: OMUL should be evaluated when using soft-float
When using soft-float, OMUL might be rewritten to function call
so we should ensure it was evaluated first.
Updates #28688
Fixes #28959
Change-Id: I30b87501782fff62d35151f394a1c22b0d490c6c
Reviewed-on: https://go-review.googlesource.com/c/148837
Run-TryBot: Cherry Zhang <cherryyz@google.com>
TryBot-Result: Gobot Gobot <gobot@golang.org>
Reviewed-by: Cherry Zhang <cherryyz@google.com>
(cherry picked from commit c92e73b702
)
Reviewed-on: https://go-review.googlesource.com/c/151343
Reviewed-by: Filippo Valsorda <filippo@golang.org>
This commit is contained in:
parent
25bee965c6
commit
d74e69c755
@ -1168,7 +1168,7 @@ func calcHasCall(n *Node) bool {
|
||||
|
||||
// When using soft-float, these ops might be rewritten to function calls
|
||||
// so we ensure they are evaluated first.
|
||||
case OADD, OSUB, OMINUS:
|
||||
case OADD, OSUB, OMINUS, OMUL:
|
||||
if thearch.SoftFloat && (isFloat[n.Type.Etype] || isComplex[n.Type.Etype]) {
|
||||
return true
|
||||
}
|
||||
|
31
test/fixedbugs/issue28688.go
Normal file
31
test/fixedbugs/issue28688.go
Normal file
@ -0,0 +1,31 @@
|
||||
// run -gcflags=-d=softfloat
|
||||
|
||||
// Copyright 2018 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
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
)
|
||||
|
||||
// When using soft-float, OMUL might be rewritten to function
|
||||
// call so we should ensure it was evaluated first. Stack frame
|
||||
// setup for "test" function call should happen after call to runtime.fmul32
|
||||
|
||||
var x int32 = 1
|
||||
|
||||
func main() {
|
||||
var y float32 = 1.0
|
||||
test(x, y*y)
|
||||
}
|
||||
|
||||
//go:noinline
|
||||
func test(id int32, a float32) {
|
||||
|
||||
if id != x {
|
||||
fmt.Printf("got: %d, want: %d\n", id, x)
|
||||
panic("FAIL")
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user