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

subtree update cg_gcc 2023/10/25 #117253

Merged
merged 48 commits into from
Oct 28, 2023
Merged
Show file tree
Hide file tree
Changes from 13 commits
Commits
Show all changes
48 commits
Select commit Hold shift + click to select a range
242a482
Merge commit '11a0cceab966e5ff1058ddbcab5977e8a1d6d290' into subtree-…
antoyo Oct 9, 2023
22e6f6c
Fix checks
antoyo Oct 9, 2023
ba103e3
Use IntoDynSyncSend
antoyo Oct 9, 2023
cf8c391
Add comment
antoyo Oct 10, 2023
9030b70
Update libgccjit
antoyo Oct 11, 2023
100dfce
Fix #[inline(always)] attribute
antoyo Oct 12, 2023
e3998b2
Handle unsigned comparison for signed integers
antoyo Oct 12, 2023
e1cb818
docs: add Rust logo to more compiler crates
notriddle Oct 16, 2023
e2f32c7
Ignore failing test
antoyo Oct 17, 2023
4dce75f
Merge pull request #352 from rust-lang/update-libgccjit
antoyo Oct 17, 2023
096f14d
Add support for NonNull function attribute
GuillaumeGomez Sep 4, 2023
0348a5f
Improve code readability
GuillaumeGomez Oct 17, 2023
64abf58
optimize popcount implementation
sadlerap Oct 6, 2023
c80fb4a
Merge pull request #326 from GuillaumeGomez/non-null
antoyo Oct 17, 2023
fabdc1a
Merge pull request #348 from sadlerap/optimize-popcount
antoyo Oct 18, 2023
e5fa9f8
Use the correct alignment for integer types
antoyo Oct 7, 2023
9d5e0ba
Fixes including fixing compilation for --no-default-features
antoyo Oct 17, 2023
d64662f
Merge pull request #353 from rust-lang/fix/int-types-alignment
antoyo Oct 18, 2023
99bc37e
Refactor CI scripts to have a different file for libgccjit 12
antoyo May 22, 2023
c7679c4
Revome llvm-14-tools from failures CI
antoyo Oct 18, 2023
a9f31ab
Merge pull request #355 from rust-lang/refactor-ci
antoyo Oct 19, 2023
81c1f39
optimize u128/i128 popcounts further
sadlerap Oct 18, 2023
2096606
Merge pull request #354 from sadlerap/popcount-128-bits
antoyo Oct 19, 2023
67b28ac
s/Generator/Coroutine/
oli-obk Oct 19, 2023
a690467
s/generator/coroutine/
oli-obk Oct 19, 2023
7425c56
Add comment
antoyo Sep 6, 2023
16b3da8
Merge pull request #346 from rust-lang/fix/endianness
antoyo Oct 22, 2023
fcd336b
Add basics for `test` command in build system
GuillaumeGomez Oct 24, 2023
0b6e133
Fix to be able to use a target specification JSON file and document t…
antoyo Oct 24, 2023
46887f2
Merge pull request #364 from rust-lang/doc/target-spec
antoyo Oct 24, 2023
a93d1b7
Fix volatile_load
antoyo Oct 24, 2023
3d9c8af
Merge pull request #365 from rust-lang/fix/volatile-load
antoyo Oct 25, 2023
c15ad9e
Regenerate intrinsics mapping
GuillaumeGomez Oct 25, 2023
783789f
Build the sysroot and run more tests
antoyo Oct 19, 2023
47bac1f
Merge pull request #357 from rust-lang/fix/gcc-12
antoyo Oct 25, 2023
d4a74fb
Merge pull request #363 from GuillaumeGomez/test-command
antoyo Oct 25, 2023
8329a35
Merge pull request #369 from GuillaumeGomez/regen-intrinsics
antoyo Oct 25, 2023
4d66cd8
Merge branch 'master' into sync_from_rust_2023_10_25
antoyo Oct 26, 2023
42e3705
Fix rebase
antoyo Oct 26, 2023
9efb4ce
Update to nightly-2023-10-25
antoyo Oct 26, 2023
c12ac7e
Fix warning
antoyo Oct 26, 2023
2a2b3ea
Remove duplication in CI
antoyo Oct 26, 2023
a6984f5
Fix tests
antoyo Oct 26, 2023
e4fe941
Merge pull request #371 from rust-lang/sync_from_rust_2023_10_25
antoyo Oct 26, 2023
c797ccc
Merge commit 'e4fe941b11a55c5005630696e9b6d81c65f7bd04' into subtree-…
antoyo Oct 26, 2023
eb10fa3
Fix build scripts
GuillaumeGomez Oct 27, 2023
09ce29d
Merge pull request #375 from GuillaumeGomez/fix-build-scripts
antoyo Oct 27, 2023
f0aaf2f
Merge commit '09ce29d0591a21e1abae22eac4d41ffd32993af8' into subtree-…
antoyo Oct 27, 2023
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 Readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -292,7 +292,7 @@ To send the changes to the rust repo:
```bash
cd ../rust
git pull origin master
git checkbout -b subtree-update_cg_gcc_YYYY-MM-DD
git checkout -b subtree-update_cg_gcc_YYYY-MM-DD
PATH="$HOME/bin:$PATH" ~/bin/git-subtree pull --prefix=compiler/rustc_codegen_gcc/ https://github.com/rust-lang/rustc_codegen_gcc.git master
git push
```
Expand Down
4 changes: 2 additions & 2 deletions example/std_example.rs
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
#![feature(core_intrinsics, generators, generator_trait, is_sorted)]
#![feature(core_intrinsics, coroutines, coroutine_trait, is_sorted)]

