]> git.lizzy.rs Git - rust.git/commitdiff
Auto merge of #105613 - Nilstrieb:rename-assert_uninit_valid, r=RalfJung
authorbors <bors@rust-lang.org>
Wed, 21 Dec 2022 23:20:04 +0000 (23:20 +0000)
committerbors <bors@rust-lang.org>
Wed, 21 Dec 2022 23:20:04 +0000 (23:20 +0000)
Rename `assert_uninit_valid` intrinsic

It's not about "uninit" anymore but about "filling with 0x01 bytes" so the name should at least try to reflect that.

This is actually not fully correct though, as it does still panic for all uninit with `-Zstrict-init-checks`. I'm not sure what the best way is to deal with that not causing confusion. I guess we could just remove the flag? I don't think having it makes a lot of sense anymore with the direction that we have chose to go. It could be relevant again if #100423 lands so removing it may be a bit over eager.

r? `@RalfJung`

1  2 
src/intrinsics/mod.rs

index 7a380acf798572a7606130959a7517cfecb2462b,e4a27f1bb6d403896b08207f7f2a07a8e141b4cc..e4ac89a7bec6b245d17cf41828f392a76df8e4dc
@@@ -636,15 -635,85 +636,15 @@@ fn codegen_regular_intrinsic_call<'tcx>
              intrinsic_args!(fx, args => (arg); intrinsic);
              let val = arg.load_scalar(fx);
  
 -            let res = CValue::by_val(swap(&mut fx.bcx, val), arg.layout());
 +            let res = if fx.bcx.func.dfg.value_type(val) == types::I8 {
 +                val
 +            } else {
 +                fx.bcx.ins().bswap(val)
 +            };
 +            let res = CValue::by_val(res, arg.layout());
              ret.write_cvalue(fx, res);
          }
-         sym::assert_inhabited | sym::assert_zero_valid | sym::assert_uninit_valid => {
+         sym::assert_inhabited | sym::assert_zero_valid | sym::assert_mem_uninitialized_valid => {
              intrinsic_args!(fx, args => (); intrinsic);
  
              let layout = fx.layout_of(substs.type_at(0));