Commit b282efa0 authored by Matthew Dempsky's avatar Matthew Dempsky

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: default avatarBrad Fitzpatrick <bradfitz@golang.org>
parent 3409ce39
...@@ -3941,6 +3941,10 @@ func walkCheckPtrArithmetic(n *Node, init *Nodes) *Node { ...@@ -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.
// //
......
// 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)
}
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment