about summary refs log tree commit diff
path: root/compiler/rustc_middle/messages.ftl
diff options
context:
space:
mode:
authorBastian Kersting <bkersting@google.com>2025-05-15 19:09:13 +0000
committerBastian Kersting <bkersting@google.com>2025-06-27 09:37:36 +0000
commit1087042e22ae3d14ff856f621a84eaa3e15cc537 (patch)
tree628081274946cecb6c9cb17ab87a2185ccc40e12 /compiler/rustc_middle/messages.ftl
parent40daf23eeb711dadf140b2536e67e3ff4c999196 (diff)
downloadrust-1087042e22ae3d14ff856f621a84eaa3e15cc537.tar.gz
rust-1087042e22ae3d14ff856f621a84eaa3e15cc537.zip
Insert checks for enum discriminants when debug assertions are enabled
Similar to the existing nullpointer and alignment checks, this checks
for valid enum discriminants on creation of enums through unsafe
transmutes. Essentially this sanitizes patterns like the following:
```rust
let val: MyEnum = unsafe { std::mem::transmute<u32, MyEnum>(42) };
```
An extension of this check will be done in a follow-up that explicitly
sanitizes for extern enum values that come into Rust from e.g. C/C++.

This check is similar to Miri's capabilities of checking for valid
construction of enum values.

This PR is inspired by saethlin@'s PR
https://github.com/rust-lang/rust/pull/104862. Thank you so much for
keeping this code up and the detailed comments!

I also pair-programmed large parts of this together with vabr-g@.
Diffstat (limited to 'compiler/rustc_middle/messages.ftl')
-rw-r--r--compiler/rustc_middle/messages.ftl3
1 files changed, 3 insertions, 0 deletions
diff --git a/compiler/rustc_middle/messages.ftl b/compiler/rustc_middle/messages.ftl
index 3d27e587b6c..7aa47432412 100644
--- a/compiler/rustc_middle/messages.ftl
+++ b/compiler/rustc_middle/messages.ftl
@@ -17,6 +17,9 @@ middle_assert_gen_resume_after_drop = `gen` fn or block cannot be further iterat
 
 middle_assert_gen_resume_after_panic = `gen` fn or block cannot be further iterated on after it panicked
 
+middle_assert_invalid_enum_construction =
+    trying to construct an enum from an invalid value `{$source}`
+
 middle_assert_misaligned_ptr_deref =
     misaligned pointer dereference: address must be a multiple of {$required} but is {$found}