]> Cypherpunks repositories - gostls13.git/commitdiff
cmd/8g: Make clearfat non-interleaved with pointer calculations.
authorDaniel Morsing <daniel.morsing@gmail.com>
Wed, 17 Jul 2013 09:04:34 +0000 (11:04 +0200)
committerDaniel Morsing <daniel.morsing@gmail.com>
Wed, 17 Jul 2013 09:04:34 +0000 (11:04 +0200)
clearfat (used to zero initialize structures) will use AX for x86 block ops. If we write to AX while calculating the dest pointer, we will fill the structure with incorrect values.
Since 64-bit arithmetic uses AX to synthesize a 64-bit register, getting an adress by indexing with 64-bit ops can clobber the register.

Fixes #5820.

R=golang-dev, rsc
CC=golang-dev
https://golang.org/cl/11383043

src/cmd/8g/ggen.c
test/fixedbugs/issue5820.go [new file with mode: 0644]

index 1095d5e441d5911e8d0a1a641130e911f6b56665..5570e128559266f1ad31a088eeda53be048a4d76 100644 (file)
@@ -78,9 +78,9 @@ clearfat(Node *nl)
        c = w % 4;      // bytes
        q = w / 4;      // quads
 
-       gconreg(AMOVL, 0, D_AX);
        nodreg(&n1, types[tptr], D_DI);
        agen(nl, &n1);
+       gconreg(AMOVL, 0, D_AX);
 
        if(q >= 4) {
                gconreg(AMOVL, q, D_CX);
diff --git a/test/fixedbugs/issue5820.go b/test/fixedbugs/issue5820.go
new file mode 100644 (file)
index 0000000..94de06d
--- /dev/null
@@ -0,0 +1,18 @@
+// run
+
+// Copyright 2013 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 5820: register clobber when clearfat and 64 bit arithmetic is interleaved.
+
+package main
+
+func main() {
+       array := make([][]int, 2)
+       index := uint64(1)
+       array[index] = nil
+       if array[1] != nil {
+               panic("array[1] != nil")
+       }
+}