summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRuss Cox <rsc@golang.org>2010-06-30 20:45:50 -0700
committerRuss Cox <rsc@golang.org>2010-06-30 20:45:50 -0700
commitdbdbfcf74725a012a6b111697f31db87bc3d392a (patch)
tree394052632498135e35ce700cc7e32e59eec990ae
parentedea112c8d497bc4d08d40b150cbe1ca16f54ed7 (diff)
downloadgolang-dbdbfcf74725a012a6b111697f31db87bc3d392a.tar.gz
8g: out of register bug fix
Fixes issue 868. R=ken2 CC=golang-dev http://codereview.appspot.com/1695049
-rw-r--r--src/cmd/8g/ggen.c4
-rw-r--r--test/fixedbugs/bug287.go11
-rw-r--r--test/fixedbugs/bug288.go18
3 files changed, 32 insertions, 1 deletions
diff --git a/src/cmd/8g/ggen.c b/src/cmd/8g/ggen.c
index 110446a0d..8a55ffd59 100644
--- a/src/cmd/8g/ggen.c
+++ b/src/cmd/8g/ggen.c
@@ -672,8 +672,10 @@ cgen_shift(int op, Node *nl, Node *nr, Node *res)
a = optoas(op, nl->type);
if(nr->op == OLITERAL) {
+ tempname(&n2, nl->type);
+ cgen(nl, &n2);
regalloc(&n1, nl->type, res);
- cgen(nl, &n1);
+ gmove(&n2, &n1);
sc = mpgetfix(nr->val.u.xval);
if(sc >= nl->type->width*8) {
// large shift gets 2 shifts by width
diff --git a/test/fixedbugs/bug287.go b/test/fixedbugs/bug287.go
new file mode 100644
index 000000000..a4a08eedc
--- /dev/null
+++ b/test/fixedbugs/bug287.go
@@ -0,0 +1,11 @@
+// errchk $G $D/$F.go
+
+// Copyright 2010 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.
+
+// Used to die dividing by zero; issue 879.
+
+package main
+
+var mult [3][...]byte = [3][5]byte{} // ERROR "\.\.\."
diff --git a/test/fixedbugs/bug288.go b/test/fixedbugs/bug288.go
new file mode 100644
index 000000000..0105159d1
--- /dev/null
+++ b/test/fixedbugs/bug288.go
@@ -0,0 +1,18 @@
+// $G $D/$F.go
+
+// Copyright 2010 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.
+
+// Used to run out of registers on 8g. Issue 868.
+
+package main
+
+func main() {
+ var r uint32
+ var buf [4]byte
+ a := buf[0:4]
+ r = (((((uint32(a[3]) << 8) | uint32(a[2])) << 8) |
+ uint32(a[1])) << 8) | uint32(a[0])
+ _ = r
+}