#[cfg(feature="master")]
#[cfg(target_arch="x86_64")]
use std::arch::x86_64::*;
use std::io::Write;
use std::ops::Generator;
use std::ops::Coroutine;

extern {
pub fn printf(format: *const i8, ...) -> i32;
Expand Down
2 changes: 1 addition & 1 deletion failing-non-lto-tests.txt
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ tests/ui/lto/lto-many-codegen-units.rs
tests/ui/lto/issue-100772.rs
tests/ui/lto/lto-rustc-loads-linker-plugin.rs
tests/ui/panic-runtime/lto-unwind.rs
tests/ui/sanitize/issue-111184-generator-witness.rs
tests/ui/sanitize/issue-111184-coroutine-witness.rs
tests/ui/sepcomp/sepcomp-lib-lto.rs
tests/ui/lto/lto-opt-level-s.rs
tests/ui/lto/lto-opt-level-z.rs
8 changes: 4 additions & 4 deletions failing-ui-tests.txt
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,8 @@ tests/ui/cfg/cfg-panic-abort.rs
tests/ui/drop/dynamic-drop-async.rs
tests/ui/drop/repeat-drop.rs
tests/ui/fmt/format-args-capture.rs
tests/ui/generator/panic-drops-resume.rs
tests/ui/generator/panic-drops.rs
tests/ui/coroutine/panic-drops-resume.rs
tests/ui/coroutine/panic-drops.rs
tests/ui/intrinsics/panic-uninitialized-zeroed.rs
tests/ui/iterators/iter-sum-overflow-debug.rs
tests/ui/iterators/iter-sum-overflow-overflow-checks.rs
Expand Down Expand Up @@ -53,7 +53,7 @@ tests/ui/simd/issue-89193.rs
tests/ui/statics/issue-91050-1.rs
tests/ui/statics/issue-91050-2.rs
tests/ui/alloc-error/default-alloc-error-hook.rs
tests/ui/generator/panic-safe.rs
tests/ui/coroutine/panic-safe.rs
tests/ui/issues/issue-14875.rs
tests/ui/issues/issue-29948.rs
tests/ui/panics/nested_panic_caught.rs
Expand All @@ -70,5 +70,5 @@ tests/ui/lto/lto-thin-rustc-loads-linker-plugin.rs
tests/ui/lto/all-crates.rs
tests/ui/async-await/deep-futures-are-freeze.rs
tests/ui/closures/capture-unsized-by-ref.rs
tests/ui/generator/resume-after-return.rs
tests/ui/coroutine/resume-after-return.rs
tests/ui/macros/rfc-2011-nicer-assert-messages/all-expr-kinds.rs
2 changes: 1 addition & 1 deletion failing-ui-tests12.txt
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ tests/ui/rfcs/rfc-1937-termination-trait/termination-trait-in-test.rs
tests/ui/async-await/async-fn-size-moved-locals.rs
tests/ui/async-await/async-fn-size-uninit-locals.rs
tests/ui/cfg/cfg-panic.rs
tests/ui/generator/size-moved-locals.rs
tests/ui/coroutine/size-moved-locals.rs
tests/ui/macros/rfc-2011-nicer-assert-messages/all-not-available-cases.rs
tests/ui/simd/intrinsic/generic-gather-pass.rs
tests/ui/simd/issue-85915-simd-ptrs.rs
Expand Down
2 changes: 1 addition & 1 deletion rust-toolchain
Original file line number Diff line number Diff line change
@@ -1,3 +1,3 @@
[toolchain]
channel = "nightly-2023-10-08"
channel = "nightly-2023-10-21"
components = ["rust-src", "rustc-dev", "llvm-tools-preview"]
2 changes: 1 addition & 1 deletion src/base.rs
Original file line number Diff line number Diff line change
Expand Up @@ -121,7 +121,7 @@ pub fn compile_codegen_unit(tcx: TyCtxt<'_>, cgu_name: Symbol, target_info: Lock
// NOTE: Rust relies on LLVM doing wrapping on overflow.
context.add_command_line_option("-fwrapv");

if tcx.sess.opts.cg.relocation_model == Some(rustc_target::spec::RelocModel::Static) {
if tcx.sess.relocation_model() == rustc_target::spec::RelocModel::Static {
context.add_command_line_option("-mcmodel=kernel");
context.add_command_line_option("-fno-pie");
}
Expand Down
23 changes: 17 additions & 6 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,9 @@
* TODO(antoyo): remove the patches.
*/

#![cfg_attr(not(bootstrap), allow(internal_features))]
#![cfg_attr(not(bootstrap), doc(rust_logo))]
#![cfg_attr(not(bootstrap), feature(rustdoc_internals))]
#![feature(
rustc_private,
decl_macro,
Expand Down Expand Up @@ -73,6 +76,7 @@ mod type_;
mod type_of;

use std::any::Any;
use std::fmt::Debug;
use std::sync::Arc;
use std::sync::Mutex;
#[cfg(not(feature="master"))]
Expand All @@ -93,6 +97,7 @@ use rustc_codegen_ssa::back::write::{CodegenContext, FatLtoInput, ModuleConfig,
use rustc_codegen_ssa::back::lto::{LtoModuleCodegen, SerializedModule, ThinModule};
use rustc_codegen_ssa::target_features::supported_target_features;
use rustc_data_structures::fx::FxIndexMap;
use rustc_data_structures::sync::IntoDynSyncSend;
use rustc_codegen_ssa::traits::{CodegenBackend, ExtraBackendMethods, ThinBufferMethods, WriteBackendMethods};
use rustc_errors::{DiagnosticMessage, ErrorGuaranteed, Handler, SubdiagnosticMessage};
use rustc_fluent_macro::fluent_messages;
Expand Down Expand Up @@ -138,9 +143,15 @@ impl TargetInfo {
}
}

#[derive(Clone, Debug)]
#[derive(Clone)]
pub struct LockedTargetInfo {
info: Arc<Mutex<TargetInfo>>,
info: Arc<Mutex<IntoDynSyncSend<TargetInfo>>>,
}

impl Debug for LockedTargetInfo {
fn fmt(&self, formatter: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
self.info.lock().expect("lock").fmt(formatter)
}
}

impl LockedTargetInfo {
Expand Down Expand Up @@ -174,7 +185,7 @@ impl CodegenBackend for GccCodegenBackend {
context.add_command_line_option(&format!("-march={}", target_cpu));
}

*self.target_info.info.lock().expect("lock") = context.get_target_info();
**self.target_info.info.lock().expect("lock") = context.get_target_info();
}

#[cfg(feature="master")]
Expand Down Expand Up @@ -341,12 +352,12 @@ pub fn __rustc_codegen_backend() -> Box<dyn CodegenBackend> {
let info = {
// Check whether the target supports 128-bit integers.
let context = Context::default();
Arc::new(Mutex::new(context.get_target_info()))
Arc::new(Mutex::new(IntoDynSyncSend(context.get_target_info())))
};
#[cfg(not(feature="master"))]
let info = Arc::new(Mutex::new(TargetInfo {
let info = Arc::new(Mutex::new(IntoDynSyncSend(TargetInfo {
supports_128bit_integers: AtomicBool::new(false),
}));
})));

Box::new(GccCodegenBackend {
target_info: LockedTargetInfo { info },
Expand Down
6 changes: 3 additions & 3 deletions src/type_of.rs
Original file line number Diff line number Diff line change
Expand Up @@ -87,7 +87,7 @@ fn uncached_gcc_type<'gcc, 'tcx>(cx: &CodegenCx<'gcc, 'tcx>, layout: TyAndLayout
// FIXME(eddyb) producing readable type names for trait objects can result
// in problematically distinct types due to HRTB and subtyping (see #47638).
// ty::Dynamic(..) |
ty::Adt(..) | ty::Closure(..) | ty::Foreign(..) | ty::Generator(..) | ty::Str
ty::Adt(..) | ty::Closure(..) | ty::Foreign(..) | ty::Coroutine(..) | ty::Str
if !cx.sess().fewer_names() =>
{
let mut name = with_no_trimmed_paths!(layout.ty.to_string());
Expand All @@ -98,10 +98,10 @@ fn uncached_gcc_type<'gcc, 'tcx>(cx: &CodegenCx<'gcc, 'tcx>, layout: TyAndLayout
write!(&mut name, "::{}", def.variant(index).name).unwrap();
}
}
if let (&ty::Generator(_, _, _), &Variants::Single { index }) =
if let (&ty::Coroutine(_, _, _), &Variants::Single { index }) =
(layout.ty.kind(), &layout.variants)
{
write!(&mut name, "::{}", ty::GeneratorArgs::variant_name(index)).unwrap();
write!(&mut name, "::{}", ty::CoroutineArgs::variant_name(index)).unwrap();
}
Some(name)
}
Expand Down
4 changes: 2 additions & 2 deletions test.sh
Original file line number Diff line number Diff line change
Expand Up @@ -371,10 +371,10 @@ function test_rustc() {

git checkout -- tests/ui/issues/auxiliary/issue-3136-a.rs # contains //~ERROR, but shouldn't be removed

rm -r tests/ui/{abi*,extern/,unsized-locals/,proc-macro/,threads-sendsync/,thinlto/,borrowck/,chalkify/bugs/,test*,consts/const-float-bits-reject-conv.rs,consts/issue-miri-1910.rs} || true
rm -r tests/ui/{abi*,extern/,unsized-locals/,proc-macro/,threads-sendsync/,borrowck/,test*,consts/issue-miri-1910.rs} || true
rm tests/ui/mir/mir_heavy_promoted.rs # this test is oom-killed in the CI.
# Tests generating errors.
rm tests/ui/consts/const-eval/nonnull_as_ref_ub.rs tests/ui/consts/issue-94675.rs
rm tests/ui/consts/issue-94675.rs
for test in $(rg --files-with-matches "thread" tests/ui); do
rm $test
done
Expand Down