Auto merge of #1113 - RalfJung:vtable, r=RalfJung
add test for sketchy vtable Blocked on https://github.com/rust-lang/rust/pull/67254
This commit is contained in:
commit
60c75092de
2 changed files with 47 additions and 1 deletions
|
|
@ -1 +1 @@
|
|||
e862c01aadb2d029864f7bb256cf6c85bbb5d7e4
|
||||
12307b3b08edee543a78fb9d4a837fbd6d6ac0fa
|
||||
|
|
|
|||
46
tests/compile-fail/issue-miri-1112.rs
Normal file
46
tests/compile-fail/issue-miri-1112.rs
Normal file
|
|
@ -0,0 +1,46 @@
|
|||
trait Empty {}
|
||||
|
||||
#[repr(transparent)]
|
||||
pub struct FunnyPointer(dyn Empty);
|
||||
|
||||
#[repr(C)]
|
||||
pub struct Meta {
|
||||
drop_fn: fn(&mut ()),
|
||||
size: usize,
|
||||
align: usize,
|
||||
}
|
||||
|
||||
impl Meta {
|
||||
pub fn new() -> Self {
|
||||
Meta {
|
||||
drop_fn: |_| {},
|
||||
size: 0,
|
||||
align: 1,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
#[repr(C)]
|
||||
pub struct FatPointer {
|
||||
pub data: *const (),
|
||||
pub vtable: *const (),
|
||||
}
|
||||
|
||||
impl FunnyPointer {
|
||||
pub unsafe fn from_data_ptr(data: &String, ptr: *const Meta) -> &Self {
|
||||
let obj = FatPointer {
|
||||
data: data as *const _ as *const (),
|
||||
vtable: ptr as *const _ as *const (),
|
||||
};
|
||||
let obj = std::mem::transmute::<FatPointer, *mut FunnyPointer>(obj); //~ ERROR invalid drop fn in vtable
|
||||
&*obj
|
||||
}
|
||||
}
|
||||
|
||||
fn main() {
|
||||
unsafe {
|
||||
let meta = Meta::new();
|
||||
let hello = "hello".to_string();
|
||||
let _raw: &FunnyPointer = FunnyPointer::from_data_ptr(&hello, &meta as *const _);
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue