Auto merge of #105741 - pietroalbini:pa-1.68-nightly, r=Mark-Simulacrum
Bump master bootstrap compiler This PR bumps the bootstrap compiler to the beta created earlier this week, cherry-picks the stabilization version number updates, and updates the `cfg(bootstrap)`s. r? `@Mark-Simulacrum`
This commit is contained in:
@@ -184,12 +184,7 @@ pub unsafe fn init(argc: isize, argv: *const *const u8, sigpipe: u8) {
|
||||
sigpipe::SIG_DFL => (true, Some(libc::SIG_DFL)),
|
||||
_ => unreachable!(),
|
||||
};
|
||||
// The bootstrap compiler doesn't know about sigpipe::DEFAULT, and always passes in
|
||||
// SIG_IGN. This causes some tests to fail because they expect SIGPIPE to be reset to
|
||||
// default on process spawning (which doesn't happen if #[unix_sigpipe] is specified).
|
||||
// Since we can't differentiate between the cases here, treat SIG_IGN as DEFAULT
|
||||
// unconditionally.
|
||||
if sigpipe_attr_specified && !(cfg!(bootstrap) && sigpipe == sigpipe::SIG_IGN) {
|
||||
if sigpipe_attr_specified {
|
||||
UNIX_SIGPIPE_ATTR_SPECIFIED.store(true, crate::sync::atomic::Ordering::Relaxed);
|
||||
}
|
||||
if let Some(handler) = handler {
|
||||
|
||||
@@ -29,7 +29,7 @@ use crate::ptr;
|
||||
use crate::sync::atomic::{self, AtomicPtr, Ordering};
|
||||
|
||||
// We can use true weak linkage on ELF targets.
|
||||
#[cfg(all(not(any(target_os = "macos", target_os = "ios")), not(bootstrap)))]
|
||||
#[cfg(not(any(target_os = "macos", target_os = "ios")))]
|
||||
pub(crate) macro weak {
|
||||
(fn $name:ident($($t:ty),*) -> $ret:ty) => (
|
||||
let ref $name: ExternWeak<unsafe extern "C" fn($($t),*) -> $ret> = {
|
||||
@@ -43,30 +43,14 @@ pub(crate) macro weak {
|
||||
)
|
||||
}
|
||||
|
||||
#[cfg(all(not(any(target_os = "macos", target_os = "ios")), bootstrap))]
|
||||
pub(crate) macro weak {
|
||||
(fn $name:ident($($t:ty),*) -> $ret:ty) => (
|
||||
let ref $name: ExternWeak<unsafe extern "C" fn($($t),*) -> $ret> = {
|
||||
extern "C" {
|
||||
#[linkage = "extern_weak"]
|
||||
static $name: *const libc::c_void;
|
||||
}
|
||||
#[allow(unused_unsafe)]
|
||||
ExternWeak::new(unsafe { $name })
|
||||
};
|
||||
)
|
||||
}
|
||||
|
||||
// On non-ELF targets, use the dlsym approximation of weak linkage.
|
||||
#[cfg(any(target_os = "macos", target_os = "ios"))]
|
||||
pub(crate) use self::dlsym as weak;
|
||||
|
||||
#[cfg(not(bootstrap))]
|
||||
pub(crate) struct ExternWeak<F: Copy> {
|
||||
weak_ptr: Option<F>,
|
||||
}
|
||||
|
||||
#[cfg(not(bootstrap))]
|
||||
impl<F: Copy> ExternWeak<F> {
|
||||
#[inline]
|
||||
pub(crate) fn new(weak_ptr: Option<F>) -> Self {
|
||||
@@ -79,34 +63,6 @@ impl<F: Copy> ExternWeak<F> {
|
||||
}
|
||||
}
|
||||
|
||||
#[cfg(bootstrap)]
|
||||
pub(crate) struct ExternWeak<F> {
|
||||
weak_ptr: *const libc::c_void,
|
||||
_marker: PhantomData<F>,
|
||||
}
|
||||
|
||||
#[cfg(bootstrap)]
|
||||
impl<F> ExternWeak<F> {
|
||||
#[inline]
|
||||
pub(crate) fn new(weak_ptr: *const libc::c_void) -> Self {
|
||||
ExternWeak { weak_ptr, _marker: PhantomData }
|
||||
}
|
||||
}
|
||||
|
||||
#[cfg(bootstrap)]
|
||||
impl<F> ExternWeak<F> {
|
||||
#[inline]
|
||||
pub(crate) fn get(&self) -> Option<F> {
|
||||
unsafe {
|
||||
if self.weak_ptr.is_null() {
|
||||
None
|
||||
} else {
|
||||
Some(mem::transmute_copy::<*const libc::c_void, F>(&self.weak_ptr))
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
pub(crate) macro dlsym {
|
||||
(fn $name:ident($($t:ty),*) -> $ret:ty) => (
|
||||
dlsym!(fn $name($($t),*) -> $ret, stringify!($name));
|
||||
|
||||
Reference in New Issue
Block a user