Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Sync from rust 2025/03/27 #645

Open
wants to merge 75 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
75 commits
Select commit Hold shift + click to select a range
60ee6fb
Update tests.
m-ou-se Oct 31, 2024
0f89f3f
Use a C-safe return type for `__rust_[ui]128_*` overflowing intrinsics
tgross35 Dec 15, 2024
daeeffa
Rollup merge of #132397 - m-ou-se:warn-missing-abi, r=Nadrieril
jhpratt Jan 15, 2025
cdf26a1
Rollup merge of #134338 - tgross35:overflowing-c-safe-ret, r=bjorn3,a…
jhpratt Jan 15, 2025
4600047
When LLVM's location discriminator value limit is exceeded, emit loca…
khuey Jan 17, 2025
49e047f
Treat undef bytes as equal to any other byte
oli-obk Jan 8, 2025
301d247
remove support for the #[start] attribute
RalfJung Dec 14, 2024
c482251
Auto merge of #134299 - RalfJung:remove-start, r=compiler-errors
bors Jan 21, 2025
0692ca3
Make CodegenCx and Builder generic
ZuseZ4 Jan 24, 2025
d6d7c15
Merge commit '9f33f846ddc06afd7ffd839ee4f18babac3f3204'
GuillaumeGomez Jan 24, 2025
4fec62a
Rollup merge of #135581 - EnzymeAD:refactor-codgencx, r=oli-obk
matthiaskrgr Jan 24, 2025
24ce0a2
Stabilize `const_black_box`
tgross35 Jan 12, 2025
06f8ed1
Auto merge of #136024 - GuillaumeGomez:cg_gcc-subtree, r=GuillaumeGomez
bors Jan 27, 2025
600999a
ABI-required target features: warn when they are missing in base CPU …
RalfJung Jan 27, 2025
90a6f2b
Do not treat vtable supertraits as distinct when bound with different…
compiler-errors Jan 10, 2025
12feb0e
Use ExistentialTraitRef throughout codegen
compiler-errors Jan 10, 2025
a05dca8
Rollup merge of #135414 - tgross35:stabilize-const_black_box, r=dtolnay
jhpratt Jan 31, 2025
afe0843
Auto merge of #136331 - jhpratt:rollup-curo1f4, r=jhpratt
bors Jan 31, 2025
e0d8fb9
tree-wide: parallel: Fully removed all `Lrc`, replaced with `Arc`
safinaskar Feb 3, 2025
beb24b3
intrinsics: unify rint, roundeven, nearbyint in a single round_ties_e…
RalfJung Feb 4, 2025
819ab9b
cg_gcc: Directly use rustc_abi instead of reexports
workingjubilee Nov 3, 2024
db4b00f
Auto merge of #136471 - safinaskar:parallel, r=SparrowLii
bors Feb 6, 2025
21b60aa
Remove Linkage::Private
bjorn3 Feb 7, 2025
a90648d
Remove Linkage::Appending
bjorn3 Feb 7, 2025
83f7576
compiler: remove reexports from rustc_target::callconv
workingjubilee Feb 5, 2025
180f350
Rustfmt
bjorn3 Feb 8, 2025
01f1025
Rollup merge of #136706 - workingjubilee:finish-up-rustc-abi-updates,…
workingjubilee Feb 9, 2025
5bf05c1
Auto merge of #136751 - bjorn3:update_rustfmt, r=Mark-Simulacrum
bors Feb 9, 2025
65da92e
cg_gcc: stop caring about compiling for unknown targets
workingjubilee Feb 10, 2025
d7f2227
compiler/rustc_codegen_gcc/src/back/lto.rs: delete "unsafe impl Sync/…
safinaskar Feb 11, 2025
feb78f9
Implement and use BikeshedGuaranteedNoDrop for union/unsafe field val…
compiler-errors Feb 6, 2025
853ae3d
Rollup merge of #136858 - safinaskar:parallel-cleanup-2025-02-11-07-5…
jhpratt Feb 13, 2025
fd526a2
Make `-O` mean `-C opt-level=3`
clubby789 Jan 13, 2025
5e0c773
Set both `nuw` and `nsw` in slice size calculation
scottmcm Feb 5, 2025
5e0f1f6
Auto merge of #136575 - scottmcm:nsuw-math, r=nikic
bors Feb 14, 2025
51911a7
Emit `trunc nuw` for unchecked shifts and `to_immediate_scalar`
scottmcm Feb 15, 2025
9ebb68d
Rework `OperandRef::extract_field` to stop calling `to_immediate_scal…
scottmcm Feb 16, 2025
be63572
Remove `BackendRepr::Uninhabited`, replaced with an `uninhabited: boo…
zachs18 Jan 26, 2025
aa038c2
Add `new_regular` and `new_allocator` to `ModuleCodegen`
dianqk Feb 6, 2025
9b8701d
Save pre-link bitcode to `ModuleCodegen`
dianqk Feb 6, 2025
a9e8cfe
Rollup merge of #136543 - RalfJung:round-ties-even, r=tgross35
tgross35 Feb 23, 2025
15f0dca
remove support for rustc_intrinsic_must_be_overridden from the compiler
RalfJung Feb 23, 2025
e92466e
Remove an unnecessary lifetime
oli-obk Feb 24, 2025
71c189a
Generalize BaseTypeCodegenMethods
oli-obk Feb 24, 2025
334eb82
Remove an unused lifetime param
oli-obk Feb 24, 2025
7848145
remove `simd_fpow` and `simd_fpowi`
folkertdev Feb 25, 2025
b627900
Rollup merge of #137595 - folkertdev:remove-simd-pow-powi, r=RalfJung
fmease Feb 25, 2025
7721431
Stop using `hash_raw_entry` in `CodegenCx::const_str`
cuviper Feb 27, 2025
975dee2
rename BackendRepr::Vector → SimdVector
RalfJung Feb 28, 2025
24b202f
Auto merge of #133250 - DianQK:embed-bitcode-pgo, r=nikic
bors Mar 1, 2025
d344960
Rollup merge of #137804 - RalfJung:backend-repr-simd-vector, r=workin…
matthiaskrgr Mar 1, 2025
c25f12a
Revert "Auto merge of #135335 - oli-obk:push-zxwssomxxtnq, r=saethlin"
compiler-errors Mar 2, 2025
fe9feb3
Rollup merge of #137741 - cuviper:const_str-raw_entry, r=Mark-Simulacrum
matthiaskrgr Mar 3, 2025
273fe4a
Rollup merge of #137894 - compiler-errors:no-scalar-pair-opt, r=oli-obk
matthiaskrgr Mar 3, 2025
ab17806
Auto merge of #137959 - matthiaskrgr:rollup-62vjvwr, r=matthiaskrgr
bors Mar 4, 2025
ae07d7d
Simplify `implied_target_features`.
nnethercote Feb 25, 2025
b2b94f4
Change signature of `target_features_cfg`.
nnethercote Feb 25, 2025
24bf404
Rollup merge of #137549 - oli-obk:llvm-ffi, r=davidtwco
matthiaskrgr Mar 7, 2025
70b5888
compiler: Use size_of from the prelude instead of imported
thaliaarchi Mar 5, 2025
454b083
Rollup merge of #138040 - thaliaarchi:use-prelude-size-of.compiler, r…
matthiaskrgr Mar 9, 2025
b802554
Auto merge of #137586 - nnethercote:SetImpliedBits, r=bjorn3
bors Mar 11, 2025
7989568
intrinsics: remove unnecessary leading underscore from argument names
RalfJung Mar 12, 2025
b25a593
Remove implicit #[no_mangle] for #[rustc_std_internal_symbol]
bjorn3 Dec 2, 2023
ed271f8
Merge branch 'master' into sync_from_rust_2025_03_27
antoyo Mar 27, 2025
d728544
Update to nightly-2025-03-27
antoyo Mar 27, 2025
0c38b38
Fix patches
antoyo Mar 27, 2025
a317325
Fix compilation
antoyo Mar 27, 2025
4dfb289
Implement copysignf128
antoyo Mar 27, 2025
7a7bbf2
Remove most of builtins hack since it's not necessary anymore
antoyo Mar 27, 2025
a98cba8
Update other patches
antoyo Mar 27, 2025
7351115
Fix libcore tests
antoyo Mar 27, 2025
1930c41
Fix clippy warnings
antoyo Mar 27, 2025
b0ac7c8
Update GCC version
antoyo Mar 27, 2025
09ef4d3
Fix tests
antoyo Mar 27, 2025
42701cf
Fix int_to_float_cast for f128
antoyo Mar 27, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
28 changes: 1 addition & 27 deletions build_system/src/test.rs
Original file line number Diff line number Diff line change
Expand Up @@ -426,19 +426,6 @@ fn std_tests(env: &Env, args: &TestArg) -> Result<(), String> {
run_command_with_env(&command, None, Some(env))?;
maybe_run_command_in_vm(&[&cargo_target_dir.join("track-caller-attribute")], env, args)?;

// FIXME: create a function "display_if_not_quiet" or something along the line.
println!("[AOT] mod_bench");
let mut command = args.config_info.rustc_command_vec();
command.extend_from_slice(&[
&"example/mod_bench.rs",
&"--crate-type",
&"bin",
&"--target",
&args.config_info.target_triple,
]);
run_command_with_env(&command, None, Some(env))?;
// FIXME: the compiled binary is not run.

Ok(())
}

