mirror of
https://github.com/golang/go
synced 2024-11-26 08:17:59 -07:00
reflect: panic on New of go:notinheap type
For #42076 Fixes #45451 Change-Id: I69646226d3480d5403205412ddd13c0cfc2c8a53 Reviewed-on: https://go-review.googlesource.com/c/go/+/308970 Trust: Ian Lance Taylor <iant@golang.org> Run-TryBot: Ian Lance Taylor <iant@golang.org> TryBot-Result: Go Bot <gobot@golang.org> Reviewed-by: Keith Randall <khr@golang.org>
This commit is contained in:
parent
5305bdedb0
commit
554d2c4f06
@ -59,6 +59,7 @@ func Test28896(t *testing.T) { test28896(t) }
|
|||||||
func Test30065(t *testing.T) { test30065(t) }
|
func Test30065(t *testing.T) { test30065(t) }
|
||||||
func Test32579(t *testing.T) { test32579(t) }
|
func Test32579(t *testing.T) { test32579(t) }
|
||||||
func Test31891(t *testing.T) { test31891(t) }
|
func Test31891(t *testing.T) { test31891(t) }
|
||||||
|
func Test45451(t *testing.T) { test45451(t) }
|
||||||
func TestAlign(t *testing.T) { testAlign(t) }
|
func TestAlign(t *testing.T) { testAlign(t) }
|
||||||
func TestAtol(t *testing.T) { testAtol(t) }
|
func TestAtol(t *testing.T) { testAtol(t) }
|
||||||
func TestBlocking(t *testing.T) { testBlocking(t) }
|
func TestBlocking(t *testing.T) { testBlocking(t) }
|
||||||
|
@ -912,6 +912,9 @@ void cFunc37033(uintptr_t handle) { GoFunc37033(handle); }
|
|||||||
enum Enum40494 { X_40494 };
|
enum Enum40494 { X_40494 };
|
||||||
union Union40494 { int x; };
|
union Union40494 { int x; };
|
||||||
void issue40494(enum Enum40494 e, union Union40494* up) {}
|
void issue40494(enum Enum40494 e, union Union40494* up) {}
|
||||||
|
|
||||||
|
// Issue 45451, bad handling of go:notinheap types.
|
||||||
|
typedef struct issue45451Undefined issue45451;
|
||||||
*/
|
*/
|
||||||
import "C"
|
import "C"
|
||||||
|
|
||||||
@ -2266,3 +2269,19 @@ var issue39877 *C.void = nil
|
|||||||
func Issue40494() {
|
func Issue40494() {
|
||||||
C.issue40494(C.enum_Enum40494(C.X_40494), (*C.union_Union40494)(nil))
|
C.issue40494(C.enum_Enum40494(C.X_40494), (*C.union_Union40494)(nil))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Issue 45451.
|
||||||
|
func test45451(t *testing.T) {
|
||||||
|
var u *C.issue45451
|
||||||
|
typ := reflect.ValueOf(u).Type().Elem()
|
||||||
|
|
||||||
|
// The type is undefined in C so allocating it should panic.
|
||||||
|
defer func() {
|
||||||
|
if r := recover(); r == nil {
|
||||||
|
t.Error("expected panic")
|
||||||
|
}
|
||||||
|
}()
|
||||||
|
|
||||||
|
_ = reflect.New(typ)
|
||||||
|
t.Errorf("reflect.New(%v) should have panicked", typ)
|
||||||
|
}
|
||||||
|
@ -2702,9 +2702,14 @@ func New(typ Type) Value {
|
|||||||
panic("reflect: New(nil)")
|
panic("reflect: New(nil)")
|
||||||
}
|
}
|
||||||
t := typ.(*rtype)
|
t := typ.(*rtype)
|
||||||
|
pt := t.ptrTo()
|
||||||
|
if ifaceIndir(pt) {
|
||||||
|
// This is a pointer to a go:notinheap type.
|
||||||
|
panic("reflect: New of type that may not be allocated in heap (possibly undefined cgo C type)")
|
||||||
|
}
|
||||||
ptr := unsafe_New(t)
|
ptr := unsafe_New(t)
|
||||||
fl := flag(Ptr)
|
fl := flag(Ptr)
|
||||||
return Value{t.ptrTo(), ptr, fl}
|
return Value{pt, ptr, fl}
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewAt returns a Value representing a pointer to a value of the
|
// NewAt returns a Value representing a pointer to a value of the
|
||||||
|
Loading…
Reference in New Issue
Block a user