mirror of
https://github.com/rust-lang/rust.git
synced 2024-11-22 14:55:26 +00:00
rewrite and rename issue-46239
This commit is contained in:
parent
ddba1dc97e
commit
ddb81ce680
@ -64,6 +64,12 @@ impl Rustc {
|
||||
self
|
||||
}
|
||||
|
||||
/// Specify a specific optimization level.
|
||||
pub fn opt_level(&mut self, option: &str) -> &mut Self {
|
||||
self.cmd.arg(format!("-Copt-level={option}"));
|
||||
self
|
||||
}
|
||||
|
||||
/// Specify type(s) of output files to generate.
|
||||
pub fn emit(&mut self, kinds: &str) -> &mut Self {
|
||||
self.cmd.arg(format!("--emit={kinds}"));
|
||||
|
@ -112,7 +112,6 @@ run-make/issue-37839/Makefile
|
||||
run-make/issue-37893/Makefile
|
||||
run-make/issue-38237/Makefile
|
||||
run-make/issue-40535/Makefile
|
||||
run-make/issue-46239/Makefile
|
||||
run-make/issue-47384/Makefile
|
||||
run-make/issue-47551/Makefile
|
||||
run-make/issue-51671/Makefile
|
||||
|
21
tests/codegen/noalias-freeze.rs
Normal file
21
tests/codegen/noalias-freeze.rs
Normal file
@ -0,0 +1,21 @@
|
||||
//@ compile-flags: -Copt-level=1
|
||||
|
||||
// References returned by a Frozen pointer type
|
||||
// could be marked as "noalias", which caused miscompilation errors.
|
||||
// This test runs the most minimal possible code that can reproduce this bug,
|
||||
// and checks that noalias does not appear.
|
||||
// See https://github.com/rust-lang/rust/issues/46239
|
||||
|
||||
#![crate_type = "lib"]
|
||||
|
||||
fn project<T>(x: &(T,)) -> &T { &x.0 }
|
||||
|
||||
fn dummy() {}
|
||||
|
||||
// CHECK-LABEL: @foo(
|
||||
// CHECK-NOT: noalias
|
||||
#[no_mangle]
|
||||
pub fn foo() {
|
||||
let f = (dummy as fn(),);
|
||||
(*project(&f))();
|
||||
}
|
@ -1,6 +0,0 @@
|
||||
# ignore-cross-compile
|
||||
include ../tools.mk
|
||||
|
||||
all:
|
||||
$(RUSTC) main.rs -C opt-level=1
|
||||
$(call RUN,main)
|
@ -1,8 +0,0 @@
|
||||
fn project<T>(x: &(T,)) -> &T { &x.0 }
|
||||
|
||||
fn dummy() {}
|
||||
|
||||
fn main() {
|
||||
let f = (dummy as fn(),);
|
||||
(*project(&f))();
|
||||
}
|
Loading…
Reference in New Issue
Block a user