Skip to content

Commit 72df778

Browse files
Rollup merge of #132574 - workingjubilee:abi-in-compiler, r=compiler-errors
compiler: Directly use rustc_abi almost everywhere Use rustc_abi instead of rustc_target where applicable. This is mostly described by the following substitutions: ```rust match path_substring { rustc_target::spec::abi::Abi => rustc_abi::ExternAbi, rustc_target::abi::call => rustc_target::callconv, rustc_target::abi => rustc_abi, } ``` A number of spot-fixes make that not quite the whole story. The main exception is in 33edc68 where I get a lot more persnickety about how things are imported, especially in `rustc_middle::ty::layout`, not just from where. This includes putting an end to a reexport of `rustc_middle::ty::ReprOptions`, for the same reason that the rest of this change is happening: reexports mostly confound things. This notably omits rustc_passes and the ast crates, as I'm still examining a question I have about how they do stability checking of `extern "Abi"` strings and if I can simplify their logic. The rustc_abi and rustc_target crates also go untouched because they will be entangled in that cleanup. r? compiler-errors
2 parents 1505997 + fa20473 commit 72df778

File tree

141 files changed

+363
-385
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

141 files changed

+363
-385
lines changed

Cargo.lock

Lines changed: 0 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -4093,7 +4093,6 @@ dependencies = [
40934093
"rustc_macros",
40944094
"rustc_middle",
40954095
"rustc_span",
4096-
"rustc_target",
40974096
"smallvec",
40984097
"tracing",
40994098
]
@@ -4237,7 +4236,6 @@ dependencies = [
42374236
"rustc_middle",
42384237
"rustc_session",
42394238
"rustc_span",
4240-
"rustc_target",
42414239
"smallvec",
42424240
"tracing",
42434241
"tracing-subscriber",
@@ -4437,7 +4435,6 @@ dependencies = [
44374435
"rustc_middle",
44384436
"rustc_session",
44394437
"rustc_span",
4440-
"rustc_target",
44414438
"tracing",
44424439
]
44434440

compiler/rustc_codegen_llvm/src/abi.rs

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -2,6 +2,7 @@ use std::cmp;
22

33
use libc::c_uint;
44
use rustc_abi as abi;
5+
pub(crate) use rustc_abi::ExternAbi;
56
use rustc_abi::Primitive::Int;
67
use rustc_abi::{HasDataLayout, Size};
78
use rustc_codegen_ssa::MemFlags;
@@ -13,9 +14,8 @@ use rustc_middle::ty::layout::LayoutOf;
1314
pub(crate) use rustc_middle::ty::layout::{WIDE_PTR_ADDR, WIDE_PTR_EXTRA};
1415
use rustc_middle::{bug, ty};
1516
use rustc_session::config;
16-
pub(crate) use rustc_target::abi::call::*;
17+
pub(crate) use rustc_target::callconv::*;
1718
use rustc_target::spec::SanitizerSet;
18-
pub(crate) use rustc_target::spec::abi::Abi;
1919
use smallvec::SmallVec;
2020

2121
use crate::attributes::llfn_attrs_from_instance;
@@ -436,7 +436,7 @@ impl<'ll, 'tcx> FnAbiLlvmExt<'ll, 'tcx> for FnAbi<'tcx, Ty<'tcx>> {
436436
i - 1
437437
};
438438

439-
let apply_range_attr = |idx: AttributePlace, scalar: rustc_target::abi::Scalar| {
439+
let apply_range_attr = |idx: AttributePlace, scalar: rustc_abi::Scalar| {
440440
if cx.sess().opts.optimize != config::OptLevel::No
441441
&& llvm_util::get_version() >= (19, 0, 0)
442442
&& matches!(scalar.primitive(), Int(..))

compiler/rustc_codegen_llvm/src/asm.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,7 @@
11
use std::assert_matches::assert_matches;
22

33
use libc::{c_char, c_uint};
4+
use rustc_abi::{BackendRepr, Float, Integer, Primitive, Scalar};
45
use rustc_ast::{InlineAsmOptions, InlineAsmTemplatePiece};
56
use rustc_codegen_ssa::mir::operand::OperandValue;
67
use rustc_codegen_ssa::traits::*;
@@ -9,7 +10,6 @@ use rustc_middle::ty::Instance;
910
use rustc_middle::ty::layout::TyAndLayout;
1011
use rustc_middle::{bug, span_bug};
1112
use rustc_span::{Pos, Span, Symbol, sym};
12-
use rustc_target::abi::*;
1313
use rustc_target::asm::*;
1414
use smallvec::SmallVec;
1515
use tracing::debug;

compiler/rustc_codegen_llvm/src/builder.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -21,7 +21,7 @@ use rustc_middle::ty::{self, Instance, Ty, TyCtxt};
2121
use rustc_sanitizers::{cfi, kcfi};
2222
use rustc_session::config::OptLevel;
2323
use rustc_span::Span;
24-
use rustc_target::abi::call::FnAbi;
24+
use rustc_target::callconv::FnAbi;
2525
use rustc_target::spec::{HasTargetSpec, SanitizerSet, Target};
2626
use smallvec::SmallVec;
2727
use tracing::{debug, instrument};

compiler/rustc_codegen_llvm/src/consts.rs

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,8 @@
11
use std::ops::Range;
22

3+
use rustc_abi::{
4+
Align, AlignFromBytesError, HasDataLayout, Primitive, Scalar, Size, WrappingRange,
5+
};
36
use rustc_codegen_ssa::common;
47
use rustc_codegen_ssa::traits::*;
58
use rustc_hir::def::DefKind;
@@ -14,9 +17,6 @@ use rustc_middle::ty::layout::LayoutOf;
1417
use rustc_middle::ty::{self, Instance};
1518
use rustc_middle::{bug, span_bug};
1619
use rustc_session::config::Lto;
17-
use rustc_target::abi::{
18-
Align, AlignFromBytesError, HasDataLayout, Primitive, Scalar, Size, WrappingRange,
19-
};
2020
use tracing::{debug, instrument, trace};
2121

2222
use crate::common::{AsCCharPtr, CodegenCx};

compiler/rustc_codegen_llvm/src/context.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -3,6 +3,7 @@ use std::cell::{Cell, RefCell};
33
use std::ffi::{CStr, c_uint};
44
use std::str;
55

6+
use rustc_abi::{HasDataLayout, TargetDataLayout, VariantIdx};
67
use rustc_codegen_ssa::back::versioned_llvm_target;
78
use rustc_codegen_ssa::base::{wants_msvc_seh, wants_wasm_eh};
89
use rustc_codegen_ssa::errors as ssa_errors;
@@ -24,7 +25,6 @@ use rustc_session::config::{
2425
};
2526
use rustc_span::source_map::Spanned;
2627
use rustc_span::{DUMMY_SP, Span};
27-
use rustc_target::abi::{HasDataLayout, TargetDataLayout, VariantIdx};
2828
use rustc_target::spec::{HasTargetSpec, RelocModel, SmallDataThresholdSupport, Target, TlsModel};
2929
use smallvec::SmallVec;
3030

compiler/rustc_codegen_llvm/src/coverageinfo/mod.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2,6 +2,7 @@ use std::cell::{OnceCell, RefCell};
22
use std::ffi::{CStr, CString};
33

44
use libc::c_uint;
5+
use rustc_abi::Size;
56
use rustc_codegen_ssa::traits::{
67
BuilderMethods, ConstCodegenMethods, CoverageInfoBuilderMethods, MiscCodegenMethods,
78
};
@@ -10,7 +11,6 @@ use rustc_llvm::RustString;
1011
use rustc_middle::mir::coverage::CoverageKind;
1112
use rustc_middle::ty::Instance;
1213
use rustc_middle::ty::layout::HasTyCtxt;
13-
use rustc_target::abi::Size;
1414
use tracing::{debug, instrument};
1515

1616
use crate::builder::Builder;

compiler/rustc_codegen_llvm/src/debuginfo/metadata.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -5,6 +5,7 @@ use std::path::{Path, PathBuf};
55
use std::{iter, ptr};
66

77
use libc::{c_char, c_longlong, c_uint};
8+
use rustc_abi::{Align, Size};
89
use rustc_codegen_ssa::debuginfo::type_names::{VTableNameKind, cpp_like_debuginfo};
910
use rustc_codegen_ssa::traits::*;
1011
use rustc_hir::def::{CtorKind, DefKind};
@@ -19,7 +20,6 @@ use rustc_session::config::{self, DebugInfo, Lto};
1920
use rustc_span::symbol::Symbol;
2021
use rustc_span::{DUMMY_SP, FileName, FileNameDisplayPreference, SourceFile, hygiene};
2122
use rustc_symbol_mangling::typeid_for_trait_ref;
22-
use rustc_target::abi::{Align, Size};
2323
use rustc_target::spec::DebuginfoKind;
2424
use smallvec::smallvec;
2525
use tracing::{debug, instrument};

compiler/rustc_codegen_llvm/src/debuginfo/metadata/enums/cpp_like.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,14 +1,14 @@
11
use std::borrow::Cow;
22

33
use libc::c_uint;
4+
use rustc_abi::{Align, Endian, Size, TagEncoding, VariantIdx, Variants};
45
use rustc_codegen_ssa::debuginfo::type_names::compute_debuginfo_type_name;
56
use rustc_codegen_ssa::debuginfo::{tag_base_type, wants_c_like_enum_debuginfo};
67
use rustc_codegen_ssa::traits::ConstCodegenMethods;
78
use rustc_index::IndexVec;
89
use rustc_middle::bug;
910
use rustc_middle::ty::layout::{LayoutOf, TyAndLayout};
1011
use rustc_middle::ty::{self, AdtDef, CoroutineArgs, CoroutineArgsExt, Ty};
11-
use rustc_target::abi::{Align, Endian, Size, TagEncoding, VariantIdx, Variants};
1212
use smallvec::smallvec;
1313

1414
use crate::common::{AsCCharPtr, CodegenCx};

compiler/rustc_codegen_llvm/src/debuginfo/metadata/enums/mod.rs

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,6 @@
11
use std::borrow::Cow;
22

3+
use rustc_abi::{FieldIdx, TagEncoding, VariantIdx, Variants};
34
use rustc_codegen_ssa::debuginfo::type_names::{compute_debuginfo_type_name, cpp_like_debuginfo};
45
use rustc_codegen_ssa::debuginfo::{tag_base_type, wants_c_like_enum_debuginfo};
56
use rustc_hir::def::CtorKind;
@@ -9,7 +10,6 @@ use rustc_middle::mir::CoroutineLayout;
910
use rustc_middle::ty::layout::{LayoutOf, TyAndLayout};
1011
use rustc_middle::ty::{self, AdtDef, CoroutineArgs, CoroutineArgsExt, Ty, VariantDef};
1112
use rustc_span::Symbol;
12-
use rustc_target::abi::{FieldIdx, TagEncoding, VariantIdx, Variants};
1313

1414
use super::type_map::{DINodeCreationResult, UniqueTypeId};
1515
use super::{SmallVec, size_and_align_of};

0 commit comments

Comments
 (0)