mirror of
https://github.com/golang/go
synced 2024-11-11 19:51:37 -07:00
cmd/compile: update WBLoads during deadcode
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 <khr@golang.org> Reviewed-by: Austin Clements <austin@google.com> TryBot-Result: Gobot Gobot <gobot@golang.org>
This commit is contained in:
parent
b65934f237
commit
db9341a024
@ -252,6 +252,19 @@ func deadcode(f *Func) {
|
|||||||
b.Values = b.Values[:i]
|
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.
|
// Remove unreachable blocks. Return dead blocks to allocator.
|
||||||
i = 0
|
i = 0
|
||||||
for _, b := range f.Blocks {
|
for _, b := range f.Blocks {
|
||||||
|
26
test/fixedbugs/issue25516.go
Normal file
26
test/fixedbugs/issue25516.go
Normal file
@ -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
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user