2019-06-28 10:27:19 +02:00
|
|
|
// Even with intptrcast and without validation, we want to be *sure* to catch bugs
|
|
|
|
// that arise from pointers being insufficiently aligned. The only way to achieve
|
|
|
|
// that is not not let programs exploit integer information for alignment, so here
|
|
|
|
// we test that this is indeed the case.
|
2020-04-14 09:50:20 +02:00
|
|
|
//
|
|
|
|
// See https://github.com/rust-lang/miri/issues/1074.
|
2019-06-28 10:27:19 +02:00
|
|
|
fn main() {
|
|
|
|
let x = &mut [0u8; 3];
|
|
|
|
let base_addr = x as *mut _ as usize;
|
2019-07-27 11:03:12 +02:00
|
|
|
let base_addr_aligned = if base_addr % 2 == 0 { base_addr } else { base_addr+1 };
|
|
|
|
let u16_ptr = base_addr_aligned as *mut u16;
|
2020-03-08 23:34:54 +01:00
|
|
|
unsafe { *u16_ptr = 2; } //~ ERROR memory with alignment 1, but alignment 2 is required
|
2019-06-28 10:27:19 +02:00
|
|
|
println!("{:?}", x);
|
|
|
|
}
|