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

Rustup #4231

Closed
wants to merge 28 commits into from
Closed

Rustup #4231

Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
5df1e53
Stablize feature `anonymous_pipe`
NobodyXu Mar 1, 2025
0c83f0e
Auto merge of #137278 - heiseish:101210-extra-codegen-tests, r=scottmcm
bors Mar 16, 2025
c5a29ea
Auto merge of #137011 - LuuuXXX:promote-ohos-with-host-tools, r=Amanieu
bors Mar 16, 2025
30aad29
Auto merge of #138363 - beetrees:f16-f128-integer-convert, r=Amanieu
bors Mar 17, 2025
b660b49
replace config.toml to bootstrap.toml in src:tools
Shourya742 Feb 15, 2025
b7eddb8
Rollup merge of #136355 - GuillaumeGomez:proc-macro_add_value_retriev…
jhpratt Mar 17, 2025
0e04d62
Rollup merge of #137621 - Berrysoft:cygwin-std, r=joboet
jhpratt Mar 17, 2025
832fb80
Rollup merge of #137793 - NobodyXu:stablise-annoymous-pipe, r=joshtri…
jhpratt Mar 17, 2025
9b37815
Rollup merge of #138341 - xizheyin:issue-138322, r=joboet
jhpratt Mar 17, 2025
d58ed15
Rollup merge of #138517 - compiler-errors:better-child-capture, r=oli…
jhpratt Mar 17, 2025
90b5d94
Rollup merge of #138584 - atouchet:found, r=jieyouxu
jhpratt Mar 17, 2025
bf8c785
Rollup merge of #138586 - jyn514:doc-register-tool, r=jieyouxu
jhpratt Mar 17, 2025
a28758e
Rollup merge of #138590 - yotamofek:pr/flatten-ifs, r=fmease
jhpratt Mar 17, 2025
7b5f470
Rollup merge of #138592 - onur-ozkan:follow-up-137147, r=Kobzol
jhpratt Mar 17, 2025
cba258d
Auto merge of #138595 - jhpratt:rollup-09pvfzu, r=jhpratt
bors Mar 17, 2025
66e52ee
Fix miri
bjorn3 Jun 30, 2024
f004139
Rollup merge of #133870 - nbdd0121:asm, r=traviscross,nnethercote
matthiaskrgr Mar 17, 2025
d031f26
Rollup merge of #137449 - compiler-errors:control-flow, r=Amanieu,lni…
matthiaskrgr Mar 17, 2025
f6cb318
Rollup merge of #137465 - Zalathar:visit-primary, r=oli-obk
matthiaskrgr Mar 17, 2025
7af2939
Rollup merge of #138349 - 1c3t3a:external-weak-cfi, r=rcvalle
matthiaskrgr Mar 17, 2025
144b07e
Rollup merge of #138412 - cuviper:licenses, r=jieyouxu
matthiaskrgr Mar 17, 2025
778e222
Rollup merge of #138577 - aDotInTheVoid:deprecate-deprecations, r=Gui…
matthiaskrgr Mar 17, 2025
9841bdb
Rollup merge of #138588 - nnethercote:avoid-double-lower_ident, r=com…
matthiaskrgr Mar 17, 2025
7351fd4
Auto merge of #137081 - Shourya742:2025-02-15-change-config.toml-to-b…
bors Mar 17, 2025
cf51081
Auto merge of #138611 - matthiaskrgr:rollup-hmjbqva, r=matthiaskrgr
bors Mar 17, 2025
942cc29
Auto merge of #127173 - bjorn3:mangle_rustc_std_internal_symbol, r=we…
bors Mar 17, 2025
a72da5f
Preparing for merge from rustc
RalfJung Mar 18, 2025
ae3de22
Merge from rustc
RalfJung Mar 18, 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
2 changes: 1 addition & 1 deletion CONTRIBUTING.md
Original file line number Diff line number Diff line change
Expand Up @@ -153,7 +153,7 @@ MIRI_LOG=rustc_mir::interpret=info,miri::stacked_borrows ./miri run tests/pass/v

Note that you will only get `info`, `warn` or `error` messages if you use a prebuilt compiler.
In order to get `debug` and `trace` level messages, you need to build miri with a locally built
compiler that has `debug=true` set in `config.toml`.
compiler that has `debug=true` set in `bootstrap.toml`.

#### Debugging error messages

