rust/tests/ui/consts/const-eval/ub-ref-ptr.stderr

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

169 lines
8.5 KiB
Plaintext
Raw Normal View History

2021-03-31 09:33:45 +00:00
error[E0080]: it is undefined behavior to use this value
--> $DIR/ub-ref-ptr.rs:16:1
2021-03-31 09:33:45 +00:00
|
LL | const UNALIGNED: &u16 = unsafe { mem::transmute(&[0u8; 4]) };
2022-02-13 16:27:59 +01:00
| ^^^^^^^^^^^^^^^^^^^^^ constructing invalid value: encountered an unaligned reference (required 2 byte alignment but found 1)
2021-03-31 09:33:45 +00:00
|
= note: The rules on what exactly is undefined behavior aren't clear, so this check might be overzealous. Please open an issue on the rustc repository if you believe it should not be considered undefined behavior.
= note: the raw bytes of the constant (size: $SIZE, align: $ALIGN) {
HEX_DUMP
2021-03-31 09:33:45 +00:00
}
error[E0080]: it is undefined behavior to use this value
--> $DIR/ub-ref-ptr.rs:20:1
2021-03-31 09:33:45 +00:00
|
LL | const UNALIGNED_BOX: Box<u16> = unsafe { mem::transmute(&[0u8; 4]) };
2022-02-13 16:27:59 +01:00
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ constructing invalid value: encountered an unaligned box (required 2 byte alignment but found 1)
2021-03-31 09:33:45 +00:00
|
= note: The rules on what exactly is undefined behavior aren't clear, so this check might be overzealous. Please open an issue on the rustc repository if you believe it should not be considered undefined behavior.
= note: the raw bytes of the constant (size: $SIZE, align: $ALIGN) {
HEX_DUMP
2021-03-31 09:33:45 +00:00
}
error[E0080]: it is undefined behavior to use this value
--> $DIR/ub-ref-ptr.rs:24:1
2021-03-31 09:33:45 +00:00
|
LL | const NULL: &u16 = unsafe { mem::transmute(0usize) };
2022-02-13 16:27:59 +01:00
| ^^^^^^^^^^^^^^^^ constructing invalid value: encountered a null reference
2021-03-31 09:33:45 +00:00
|
= note: The rules on what exactly is undefined behavior aren't clear, so this check might be overzealous. Please open an issue on the rustc repository if you believe it should not be considered undefined behavior.
= note: the raw bytes of the constant (size: $SIZE, align: $ALIGN) {
HEX_DUMP
2021-03-31 09:33:45 +00:00
}
error[E0080]: it is undefined behavior to use this value
--> $DIR/ub-ref-ptr.rs:27:1
2021-03-31 09:33:45 +00:00
|
LL | const NULL_BOX: Box<u16> = unsafe { mem::transmute(0usize) };
2022-02-13 16:27:59 +01:00
| ^^^^^^^^^^^^^^^^^^^^^^^^ constructing invalid value: encountered a null box
2021-03-31 09:33:45 +00:00
|
= note: The rules on what exactly is undefined behavior aren't clear, so this check might be overzealous. Please open an issue on the rustc repository if you believe it should not be considered undefined behavior.
= note: the raw bytes of the constant (size: $SIZE, align: $ALIGN) {
HEX_DUMP
2021-03-31 09:33:45 +00:00
}
2022-09-21 13:05:20 +02:00
error[E0080]: evaluation of constant value failed
--> $DIR/ub-ref-ptr.rs:34:1
2021-03-31 09:33:45 +00:00
|
LL | const REF_AS_USIZE: usize = unsafe { mem::transmute(&0) };
2022-02-13 16:27:59 +01:00
| ^^^^^^^^^^^^^^^^^^^^^^^^^ unable to turn pointer into raw bytes
2021-03-31 09:33:45 +00:00
|
2022-08-27 17:46:14 -04:00
= help: this code performed an operation that depends on the underlying bytes representing a pointer
= help: the absolute address of a pointer is not known at compile-time, so such operations are not supported
2021-03-31 09:33:45 +00:00
2022-09-21 13:05:20 +02:00
error[E0080]: evaluation of constant value failed
--> $DIR/ub-ref-ptr.rs:37:39
2021-03-31 09:33:45 +00:00
|
LL | const REF_AS_USIZE_SLICE: &[usize] = &[unsafe { mem::transmute(&0) }];
2022-09-21 13:05:20 +02:00
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ unable to turn pointer into raw bytes
2021-03-31 09:33:45 +00:00
|
2022-08-27 17:46:14 -04:00
= help: this code performed an operation that depends on the underlying bytes representing a pointer
= help: the absolute address of a pointer is not known at compile-time, so such operations are not supported
2021-03-31 09:33:45 +00:00
note: erroneous constant used
--> $DIR/ub-ref-ptr.rs:37:38
|
LL | const REF_AS_USIZE_SLICE: &[usize] = &[unsafe { mem::transmute(&0) }];
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
2022-09-21 13:05:20 +02:00
error[E0080]: evaluation of constant value failed
--> $DIR/ub-ref-ptr.rs:40:86
2021-03-31 09:33:45 +00:00
|
LL | const REF_AS_USIZE_BOX_SLICE: Box<[usize]> = unsafe { mem::transmute::<&[usize], _>(&[mem::transmute(&0)]) };
2022-09-21 13:05:20 +02:00
| ^^^^^^^^^^^^^^^^^^^^ unable to turn pointer into raw bytes
2021-03-31 09:33:45 +00:00
|
2022-08-27 17:46:14 -04:00
= help: this code performed an operation that depends on the underlying bytes representing a pointer
= help: the absolute address of a pointer is not known at compile-time, so such operations are not supported
note: erroneous constant used
--> $DIR/ub-ref-ptr.rs:40:85
|
LL | const REF_AS_USIZE_BOX_SLICE: Box<[usize]> = unsafe { mem::transmute::<&[usize], _>(&[mem::transmute(&0)]) };
| ^^^^^^^^^^^^^^^^^^^^^
2021-03-31 09:33:45 +00:00
error[E0080]: it is undefined behavior to use this value
--> $DIR/ub-ref-ptr.rs:43:1
2021-03-31 09:33:45 +00:00
|
LL | const USIZE_AS_REF: &'static u8 = unsafe { mem::transmute(1337usize) };
2023-02-06 16:00:54 +01:00
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ constructing invalid value: encountered a dangling reference (0x539[noalloc] has no provenance)
2021-03-31 09:33:45 +00:00
|
= note: The rules on what exactly is undefined behavior aren't clear, so this check might be overzealous. Please open an issue on the rustc repository if you believe it should not be considered undefined behavior.
= note: the raw bytes of the constant (size: $SIZE, align: $ALIGN) {
HEX_DUMP
2021-03-31 09:33:45 +00:00
}
error[E0080]: it is undefined behavior to use this value
--> $DIR/ub-ref-ptr.rs:46:1
2021-03-31 09:33:45 +00:00
|
LL | const USIZE_AS_BOX: Box<u8> = unsafe { mem::transmute(1337usize) };
2023-02-06 16:00:54 +01:00
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^ constructing invalid value: encountered a dangling box (0x539[noalloc] has no provenance)
2021-03-31 09:33:45 +00:00
|
= note: The rules on what exactly is undefined behavior aren't clear, so this check might be overzealous. Please open an issue on the rustc repository if you believe it should not be considered undefined behavior.
= note: the raw bytes of the constant (size: $SIZE, align: $ALIGN) {
HEX_DUMP
2021-03-31 09:33:45 +00:00
}
error[E0080]: evaluation of constant value failed
--> $DIR/ub-ref-ptr.rs:49:41
2021-03-31 09:33:45 +00:00
|
LL | const UNINIT_PTR: *const i32 = unsafe { MaybeUninit { uninit: () }.init };
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ using uninitialized data, but this operation requires initialized memory
2021-03-31 09:33:45 +00:00
error[E0080]: it is undefined behavior to use this value
--> $DIR/ub-ref-ptr.rs:53:1
2022-02-22 18:49:12 -05:00
|
LL | const NULL_FN_PTR: fn() = unsafe { mem::transmute(0usize) };
| ^^^^^^^^^^^^^^^^^^^^^^^ constructing invalid value: encountered null pointer, but expected a function pointer
2022-02-22 18:49:12 -05:00
|
= note: The rules on what exactly is undefined behavior aren't clear, so this check might be overzealous. Please open an issue on the rustc repository if you believe it should not be considered undefined behavior.
= note: the raw bytes of the constant (size: $SIZE, align: $ALIGN) {
HEX_DUMP
2022-02-22 18:49:12 -05:00
}
error[E0080]: evaluation of constant value failed
--> $DIR/ub-ref-ptr.rs:55:38
2021-03-31 09:33:45 +00:00
|
LL | const UNINIT_FN_PTR: fn() = unsafe { MaybeUninit { uninit: () }.init };
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ using uninitialized data, but this operation requires initialized memory
2021-03-31 09:33:45 +00:00
2022-02-22 18:49:12 -05:00
error[E0080]: it is undefined behavior to use this value
--> $DIR/ub-ref-ptr.rs:58:1
2022-02-22 18:49:12 -05:00
|
LL | const DANGLING_FN_PTR: fn() = unsafe { mem::transmute(13usize) };
| ^^^^^^^^^^^^^^^^^^^^^^^^^^^ constructing invalid value: encountered 0xd[noalloc], but expected a function pointer
2022-02-22 18:49:12 -05:00
|
= note: The rules on what exactly is undefined behavior aren't clear, so this check might be overzealous. Please open an issue on the rustc repository if you believe it should not be considered undefined behavior.
= note: the raw bytes of the constant (size: $SIZE, align: $ALIGN) {
HEX_DUMP
2022-02-22 18:49:12 -05:00
}
error[E0080]: it is undefined behavior to use this value
--> $DIR/ub-ref-ptr.rs:60:1
2022-02-22 18:49:12 -05:00
|
LL | const DATA_FN_PTR: fn() = unsafe { mem::transmute(&13) };
| ^^^^^^^^^^^^^^^^^^^^^^^ constructing invalid value: encountered alloc41, but expected a function pointer
2022-02-22 18:49:12 -05:00
|
= note: The rules on what exactly is undefined behavior aren't clear, so this check might be overzealous. Please open an issue on the rustc repository if you believe it should not be considered undefined behavior.
= note: the raw bytes of the constant (size: $SIZE, align: $ALIGN) {
HEX_DUMP
2022-02-22 18:49:12 -05:00
}
error[E0080]: evaluation of constant value failed
2022-11-20 09:54:45 +01:00
--> $SRC_DIR/core/src/ptr/mod.rs:LL:COL
|
= note: accessing memory with alignment 1, but alignment 4 is required
|
note: inside `std::ptr::read::<u32>`
--> $SRC_DIR/core/src/ptr/mod.rs:LL:COL
note: inside `ptr::const_ptr::<impl *const u32>::read`
2022-11-20 09:54:45 +01:00
--> $SRC_DIR/core/src/ptr/const_ptr.rs:LL:COL
note: inside `UNALIGNED_READ`
--> $DIR/ub-ref-ptr.rs:67:5
2022-11-20 09:54:45 +01:00
|
LL | ptr.read();
| ^^^^^^^^^^
2022-11-20 09:54:45 +01:00
error: aborting due to 15 previous errors
2021-03-31 09:33:45 +00:00
For more information about this error, try `rustc --explain E0080`.