mirror of
https://github.com/golang/go
synced 2024-11-22 21:50:03 -07:00
cmd/compile: recognize reflect.{Slice,String}Header for -d=checkptr
Avoids false positive pointer arithmetic panic. Fixes #35027. Change-Id: Idd008caaab25fcf739327ac50a021b835ef13def Reviewed-on: https://go-review.googlesource.com/c/go/+/202560 Run-TryBot: Matthew Dempsky <mdempsky@google.com> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Brad Fitzpatrick <bradfitz@golang.org>
This commit is contained in:
parent
3409ce39bf
commit
b282efa022
@ -3941,6 +3941,10 @@ func walkCheckPtrArithmetic(n *Node, init *Nodes) *Node {
|
|||||||
return n
|
return n
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if n.Left.Op == ODOTPTR && isReflectHeaderDataField(n.Left) {
|
||||||
|
return n
|
||||||
|
}
|
||||||
|
|
||||||
// Find original unsafe.Pointer operands involved in this
|
// Find original unsafe.Pointer operands involved in this
|
||||||
// arithmetic expression.
|
// arithmetic expression.
|
||||||
//
|
//
|
||||||
|
23
test/fixedbugs/issue35027.go
Normal file
23
test/fixedbugs/issue35027.go
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
// run -gcflags=-d=checkptr
|
||||||
|
|
||||||
|
// Copyright 2019 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 (
|
||||||
|
"reflect"
|
||||||
|
"unsafe"
|
||||||
|
)
|
||||||
|
|
||||||
|
var s []int
|
||||||
|
|
||||||
|
func main() {
|
||||||
|
s = []int{42}
|
||||||
|
h := (*reflect.SliceHeader)(unsafe.Pointer(&s))
|
||||||
|
x := *(*int)(unsafe.Pointer(h.Data))
|
||||||
|
if x != 42 {
|
||||||
|
panic(x)
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user