Expand Down Expand Up @@ -691,25 +678,12 @@ fn test_projects(env: &Env, args: &TestArg) -> Result<(), String> {
fn test_libcore(env: &Env, args: &TestArg) -> Result<(), String> {
// FIXME: create a function "display_if_not_quiet" or something along the line.
println!("[TEST] libcore");
let path = get_sysroot_dir().join("sysroot_src/library/core/tests");
let path = get_sysroot_dir().join("sysroot_src/library/coretests");
let _ = remove_dir_all(path.join("target"));
run_cargo_command(&[&"test"], Some(&path), env, args)?;
Ok(())
}

// echo "[BENCH COMPILE] mod_bench"
//
// COMPILE_MOD_BENCH_INLINE="$RUSTC example/mod_bench.rs --crate-type bin -Zmir-opt-level=3 -O --crate-name mod_bench_inline"
// COMPILE_MOD_BENCH_LLVM_0="rustc example/mod_bench.rs --crate-type bin -Copt-level=0 -o $cargo_target_dir/mod_bench_llvm_0 -Cpanic=abort"
// COMPILE_MOD_BENCH_LLVM_1="rustc example/mod_bench.rs --crate-type bin -Copt-level=1 -o $cargo_target_dir/mod_bench_llvm_1 -Cpanic=abort"
// COMPILE_MOD_BENCH_LLVM_2="rustc example/mod_bench.rs --crate-type bin -Copt-level=2 -o $cargo_target_dir/mod_bench_llvm_2 -Cpanic=abort"
// COMPILE_MOD_BENCH_LLVM_3="rustc example/mod_bench.rs --crate-type bin -Copt-level=3 -o $cargo_target_dir/mod_bench_llvm_3 -Cpanic=abort"
//
// Use 100 runs, because a single compilations doesn't take more than ~150ms, so it isn't very slow
// hyperfine --runs ${COMPILE_RUNS:-100} "$COMPILE_MOD_BENCH_INLINE" "$COMPILE_MOD_BENCH_LLVM_0" "$COMPILE_MOD_BENCH_LLVM_1" "$COMPILE_MOD_BENCH_LLVM_2" "$COMPILE_MOD_BENCH_LLVM_3"
// echo "[BENCH RUN] mod_bench"
// hyperfine --runs ${RUN_RUNS:-10} $cargo_target_dir/mod_bench{,_inline} $cargo_target_dir/mod_bench_llvm_*

fn extended_rand_tests(env: &Env, args: &TestArg) -> Result<(), String> {
if !args.is_using_gcc_master_branch() {
println!("Not using GCC master branch. Skipping `extended_rand_tests`.");
Expand Down
7 changes: 4 additions & 3 deletions example/alloc_example.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
#![feature(start, core_intrinsics, alloc_error_handler, lang_items)]
#![feature(core_intrinsics, alloc_error_handler, lang_items)]
#![no_std]
#![no_main]
#![allow(internal_features)]

extern crate alloc;
Expand Down Expand Up @@ -37,8 +38,8 @@ unsafe extern "C" fn _Unwind_Resume() {
core::intrinsics::unreachable();
}

#[start]
fn main(_argc: isize, _argv: *const *const u8) -> isize {
#[no_mangle]
extern "C" fn main(_argc: core::ffi::c_int, _argv: *const *const u8) -> core::ffi::c_int {
let world: Box<&str> = Box::new("Hello World!\0");
unsafe {
puts(*world as *const str as *const u8);
Expand Down
49 changes: 28 additions & 21 deletions example/mini_core.rs
Original file line number Diff line number Diff line change
Expand Up @@ -58,6 +58,9 @@ trait Receiver {
#[lang = "copy"]
pub trait Copy {}

#[lang = "bikeshed_guaranteed_no_drop"]
pub trait BikeshedGuaranteedNoDrop {}

impl Copy for bool {}
impl Copy for u8 {}
impl Copy for u16 {}
Expand Down Expand Up @@ -135,6 +138,14 @@ impl Mul for u8 {
}
}

impl Mul for i32 {
type Output = Self;

fn mul(self, rhs: Self) -> Self::Output {
self * rhs
}
}

impl Mul for usize {
type Output = Self;

Expand Down Expand Up @@ -245,6 +256,14 @@ impl Sub for i16 {
}
}

impl Sub for i32 {
type Output = Self;

fn sub(self, rhs: Self) -> Self {
self - rhs
}
}

#[lang = "rem"]
pub trait Rem<RHS = Self> {
type Output;
Expand Down Expand Up @@ -617,40 +636,28 @@ pub union MaybeUninit<T> {
pub mod intrinsics {
#[rustc_intrinsic]
pub fn abort() -> !;

#[rustc_intrinsic]
pub fn size_of<T>() -> usize;

#[rustc_intrinsic]
pub unsafe fn size_of_val<T: ?::Sized>(_val: *const T) -> usize;

pub unsafe fn size_of_val<T: ?::Sized>(val: *const T) -> usize;
#[rustc_intrinsic]
pub fn min_align_of<T>() -> usize;

#[rustc_intrinsic]
pub unsafe fn min_align_of_val<T: ?::Sized>(_val: *const T) -> usize;

pub unsafe fn min_align_of_val<T: ?::Sized>(val: *const T) -> usize;
#[rustc_intrinsic]
pub unsafe fn copy<T>(_src: *const T, _dst: *mut T, _count: usize);

pub unsafe fn copy<T>(src: *const T, dst: *mut T, count: usize);
#[rustc_intrinsic]
pub unsafe fn transmute<T, U>(_e: T) -> U;

pub unsafe fn transmute<T, U>(e: T) -> U;
#[rustc_intrinsic]
pub unsafe fn ctlz_nonzero<T>(_x: T) -> u32;

pub unsafe fn ctlz_nonzero<T>(x: T) -> u32;
#[rustc_intrinsic]
pub fn needs_drop<T: ?::Sized>() -> bool;

#[rustc_intrinsic]
pub fn bitreverse<T>(_x: T) -> T;

pub fn bitreverse<T>(x: T) -> T;
#[rustc_intrinsic]
pub fn bswap<T>(_x: T) -> T;

pub fn bswap<T>(x: T) -> T;
#[rustc_intrinsic]
pub unsafe fn write_bytes<T>(_dst: *mut T, _val: u8, _count: usize);

pub unsafe fn write_bytes<T>(dst: *mut T, val: u8, count: usize);
#[rustc_intrinsic]
pub unsafe fn unreachable() -> !;
}
Expand Down Expand Up @@ -694,7 +701,7 @@ impl<T> Index<usize> for [T] {
}
}

extern {
extern "C" {
type VaListImpl;
}

Expand Down
6 changes: 3 additions & 3 deletions example/mini_core_hello_world.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
// Adapted from https://github.com/sunfishcode/mir2cranelift/blob/master/rust-examples/nocore-hello-world.rs

#![feature(
no_core, unboxed_closures, start, lang_items, never_type, linkage,
no_core, unboxed_closures, lang_items, never_type, linkage,
extern_types, thread_local
)]
#![no_core]
Expand Down Expand Up @@ -258,13 +258,13 @@ fn main() {

assert_eq!(((|()| 42u8) as fn(()) -> u8)(()), 42);

extern {
extern "C" {
#[linkage = "weak"]
static ABC: *const u8;
}

{
extern {
extern "C" {
#[linkage = "weak"]
static ABC: *const u8;
}
Expand Down
36 changes: 0 additions & 36 deletions example/mod_bench.rs

This file was deleted.

2 changes: 1 addition & 1 deletion example/std_example.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ use std::arch::x86_64::*;
use std::io::Write;
use std::ops::Coroutine;

extern {
extern "C" {
pub fn printf(format: *const i8, ...) -> i32;
}

Expand Down
2 changes: 1 addition & 1 deletion libgccjit.version
Original file line number Diff line number Diff line change
@@ -1 +1 @@
d6f5a708104a98199ac0f01a3b6b279a0f7c66d3
be7a45328b8f3a8e58608bdf0697d940b3e20846
44 changes: 0 additions & 44 deletions patches/0022-core-Disable-not-compiling-tests.patch

This file was deleted.

26 changes: 13 additions & 13 deletions patches/0028-core-Disable-long-running-tests.patch
Original file line number Diff line number Diff line change
@@ -1,32 +1,32 @@
From eb703e627e7a84f1cd8d0d87f0f69da1f0acf765 Mon Sep 17 00:00:00 2001
From: bjorn3 <[email protected].com>
Date: Fri, 3 Dec 2021 12:16:30 +0100
From ec2d0dc77fb484d926b45bb626b0db6a4bb0ab5c Mon Sep 17 00:00:00 2001
From: None <none@example.com>
Date: Thu, 27 Mar 2025 09:20:41 -0400
Subject: [PATCH] Disable long running tests

---
library/core/tests/slice.rs | 2 ++
library/coretests/tests/slice.rs | 2 ++
1 file changed, 2 insertions(+)

diff --git a/library/core/tests/slice.rs b/library/core/tests/slice.rs
index 8402833..84592e0 100644
--- a/library/core/tests/slice.rs
+++ b/library/core/tests/slice.rs
@@ -2462,6 +2462,7 @@ take_tests! {
diff --git a/library/coretests/tests/slice.rs b/library/coretests/tests/slice.rs
index d17e681..fba5cd6 100644
--- a/library/coretests/tests/slice.rs
+++ b/library/coretests/tests/slice.rs
@@ -2486,6 +2486,7 @@ split_off_tests! {
#[cfg(not(miri))] // unused in Miri
const EMPTY_MAX: &'static [()] = &[(); usize::MAX];

+/*
// can't be a constant due to const mutability rules
#[cfg(not(miri))] // unused in Miri
macro_rules! empty_max_mut {
@@ -2485,6 +2486,7 @@ take_tests! {
(take_mut_oob_max_range_to_inclusive, (..=usize::MAX), None, empty_max_mut!()),
(take_mut_in_bounds_max_range_from, (usize::MAX..), Some(&mut [] as _), empty_max_mut!()),
@@ -2509,6 +2510,7 @@ split_off_tests! {
(split_off_mut_oob_max_range_to_inclusive, (..=usize::MAX), None, empty_max_mut!()),
(split_off_mut_in_bounds_max_range_from, (usize::MAX..), Some(&mut [] as _), empty_max_mut!()),
}
+*/

#[test]
fn test_slice_from_ptr_range() {
--
2.26.2.7.g19db9cfb68
2.49.0

18 changes: 10 additions & 8 deletions patches/cross_patches/0001-Disable-libstd-and-libtest-dylib.patch
Original file line number Diff line number Diff line change
@@ -1,23 +1,25 @@
From 966beefe08be6045bfcca26079b76a7a80413080 Mon Sep 17 00:00:00 2001
From b2911e732d1bf0e28872495c4c47af1dad3c7911 Mon Sep 17 00:00:00 2001
From: None <[email protected]>
Date: Thu, 28 Sep 2023 17:37:38 -0400
Date: Thu, 27 Mar 2025 14:30:10 -0400
Subject: [PATCH] Disable libstd and libtest dylib

---
library/std/Cargo.toml | 2 +-
library/test/Cargo.toml | 2 +-
2 files changed, 2 insertions(+), 2 deletions(-)
library/std/Cargo.toml | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/library/std/Cargo.toml b/library/std/Cargo.toml
index 5b21355..cb0c49b 100644
index 176da60..c183cdb 100644
--- a/library/std/Cargo.toml
+++ b/library/std/Cargo.toml
@@ -9,7 +9,7 @@ description = "The Rust Standard Library"
edition = "2021"
@@ -10,7 +10,7 @@ edition = "2024"
autobenches = false

[lib]
-crate-type = ["dylib", "rlib"]
+crate-type = ["rlib"]

[dependencies]
alloc = { path = "../alloc", public = true }
--
2.49.0

Loading
Loading