Expand Down
2 changes: 1 addition & 1 deletion cargo-miri/src/setup.rs
Original file line number Diff line number Diff line change
Expand Up @@ -115,7 +115,7 @@ pub fn setup(
// https://github.com/rust-lang/miri/issues/1421,
// https://github.com/rust-lang/miri/issues/2429). Looks like setting
// `RUSTC_WRAPPER` to the empty string overwrites `build.rustc-wrapper` set via
// `config.toml`.
// `bootstrap.toml`.
command.env("RUSTC_WRAPPER", "");

if show_setup {
Expand Down
2 changes: 1 addition & 1 deletion rust-version
Original file line number Diff line number Diff line change
@@ -1 +1 @@
9f274ba3997030a2b7656755a6810fd26cb709f3
493c38ba371929579fe136df26eccd9516347c7a
1 change: 1 addition & 0 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -71,6 +71,7 @@ extern crate rustc_index;
extern crate rustc_middle;
extern crate rustc_session;
extern crate rustc_span;
extern crate rustc_symbol_mangling;
extern crate rustc_target;
// Linking `rustc_driver` pulls in the required object code as the rest of the rustc crates are
// shipped only as rmeta files.
Expand Down
8 changes: 7 additions & 1 deletion src/shims/extern_static.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
//! Provides the `extern static` that this platform expects.

use rustc_symbol_mangling::mangle_internal_symbol;

use crate::*;

impl<'tcx> MiriMachine<'tcx> {
Expand Down Expand Up @@ -50,7 +52,11 @@ impl<'tcx> MiriMachine<'tcx> {
// "__rust_alloc_error_handler_should_panic"
let val = ecx.tcx.sess.opts.unstable_opts.oom.should_panic();
let val = ImmTy::from_int(val, ecx.machine.layouts.u8);
Self::alloc_extern_static(ecx, "__rust_alloc_error_handler_should_panic", val)?;
Self::alloc_extern_static(
ecx,
&mangle_internal_symbol(*ecx.tcx, "__rust_alloc_error_handler_should_panic"),
val,
)?;

if ecx.target_os_is_unix() {
// "environ" is mandated by POSIX.
Expand Down
50 changes: 32 additions & 18 deletions src/shims/foreign_items.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ use rustc_middle::mir::interpret::AllocInit;
use rustc_middle::ty::Ty;
use rustc_middle::{mir, ty};
use rustc_span::Symbol;
use rustc_symbol_mangling::mangle_internal_symbol;
use rustc_target::callconv::{Conv, FnAbi};

use self::helpers::{ToHost, ToSoft};
Expand Down Expand Up @@ -51,17 +52,18 @@ pub trait EvalContextExt<'tcx>: crate::MiriInterpCxExt<'tcx> {

// Some shims forward to other MIR bodies.
match link_name.as_str() {
"__rust_alloc_error_handler" => {
name if name == mangle_internal_symbol(*this.tcx, "__rust_alloc_error_handler") => {
// Forward to the right symbol that implements this function.
let Some(handler_kind) = this.tcx.alloc_error_handler_kind(()) else {
// in real code, this symbol does not exist without an allocator
throw_unsup_format!(
"`__rust_alloc_error_handler` cannot be called when no alloc error handler is set"
);
};
let name = alloc_error_handler_name(handler_kind);
let name =
mangle_internal_symbol(*this.tcx, alloc_error_handler_name(handler_kind));
let handler = this
.lookup_exported_symbol(Symbol::intern(name))?
.lookup_exported_symbol(Symbol::intern(&name))?
.expect("missing alloc error handler symbol");
return interp_ok(Some(handler));
}
Expand Down Expand Up @@ -136,15 +138,29 @@ pub trait EvalContextExt<'tcx>: crate::MiriInterpCxExt<'tcx> {
// Find it if it was not cached.
let mut instance_and_crate: Option<(ty::Instance<'_>, CrateNum)> = None;
helpers::iter_exported_symbols(tcx, |cnum, def_id| {
if tcx.is_foreign_item(def_id) {
// Skip over imports of items
return interp_ok(());
}

let attrs = tcx.codegen_fn_attrs(def_id);
// FIXME use tcx.symbol_name(instance) instead
let symbol_name = if let Some(export_name) = attrs.export_name {
export_name
} else if attrs.flags.contains(CodegenFnAttrFlags::NO_MANGLE) {
} else if attrs.flags.contains(CodegenFnAttrFlags::NO_MANGLE)
|| attrs.flags.contains(CodegenFnAttrFlags::RUSTC_STD_INTERNAL_SYMBOL)
{
tcx.item_name(def_id)
} else {
// Skip over items without an explicitly defined symbol name.
return interp_ok(());
};
let symbol_name =
if attrs.flags.contains(CodegenFnAttrFlags::RUSTC_STD_INTERNAL_SYMBOL) {
Symbol::intern(&mangle_internal_symbol(tcx, symbol_name.as_str()))
} else {
symbol_name
};
if symbol_name == link_name {
if let Some((original_instance, original_cnum)) = instance_and_crate {
// Make sure we are consistent wrt what is 'first' and 'second'.
Expand Down Expand Up @@ -489,7 +505,9 @@ trait EvalContextExtPriv<'tcx>: crate::MiriInterpCxExt<'tcx> {
}

// Rust allocation
"__rust_alloc" | "miri_alloc" => {
name if name == mangle_internal_symbol(*this.tcx, "__rust_alloc")
|| name == "miri_alloc" =>
{
let default = |ecx: &mut MiriInterpCx<'tcx>| {
// Only call `check_shim` when `#[global_allocator]` isn't used. When that
// macro is used, we act like no shim exists, so that the exported function can run.
Expand All @@ -500,9 +518,8 @@ trait EvalContextExtPriv<'tcx>: crate::MiriInterpCxExt<'tcx> {
ecx.check_rustc_alloc_request(size, align)?;

let memory_kind = match link_name.as_str() {
"__rust_alloc" => MiriMemoryKind::Rust,
"miri_alloc" => MiriMemoryKind::Miri,
_ => unreachable!(),
_ => MiriMemoryKind::Rust,
};

let ptr = ecx.allocate_ptr(
Expand All @@ -516,15 +533,14 @@ trait EvalContextExtPriv<'tcx>: crate::MiriInterpCxExt<'tcx> {
};

match link_name.as_str() {
"__rust_alloc" => return this.emulate_allocator(default),
"miri_alloc" => {
default(this)?;
return interp_ok(EmulateItemResult::NeedsReturn);
}
_ => unreachable!(),
_ => return this.emulate_allocator(default),
}
}
"__rust_alloc_zeroed" => {
name if name == mangle_internal_symbol(*this.tcx, "__rust_alloc_zeroed") => {
return this.emulate_allocator(|this| {
// See the comment for `__rust_alloc` why `check_shim` is only called in the
// default case.
Expand All @@ -543,7 +559,9 @@ trait EvalContextExtPriv<'tcx>: crate::MiriInterpCxExt<'tcx> {
this.write_pointer(ptr, dest)
});
}
"__rust_dealloc" | "miri_dealloc" => {
name if name == mangle_internal_symbol(*this.tcx, "__rust_dealloc")
|| name == "miri_dealloc" =>
{
let default = |ecx: &mut MiriInterpCx<'tcx>| {
// See the comment for `__rust_alloc` why `check_shim` is only called in the
// default case.
Expand All @@ -554,9 +572,8 @@ trait EvalContextExtPriv<'tcx>: crate::MiriInterpCxExt<'tcx> {
let align = ecx.read_target_usize(align)?;

let memory_kind = match link_name.as_str() {
"__rust_dealloc" => MiriMemoryKind::Rust,
"miri_dealloc" => MiriMemoryKind::Miri,
_ => unreachable!(),
_ => MiriMemoryKind::Rust,
};

// No need to check old_size/align; we anyway check that they match the allocation.
Expand All @@ -568,17 +585,14 @@ trait EvalContextExtPriv<'tcx>: crate::MiriInterpCxExt<'tcx> {
};

match link_name.as_str() {
"__rust_dealloc" => {
return this.emulate_allocator(default);
}
"miri_dealloc" => {
default(this)?;
return interp_ok(EmulateItemResult::NeedsReturn);
}
_ => unreachable!(),
_ => return this.emulate_allocator(default),
}
}
"__rust_realloc" => {
name if name == mangle_internal_symbol(*this.tcx, "__rust_realloc") => {
return this.emulate_allocator(|this| {
// See the comment for `__rust_alloc` why `check_shim` is only called in the
// default case.
Expand Down
3 changes: 3 additions & 0 deletions tests/fail/alloc/too_large.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,7 @@
#![feature(rustc_attrs)]

extern "Rust" {
#[rustc_std_internal_symbol]
fn __rust_alloc(size: usize, align: usize) -> *mut u8;
}

Expand Down
3 changes: 3 additions & 0 deletions tests/fail/alloc/unsupported_big_alignment.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,10 @@
// because rustc does not support alignments that large.
// https://github.com/rust-lang/miri/issues/3687

#![feature(rustc_attrs)]

extern "Rust" {
#[rustc_std_internal_symbol]
fn __rust_alloc(size: usize, align: usize) -> *mut u8;
}

Expand Down
4 changes: 4 additions & 0 deletions tests/fail/alloc/unsupported_non_power_two_alignment.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
// Test non-power-of-two alignment.

#![feature(rustc_attrs)]

extern "Rust" {
#[rustc_std_internal_symbol]
fn __rust_alloc(size: usize, align: usize) -> *mut u8;
}

Expand Down
3 changes: 3 additions & 0 deletions tests/fail/data_race/dealloc_read_race1.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@
// Avoid accidental synchronization via address reuse inside `thread::spawn`.
//@compile-flags: -Zmiri-address-reuse-cross-thread-rate=0

#![feature(rustc_attrs)]

use std::thread::spawn;

#[derive(Copy, Clone)]
Expand All @@ -12,6 +14,7 @@ unsafe impl<T> Send for EvilSend<T> {}
unsafe impl<T> Sync for EvilSend<T> {}

extern "Rust" {
#[rustc_std_internal_symbol]
fn __rust_dealloc(ptr: *mut u8, size: usize, align: usize);
}

Expand Down
3 changes: 3 additions & 0 deletions tests/fail/data_race/dealloc_read_race2.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@
// Avoid accidental synchronization via address reuse inside `thread::spawn`.
//@compile-flags: -Zmiri-address-reuse-cross-thread-rate=0

#![feature(rustc_attrs)]

use std::thread::spawn;

#[derive(Copy, Clone)]
Expand All @@ -12,6 +14,7 @@ unsafe impl<T> Send for EvilSend<T> {}
unsafe impl<T> Sync for EvilSend<T> {}

extern "Rust" {
#[rustc_std_internal_symbol]
fn __rust_dealloc(ptr: *mut u8, size: usize, align: usize);
}

Expand Down
3 changes: 3 additions & 0 deletions tests/fail/data_race/dealloc_write_race1.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@
// Avoid accidental synchronization via address reuse inside `thread::spawn`.
//@compile-flags: -Zmiri-address-reuse-cross-thread-rate=0

#![feature(rustc_attrs)]

use std::thread::spawn;

#[derive(Copy, Clone)]
Expand All @@ -12,6 +14,7 @@ unsafe impl<T> Send for EvilSend<T> {}
unsafe impl<T> Sync for EvilSend<T> {}

extern "Rust" {
#[rustc_std_internal_symbol]
fn __rust_dealloc(ptr: *mut u8, size: usize, align: usize);
}
pub fn main() {
Expand Down
3 changes: 3 additions & 0 deletions tests/fail/data_race/dealloc_write_race2.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@
// Avoid accidental synchronization via address reuse inside `thread::spawn`.
//@compile-flags: -Zmiri-address-reuse-cross-thread-rate=0

#![feature(rustc_attrs)]

use std::thread::spawn;

#[derive(Copy, Clone)]
Expand All @@ -12,6 +14,7 @@ unsafe impl<T> Send for EvilSend<T> {}
unsafe impl<T> Sync for EvilSend<T> {}

extern "Rust" {
#[rustc_std_internal_symbol]
fn __rust_dealloc(ptr: *mut u8, size: usize, align: usize);
}
pub fn main() {
Expand Down
2 changes: 2 additions & 0 deletions tests/pass/function_calls/exported_symbol.rs
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,7 @@ fn main() {

extern "Rust" {
fn bar() -> i32;
#[rustc_std_internal_symbol]
fn baz() -> i32;
fn qux() -> i32;
}
Expand All @@ -63,6 +64,7 @@ fn main() {

extern "C" {
fn bar() -> i32;
#[rustc_std_internal_symbol]
fn baz() -> i32;
fn qux() -> i32;
}
Expand Down
2 changes: 0 additions & 2 deletions tests/pass/shims/pipe.rs
Original file line number Diff line number Diff line change
@@ -1,7 +1,5 @@
//@ignore-target: windows

#![feature(anonymous_pipe)]

use std::io::{Read, Write, pipe};

fn main() {
Expand Down
Loading