Skip to content

Commit

Permalink
cmd/compile: update WBLoads during deadcode
Browse files Browse the repository at this point in the history
When we deadcode-remove a block which is a write barrier test,
remove that block from the list of write barrier test blocks.

Fixes #25516

Change-Id: I1efe732d5476003eab4ad6bf67d0340d7874ff0c
Reviewed-on: https://go-review.googlesource.com/115037
Run-TryBot: Keith Randall <[email protected]>
Reviewed-by: Austin Clements <[email protected]>
TryBot-Result: Gobot Gobot <[email protected]>
  • Loading branch information
randall77 committed May 29, 2018
1 parent b65934f commit db9341a
Show file tree
Hide file tree
Showing 2 changed files with 39 additions and 0 deletions.
13 changes: 13 additions & 0 deletions src/cmd/compile/internal/ssa/deadcode.go
Original file line number Diff line number Diff line change
Expand Up @@ -252,6 +252,19 @@ func deadcode(f *Func) {
b.Values = b.Values[:i]
}

// Remove dead blocks from WBLoads list.
i = 0
for _, b := range f.WBLoads {
if reachable[b.ID] {
f.WBLoads[i] = b
i++
}
}
for j := i; j < len(f.WBLoads); j++ {
f.WBLoads[j] = nil
}
f.WBLoads = f.WBLoads[:i]

// Remove unreachable blocks. Return dead blocks to allocator.
i = 0
for _, b := range f.Blocks {
Expand Down
26 changes: 26 additions & 0 deletions test/fixedbugs/issue25516.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
// compile

// 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.

// Make sure dead write barriers are handled correctly.

package main

func f(p **int) {
// The trick here is to eliminate the block containing the write barrier,
// but only after the write barrier branches are inserted.
// This requires some delicate code.
i := 0
var b []bool
var s string
for true {
if b[i] {
var a []string
s = a[len(s)]
i = 0
}
*p = nil
}
}

0 comments on commit db9341a

Please sign in to comment.