enable fuzzy_provenance_casts in libcore+tests

This commit is contained in:
Ralf Jung 2022-11-20 11:28:08 +01:00
parent 2bb28c174b
commit 428ab59fb7
5 changed files with 7 additions and 0 deletions

View File

@ -89,6 +89,7 @@
// Lints: // Lints:
#![deny(rust_2021_incompatible_or_patterns)] #![deny(rust_2021_incompatible_or_patterns)]
#![deny(unsafe_op_in_unsafe_fn)] #![deny(unsafe_op_in_unsafe_fn)]
#![deny(fuzzy_provenance_casts)]
#![warn(deprecated_in_future)] #![warn(deprecated_in_future)]
#![warn(missing_debug_implementations)] #![warn(missing_debug_implementations)]
#![warn(missing_docs)] #![warn(missing_docs)]
@ -162,6 +163,7 @@
#![feature(slice_ptr_get)] #![feature(slice_ptr_get)]
#![feature(slice_split_at_unchecked)] #![feature(slice_split_at_unchecked)]
#![feature(str_internals)] #![feature(str_internals)]
#![feature(strict_provenance)]
#![feature(utf16_extra)] #![feature(utf16_extra)]
#![feature(utf16_extra_const)] #![feature(utf16_extra_const)]
#![feature(variant_count)] #![feature(variant_count)]

View File

@ -140,6 +140,7 @@ impl<T: ?Sized> *const T {
/// assert_eq!(<*const u8>::from_bits(1), dangling); /// assert_eq!(<*const u8>::from_bits(1), dangling);
/// ``` /// ```
#[unstable(feature = "ptr_to_from_bits", issue = "91126")] #[unstable(feature = "ptr_to_from_bits", issue = "91126")]
#[allow(fuzzy_provenance_casts)] // this is an unstable and semi-deprecated cast function
pub fn from_bits(bits: usize) -> Self pub fn from_bits(bits: usize) -> Self
where where
T: Sized, T: Sized,

View File

@ -616,6 +616,7 @@ pub const fn invalid_mut<T>(addr: usize) -> *mut T {
#[inline] #[inline]
#[unstable(feature = "strict_provenance", issue = "95228")] #[unstable(feature = "strict_provenance", issue = "95228")]
#[cfg_attr(miri, track_caller)] // even without panics, this helps for Miri backtraces #[cfg_attr(miri, track_caller)] // even without panics, this helps for Miri backtraces
#[allow(fuzzy_provenance_casts)] // this *is* the strict provenance API one should use instead
pub fn from_exposed_addr<T>(addr: usize) -> *const T pub fn from_exposed_addr<T>(addr: usize) -> *const T
where where
T: Sized, T: Sized,
@ -653,6 +654,7 @@ where
#[inline] #[inline]
#[unstable(feature = "strict_provenance", issue = "95228")] #[unstable(feature = "strict_provenance", issue = "95228")]
#[cfg_attr(miri, track_caller)] // even without panics, this helps for Miri backtraces #[cfg_attr(miri, track_caller)] // even without panics, this helps for Miri backtraces
#[allow(fuzzy_provenance_casts)] // this *is* the strict provenance API one should use instead
pub fn from_exposed_addr_mut<T>(addr: usize) -> *mut T pub fn from_exposed_addr_mut<T>(addr: usize) -> *mut T
where where
T: Sized, T: Sized,

View File

@ -146,6 +146,7 @@ impl<T: ?Sized> *mut T {
/// assert_eq!(<*mut u8>::from_bits(1), dangling); /// assert_eq!(<*mut u8>::from_bits(1), dangling);
/// ``` /// ```
#[unstable(feature = "ptr_to_from_bits", issue = "91126")] #[unstable(feature = "ptr_to_from_bits", issue = "91126")]
#[allow(fuzzy_provenance_casts)] // this is an unstable and semi-deprecated cast function
pub fn from_bits(bits: usize) -> Self pub fn from_bits(bits: usize) -> Self
where where
T: Sized, T: Sized,

View File

@ -109,6 +109,7 @@
#![feature(utf8_chunks)] #![feature(utf8_chunks)]
#![feature(is_ascii_octdigit)] #![feature(is_ascii_octdigit)]
#![deny(unsafe_op_in_unsafe_fn)] #![deny(unsafe_op_in_unsafe_fn)]
#![deny(fuzzy_provenance_casts)]
extern crate test; extern crate test;