Initial support for riscv32{e|em|emc}_unknown_none_elf by hegza · Pull Request #130555 · rust-lang/rust (original) (raw)
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 andprivacy statement. We’ll occasionally send you account related emails.
Already on GitHub?Sign in to your account
Conversation55 Commits8 Checks6 Files changed
Conversation
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.Learn more about bidirectional Unicode characters
[ Show hidden characters]({{ revealButtonHref }})
We have a research prototype of an RV32EMC target and have been successfully running the e, em, emc programs on it. I'm hoping upstreaming this configuration would make the target maintenance slightly easier.
Configuration is based on the respective {i, im, imc} variants. As defined in RISC-V Unprivileged Spec. 20191213, the only change in RVE wrt. RVI is to reduce the number of integer registers to 16 (x0-x15), which also implies
- 2 callee saved registers instead of 12
- 32-bit / 4-byte stack alignment instead of 128 bits / 16 bytes
My initial presumption is that this will not impact how the target is defined for the compiler but only becomes relevant at the runtime level. I am willing to investigate, though.
EDIT: LLVM is now told about the presumed 32-bit stack alignment.
Thanks for the pull request, and welcome! The Rust team is excited to review your changes, and you should hear from @nnethercote (or someone else) some time within the next two weeks.
Please see the contribution instructions for more information. Namely, in order to ensure the minimum review times lag, PR authors and assigned reviewers should ensure that the review label (S-waiting-on-review
and S-waiting-on-author
) stays updated, invoking these commands when appropriate:
@rustbot author
: the review is finished, PR author should check the comments and take action accordingly@rustbot review
: the author is ready for a review, this PR will be queued again in the reviewer's queue
rustbot added S-waiting-on-review
Status: Awaiting review from the assignee but also interested parties.
Relevant to the bootstrap subteam: Rust's build system (x.py and src/bootstrap)
Relevant to the compiler team, which will review and decide on the PR/issue.
labels
Some changes occurred in src/doc/rustc/src/platform-support
cc @Noratrieb
These commits modify compiler targets.
(See the Target Tier Policy.)
This comment has been minimized.
error: data-layout for target
riscv32e-unknown-none-elf
,e-m:e-p:32:32-i64:64-n32-S32
, differs from LLVM target'sriscv32
default layout,e-m:e-p:32:32-i64:64-n32-S128
Apparently this test case wants the stack to be 128-bit aligned as is the default behavior on RISC-V. I revert back to 128-bit stack alignment to respect the test case.
@hegza Can you write a test that uses asm!
and verifies that trying to use the invalid-to-address registers on rv32e is an error? Or do we already have that? Just so that, you know, we can confirm we're probably not generating wildly incorrect code.
@hegza Can you look into what this "assembly-based tools only" means? https://github.com/llvm/llvm-project/blob/8c3b94f420a20a45dd07f3e12d6a6d649858f452/llvm/docs/RISCVUsage.rst#base-isas
Apparently this test case wants the stack to be 128-bit aligned as is the default behavior on RISC-V. I revert back to 128-bit stack alignment to respect the test case.
That is probably not what should be happening. That test case is to validate we can at least produce a binary for the target, which has in the past proved surprisingly challenging for some direly under-maintained targets. You are instead running into an internal assertion to guarantee we match LLVM's data layout. But that's not the correct layout for the target if it is demanding a 16-byte stack. What is LLVM's data layout string for RISCV32E targets?
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You can find that assertion here if you care to investigate why we might be getting the wrong(?) data layout string:
// Ensure the data-layout values hardcoded remain the defaults. |
---|
{ |
let tm = crate:🔙:write::create_informational_target_machine(tcx.sess, false); |
unsafe { |
llvm::LLVMRustSetDataLayoutFromTargetMachine(llmod, &tm); |
} |
let llvm_data_layout = unsafe { llvm::LLVMGetDataLayoutStr(llmod) }; |
let llvm_data_layout = |
str::from_utf8(unsafe { CStr::from_ptr(llvm_data_layout) }.to_bytes()) |
.expect("got a non-UTF8 data-layout from LLVM"); |
if target_data_layout != llvm_data_layout { |
tcx.dcx().emit_err(crate::errors::MismatchedDataLayout { |
rustc_target: sess.opts.target_triple.to_string().as_str(), |
rustc_layout: target_data_layout.as_str(), |
llvm_target: sess.target.llvm_target.borrow(), |
llvm_layout: llvm_data_layout, |
}); |
} |
} |
pub(crate) fn target() -> Target { |
Target { |
data_layout: "e-m:e-p:32:32-i64:64-n32-S128".into(), |
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We can either fix this to be correct for the RV32E targets...
**Tier: 2** |
Bare-metal target for RISC-V CPUs with the RV32I, RV32IM, RV32IMC, RV32IMAFC and RV32IMAC ISAs. |
**Tier: 3** |
Bare-metal target for RISC-V CPUs with the RV32IMA ISA. |
Bare-metal target for RISC-V CPUs with the RV32IMA, RV32E, RV32EM and RV32EMC ISAs. |
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Or we can add documentation that we don't actually generate code with a 4-byte stack alignment, but rather to a 16-byte stack alignment, which is I guess technically acceptable even if it is incorrect.
That's clang's code, not LLVM.
rustbot added S-waiting-on-author
Status: This is awaiting some action (such as code changes or more information) from the author.
and removed S-waiting-on-review
Status: Awaiting review from the assignee but also interested parties.
labels
@hegza Can you look into what this "assembly-based tools only" means? https://github.com/llvm/llvm-project/blob/8c3b94f420a20a45dd07f3e12d6a6d649858f452/llvm/docs/RISCVUsage.rst#base-isas
Seems to be explained later in the same file. I believe that it means that LLVM supports the associated instructions in assembly, including assembler, disassembler, llvm-objdump, etc. Compiler & linker accept the extension and binaries have relevant ELF flags.
I infer that "assembly-based tools only" means the following are not included: C-language intrinsics & pattern matching by the compiler to recognize idiomatic patterns which can be lowered to associated instructions.
They also state specifically about E
:
Support of RV32E/RV64E and ilp32e/lp64e ABIs are experimental. To be compatible with the implementation of ilp32e in GCC, we don't use aligned registers to pass variadic arguments. Furthermore, we set the stack alignment to 4 bytes for types with length of 2*XLEN.
Add rv32e-targets to 'stage0 missing targets'. This prevents the error "no such target exists in the target list".
^ Doing as requested although I'm not 100 % sure what that means. Bors-NG doc says it "records you as the reviewer in the commit log".
Fixups as requested. Rebased to track master & squash fixups.
📌 Commit 6edd0b3 has been approved by workingjubilee
It is now in the queue for this repository.
bors added S-waiting-on-bors
Status: Waiting on bors to run and complete tests. Bors will change the label on completion.
and removed S-waiting-on-author
Status: This is awaiting some action (such as code changes or more information) from the author.
labels
Ah, I see! It has to do with the bors delegate+
. I think I figured it out 😺
bors added a commit to rust-lang-ci/rust that referenced this pull request
…iaskrgr
Rollup of 5 pull requests
Successful merges:
- rust-lang#130555 ( Initial support for riscv32{e|em|emc}_unknown_none_elf)
- rust-lang#131280 (Handle
rustc_interface
cases ofrustc::potential_query_instability
lint) - rust-lang#131281 (make Cell unstably const)
- rust-lang#131285 (clarify semantics of ConstantIndex MIR projection)
- rust-lang#131299 (fix typo in 'lang item with track_caller' message)
r? @ghost
@rustbot
modify labels: rollup
rust-timer added a commit to rust-lang-ci/rust that referenced this pull request
Rollup merge of rust-lang#130555 - hegza:rv32e, r=workingjubilee
Initial support for riscv32{e|em|emc}_unknown_none_elf
We have a research prototype of an RV32EMC target and have been successfully running the e, em, emc programs on it. I'm hoping upstreaming this configuration would make the target maintenance slightly easier.
Configuration is based on the respective {i, im, imc} variants. As defined in RISC-V Unprivileged Spec. 20191213, the only change in RVE wrt. RVI is to reduce the number of integer registers to 16 (x0-x15), which also implies
- 2 callee saved registers instead of 12
- 32-bit / 4-byte stack alignment instead of 128 bits / 16 bytes
My initial presumption is that this will not impact how the target is defined for the compiler but only becomes relevant at the runtime level. I am willing to investigate, though.
EDIT: LLVM is now told about the presumed 32-bit stack alignment.
@Disasm
@romancardenas
Does any of the targets cover RV32EC, as found in CH32V003 series and other ultracheap RV microcontrollers?
Ah, I had heard rumors about this specific E-target already existing in the wild.
No, this target mainly covers the base ISA E
and the EMC
ISA used in our prototype, core. I decided to also include EM
as there's sometimes use for that due to our outdated debug module being unable to handle compressed instructions. The raison d'être for this PR is that we currently tend to need both the newest features from latest Rust and the RV32E backend so after a couple of rather laborious rebases I figured it's easier to maintain this patch in-tree than out-of-tree.
Extension to EC
would be trivial. However, with RISC-V ISA, the extension combinations will probably keep on coming ad nauseam so I'd like to push back adding targets just for completeness sake. I've been maintaining Rust targets for a grand total of one week so I'm not 100 % sure on the best practices here but I think that if you think it's a good idea to add riscv32ec, please open an issue (or a PR) and ping me so we can give an opportunity for comments and build buy-in. I lean on agreeing, as I think it would be good to have the RV32EC target as that is most likely the most common target in the wild.
We are in fact trying to move away from adding more targets and towards a framework for stabilizing a sort of "vertical slice" of -Zbuild-std
aimed at this sort of thing (more like -Zbuild-core
, in effect) precisely because the already-added selection of RISCV targets is frankly, way too many.
So.
Use nightly, use -Zbuild-std
, report bugs, fix them, and none of the targets ever will need to support yonder bespoke RISCV ISA.
workingjubilee added a commit to workingjubilee/rustc that referenced this pull request
…-mislinked, r=tgross35
docs: Correctly link riscv32e from platform-support.md
Correctly link the riscv32e platform support page.
Just a mistake during the iteration of rust-lang#130555 that was missed in review. Presumably the rv32e-none and rv32i-none pages eventually should get merged, but this is a relatively recent addition to the ISA definition so it is not clear the current RISCV Embedded group has the expertise on-hand... nor did it have their consent.
workingjubilee added a commit to workingjubilee/rustc that referenced this pull request
…-mislinked, r=tgross35
docs: Correctly link riscv32e from platform-support.md
Correctly link the riscv32e platform support page.
Just a mistake during the iteration of rust-lang#130555 that was missed in review. Presumably the rv32e-none and rv32i-none pages eventually should get merged, but this is a relatively recent addition to the ISA definition so it is not clear the current RISCV Embedded group has the expertise on-hand... nor did it have their consent.
rust-timer added a commit to rust-lang-ci/rust that referenced this pull request
Rollup merge of rust-lang#132205 - workingjubilee:rv32e-platform-docs-mislinked, r=tgross35
docs: Correctly link riscv32e from platform-support.md
Correctly link the riscv32e platform support page.
Just a mistake during the iteration of rust-lang#130555 that was missed in review. Presumably the rv32e-none and rv32i-none pages eventually should get merged, but this is a relatively recent addition to the ISA definition so it is not clear the current RISCV Embedded group has the expertise on-hand... nor did it have their consent.
Marks issues that should be documented in the release notes of the next release.
label
wip-sync pushed a commit to NetBSD/pkgsrc-wip that referenced this pull request
Pkgsrc changes compared to rust182:
- Remove patches related to rust-lang/rust#130110, which is now integrated upstream.
- Remove patch to vendor/cc-1.0.79, now integrated in the current vendored cc crate.
- Checksum updates.
TODO:
- Cross-compilation fails ref. rust-lang/rust#133629
Upstream changes:
Version 1.83.0 (2024-11-28)
Language
- [Stabilize
&mut
,*mut
,&Cell
, and*const Cell
in const.] (rust-lang/rust#129195) - [Allow creating references to statics in
const
initializers.] (rust-lang/rust#129759) - [Implement raw lifetimes and labels (
'r#ident
).] (rust-lang/rust#126452) - [Define behavior when atomic and non-atomic reads race.] (rust-lang/rust#128778)
- [Non-exhaustive structs may now be empty.] (rust-lang/rust#128934)
- [Disallow implicit coercions from places of type
!
] (rust-lang/rust#129392) - [
const extern
functions can now be defined for other calling conventions.] (rust-lang/rust#129753) - [Stabilize
expr_2021
macro fragment specifier in all editions.] (rust-lang/rust#129972) - [The
non_local_definitions
lint now fires on less code and warns by default.] (rust-lang/rust#127117)
Compiler
- [Deprecate unsound
-Csoft-float
flag.] (rust-lang/rust#129897) - Add many new tier 3 targets:
- [
aarch64_unknown_nto_qnx700
] (rust-lang/rust#127897) - [
arm64e-apple-tvos
] (rust-lang/rust#130614) - [
armv7-rtems-eabihf
] (rust-lang/rust#127021) - [
loongarch64-unknown-linux-ohos
] (rust-lang/rust#130750) - [
riscv32-wrs-vxworks
andriscv64-wrs-vxworks
] (rust-lang/rust#130549) - [
riscv32{e|em|emc}-unknown-none-elf
] (rust-lang/rust#130555) - [
x86_64-unknown-hurd-gnu
] (rust-lang/rust#128345) - [
x86_64-unknown-trusty
] (rust-lang/rust#130453)
- [
Refer to Rust's [platform support page][platform-support-doc] for more information on Rust's tiered platform support.
Libraries
- [Implement
PartialEq
forExitCode
.] (rust-lang/rust#127633) - [Document that
catch_unwind
can deal with foreign exceptions without UB, although the exact behavior is unspecified.] (rust-lang/rust#128321) - [Implement
Default
forHashMap
/HashSet
iterators that don't already have it.] (rust-lang/rust#128711) - [Bump Unicode to version 16.0.0.] (rust-lang/rust#130183)
- [Change documentation of
ptr::add
/sub
to not claim equivalence withoffset
.] (rust-lang/rust#130229).
Stabilized APIs
- [
BufRead::skip_until
] (https://doc.rust-lang.org/stable/std/io/trait.BufRead.html#method.skip_until) - [
ControlFlow::break_value
] (https://doc.rust-lang.org/stable/core/ops/enum.ControlFlow.html#method.break_value) - [
ControlFlow::continue_value
] (https://doc.rust-lang.org/stable/core/ops/enum.ControlFlow.html#method.continue_value) - [
ControlFlow::map_break
] (https://doc.rust-lang.org/stable/core/ops/enum.ControlFlow.html#method.map_break) - [
ControlFlow::map_continue
] (https://doc.rust-lang.org/stable/core/ops/enum.ControlFlow.html#method.map_continue) - [
DebugList::finish_non_exhaustive
] (https://doc.rust-lang.org/stable/core/fmt/struct.DebugList.html#method.finish_non_exhaustive) - [
DebugMap::finish_non_exhaustive
] (https://doc.rust-lang.org/stable/core/fmt/struct.DebugMap.html#method.finish_non_exhaustive) - [
DebugSet::finish_non_exhaustive
] (https://doc.rust-lang.org/stable/core/fmt/struct.DebugSet.html#method.finish_non_exhaustive) - [
DebugTuple::finish_non_exhaustive
] (https://doc.rust-lang.org/stable/core/fmt/struct.DebugTuple.html#method.finish_non_exhaustive) - [
ErrorKind::ArgumentListTooLong
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.ArgumentListTooLong) - [
ErrorKind::Deadlock
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.Deadlock) - [
ErrorKind::DirectoryNotEmpty
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.DirectoryNotEmpty) - [
ErrorKind::ExecutableFileBusy
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.ExecutableFileBusy) - [
ErrorKind::FileTooLarge
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.FileTooLarge) - [
ErrorKind::HostUnreachable
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.HostUnreachable) - [
ErrorKind::IsADirectory
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.IsADirectory) - [
ErrorKind::NetworkDown
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.NetworkDown) - [
ErrorKind::NetworkUnreachable
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.NetworkUnreachable) - [
ErrorKind::NotADirectory
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.NotADirectory) - [
ErrorKind::NotSeekable
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.NotSeekable) - [
ErrorKind::ReadOnlyFilesystem
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.ReadOnlyFilesystem) - [
ErrorKind::ResourceBusy
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.ResourceBusy) - [
ErrorKind::StaleNetworkFileHandle
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.StaleNetworkFileHandle) - [
ErrorKind::StorageFull
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.StorageFull) - [
ErrorKind::TooManyLinks
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.TooManyLinks) - [
Option::get_or_insert_default
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.get_or_insert_default) - [
Waker::data
] (https://doc.rust-lang.org/stable/core/task/struct.Waker.html#method.data) - [
Waker::new
] (https://doc.rust-lang.org/stable/core/task/struct.Waker.html#method.new) - [
Waker::vtable
] (https://doc.rust-lang.org/stable/core/task/struct.Waker.html#method.vtable) - [
char::MIN
] (https://doc.rust-lang.org/stable/core/primitive.char.html#associatedconstant.MIN) - [
hash_map::Entry::insert_entry
] (https://doc.rust-lang.org/stable/std/collections/hash_map/enum.Entry.html#method.insert_entry) - [
hash_map::VacantEntry::insert_entry
] (https://doc.rust-lang.org/stable/std/collections/hash_map/struct.VacantEntry.html#method.insert_entry)
These APIs are now stable in const contexts:
- [
Cell::into_inner
] (https://doc.rust-lang.org/stable/core/cell/struct.Cell.html#method.into_inner) - [
Duration::as_secs_f32
] (https://doc.rust-lang.org/stable/core/time/struct.Duration.html#method.as_secs_f32) - [
Duration::as_secs_f64
] (https://doc.rust-lang.org/stable/core/time/struct.Duration.html#method.as_secs_f64) - [
Duration::div_duration_f32
] (https://doc.rust-lang.org/stable/core/time/struct.Duration.html#method.div_duration_f32) - [
Duration::div_duration_f64
] (https://doc.rust-lang.org/stable/core/time/struct.Duration.html#method.div_duration_f64) - [
MaybeUninit::as_mut_ptr
] (https://doc.rust-lang.org/stable/core/mem/union.MaybeUninit.html#method.as_mut_ptr) - [
NonNull::as_mut
] (https://doc.rust-lang.org/stable/core/ptr/struct.NonNull.html#method.as_mut) - [
NonNull::copy_from
] (https://doc.rust-lang.org/stable/core/ptr/struct.NonNull.html#method.copy_from) - [
NonNull::copy_from_nonoverlapping
] (https://doc.rust-lang.org/stable/core/ptr/struct.NonNull.html#method.copy_from_nonoverlapping) - [
NonNull::copy_to
] (https://doc.rust-lang.org/stable/core/ptr/struct.NonNull.html#method.copy_to) - [
NonNull::copy_to_nonoverlapping
] (https://doc.rust-lang.org/stable/core/ptr/struct.NonNull.html#method.copy_to_nonoverlapping) - [
NonNull::slice_from_raw_parts
] (https://doc.rust-lang.org/stable/core/ptr/struct.NonNull.html#method.slice_from_raw_parts) - [
NonNull::write
] (https://doc.rust-lang.org/stable/core/ptr/struct.NonNull.html#method.write) - [
NonNull::write_bytes
] (https://doc.rust-lang.org/stable/core/ptr/struct.NonNull.html#method.write_bytes) - [
NonNull::write_unaligned
] (https://doc.rust-lang.org/stable/core/ptr/struct.NonNull.html#method.write_unaligned) - [
OnceCell::into_inner
] (https://doc.rust-lang.org/stable/core/cell/struct.OnceCell.html#method.into_inner) - [
Option::as_mut
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.as_mut) - [
Option::expect
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.expect) - [
Option::replace
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.replace) - [
Option::take
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.take) - [
Option::unwrap
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.unwrap) - [
Option::unwrap_unchecked
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.unwrap_unchecked) - [
Option::<&_>::copied
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.copied) - [
Option::<&mut _>::copied
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.copied-1) - [
Option::<Option<_>>::flatten
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.flatten) - [
Option::<Result<_, _>>::transpose
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.transpose) - [
RefCell::into_inner
] (https://doc.rust-lang.org/stable/core/cell/struct.RefCell.html#method.into_inner) - [
Result::as_mut
] (https://doc.rust-lang.org/stable/core/result/enum.Result.html#method.as_mut) - [
Result::<&_, _>::copied
] (https://doc.rust-lang.org/stable/core/result/enum.Result.html#method.copied) - [
Result::<&mut _, _>::copied
] (https://doc.rust-lang.org/stable/core/result/enum.Result.html#method.copied-1) - [
Result::<Option<_>, _>::transpose
] (https://doc.rust-lang.org/stable/core/result/enum.Result.html#method.transpose) - [
UnsafeCell::get_mut
] (https://doc.rust-lang.org/stable/core/cell/struct.UnsafeCell.html#method.get_mut) - [
UnsafeCell::into_inner
] (https://doc.rust-lang.org/stable/core/cell/struct.UnsafeCell.html#method.into_inner) - [
array::from_mut
] (https://doc.rust-lang.org/stable/core/array/fn.from_mut.html) - [
char::encode_utf8
] (https://doc.rust-lang.org/stable/core/primitive.char.html#method.encode_utf8) - [
{float}::classify
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.classify) - [
{float}::is_finite
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.is_finite) - [
{float}::is_infinite
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.is_infinite) - [
{float}::is_nan
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.is_nan) - [
{float}::is_normal
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.is_normal) - [
{float}::is_sign_negative
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.is_sign_negative) - [
{float}::is_sign_positive
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.is_sign_positive) - [
{float}::is_subnormal
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.is_subnormal) - [
{float}::from_bits
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.from_bits) - [
{float}::from_be_bytes
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.from_be_bytes) - [
{float}::from_le_bytes
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.from_le_bytes) - [
{float}::from_ne_bytes
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.from_ne_bytes) - [
{float}::to_bits
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.to_bits) - [
{float}::to_be_bytes
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.to_be_bytes) - [
{float}::to_le_bytes
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.to_le_bytes) - [
{float}::to_ne_bytes
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.to_ne_bytes) - [
mem::replace
] (https://doc.rust-lang.org/stable/core/mem/fn.replace.html) - [
ptr::replace
] (https://doc.rust-lang.org/stable/core/ptr/fn.replace.html) - [
ptr::slice_from_raw_parts_mut
] (https://doc.rust-lang.org/stable/core/ptr/fn.slice_from_raw_parts_mut.html) - [
ptr::write
] (https://doc.rust-lang.org/stable/core/ptr/fn.write.html) - [
ptr::write_unaligned
] (https://doc.rust-lang.org/stable/core/ptr/fn.write_unaligned.html) - [
<*const _>::copy_to
] (https://doc.rust-lang.org/stable/core/primitive.pointer.html#method.copy_to) - [
<*const _>::copy_to_nonoverlapping
] (https://doc.rust-lang.org/stable/core/primitive.pointer.html#method.copy_to_nonoverlapping) - [
<*mut _>::copy_from
] (https://doc.rust-lang.org/stable/core/primitive.pointer.html#method.copy_from) - [
<*mut _>::copy_from_nonoverlapping
] (https://doc.rust-lang.org/stable/core/primitive.pointer.html#method.copy_from_nonoverlapping) - [
<*mut _>::copy_to
] (https://doc.rust-lang.org/stable/core/primitive.pointer.html#method.copy_to-1) - [
<*mut _>::copy_to_nonoverlapping
] (https://doc.rust-lang.org/stable/core/primitive.pointer.html#method.copy_to_nonoverlapping-1) - [
<*mut _>::write
] (https://doc.rust-lang.org/stable/core/primitive.pointer.html#method.write) - [
<*mut _>::write_bytes
] (https://doc.rust-lang.org/stable/core/primitive.pointer.html#method.write_bytes) - [
<*mut _>::write_unaligned
] (https://doc.rust-lang.org/stable/core/primitive.pointer.html#method.write_unaligned) - [
slice::from_mut
] (https://doc.rust-lang.org/stable/core/slice/fn.from_mut.html) - [
slice::from_raw_parts_mut
] (https://doc.rust-lang.org/stable/core/slice/fn.from_raw_parts_mut.html) - [
<[_]>::first_mut
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.first_mut) - [
<[_]>::last_mut
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.last_mut) - [
<[_]>::first_chunk_mut
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.first_chunk_mut) - [
<[_]>::last_chunk_mut
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.last_chunk_mut) - [
<[_]>::split_at_mut
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.split_at_mut) - [
<[_]>::split_at_mut_checked
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.split_at_mut_checked) - [
<[_]>::split_at_mut_unchecked
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.split_at_mut_unchecked) - [
<[_]>::split_first_mut
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.split_first_mut) - [
<[_]>::split_last_mut
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.split_last_mut) - [
<[_]>::split_first_chunk_mut
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.split_first_chunk_mut) - [
<[_]>::split_last_chunk_mut
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.split_last_chunk_mut) - [
str::as_bytes_mut
] (https://doc.rust-lang.org/stable/core/primitive.str.html#method.as_bytes_mut) - [
str::as_mut_ptr
] (https://doc.rust-lang.org/stable/core/primitive.str.html#method.as_mut_ptr) - [
str::from_utf8_unchecked_mut
] (https://doc.rust-lang.org/stable/core/str/fn.from_utf8_unchecked_mut.html)
Cargo
- [Introduced a new
CARGO_MANIFEST_PATH
environment variable, similar toCARGO_MANIFEST_DIR
but pointing directly to the manifest file.] (rust-lang/cargo#14404) - [Added
package.autolib
to the manifest, allowing[lib]
auto-discovery to be disabled.] (rust-lang/cargo#14591) - [Declare support level for each crate in Cargo's Charter / crate docs.] (rust-lang/cargo#14600)
- [Declare new Intentional Artifacts as 'small' changes.] (rust-lang/cargo#14599)
Rustdoc
- [The sidebar / hamburger menu table of contents now includes the
# headers
from the main item's doc comment] (rust-lang/rust#120736). This is similar to a third-party feature provided by the rustdoc-search-enhancements browser extension.
Compatibility Notes
[Warn against function pointers using unsupported ABI strings.] (rust-lang/rust#128784)
[Check well-formedness of the source type's signature in fn pointer casts.] (rust-lang/rust#129021) This partly closes a soundness hole that comes when casting a function item to function pointer
[Use equality instead of subtyping when resolving type dependent paths.] (rust-lang/rust#129073)
Linking on macOS now correctly includes Rust's default deployment target. Due to a linker bug, you might have to pass
MACOSX_DEPLOYMENT_TARGET
or fix your#[link]
attributes to point to the correct frameworks. See <rust-lang/rust#129369>.[Rust will now correctly raise an error for
repr(Rust)
written on non-struct
/enum
/union
items, since it previous did not have any effect.] (rust-lang/rust#129422)The future incompatibility lint
deprecated_cfg_attr_crate_type_name
[has been made into a hard error] (rust-lang/rust#129670). It was used to deny usage of#![crate_type]
and#![crate_name]
attributes in#![cfg_attr]
, which required a hack in the compiler to be able to change the used crate type and crate name after cfg expansion. Users can use--crate-type
instead of#![cfg_attr(..., crate_type = "...")]
and--crate-name
instead of#![cfg_attr(..., crate_name = "...")]
when runningrustc
/cargo rustc
on the command line. Use of those two attributes outside of#![cfg_attr]
continue to be fully supported.Until now, paths into the sysroot were always prefixed with
/rustc/$hash
in diagnostics, codegen, backtrace, e.g.thread 'main' panicked at 'hello world', map-panic.rs:2:50 stack backtrace: 0: std::panicking::begin_panic at /rustc/a55dd71d5fb0ec5a6a3a9e8c27b2127ba491ce52/library/std/src/panicking.rs:616:12 1: map_panic::main::{{closure}} at ./map-panic.rs:2:50 2: core::option::Option<T>::map at /rustc/a55dd71d5fb0ec5a6a3a9e8c27b2127ba491ce52/library/core/src/option.rs:929:29 3: map_panic::main at ./map-panic.rs:2:30 4: core::ops::function::FnOnce::call_once at /rustc/a55dd71d5fb0ec5a6a3a9e8c27b2127ba491ce52/library/core/src/ops/function.rs:248:5 note: Some details are omitted, run with `RUST_BACKTRACE=full` for a verbose backtrace.
[RFC 3127 said] (https://rust-lang.github.io/rfcs/3127-trim-paths.html#changing-handling-of-sysroot-path-in-rustc)
We want to change this behaviour such that, when
rust-src
source files can be discovered, the virtual path is discarded and therefore the local path will be embedded, unless there is a--remap-path-prefix
that causes this local path to be remapped in the usual way.#129687 implements this behaviour, when
rust-src
is present at compile time,rustc
replaces/rustc/$hash
with a real path into the localrust-src
component with best effort. To sanitize this, users must explicitly supply--remap-path-prefix=<path to rust-src>=foo
or not have therust-src
component installed.The allow-by-default
missing_docs
lint used to disable itself when invoked throughrustc --test
/cargo test
, resulting in#[expect(missing_docs)]
emitting false positives due to the expectation being wrongly unfulfilled. This behavior [has now been removed] (rust-lang/rust#130025), which allows#[expect(missing_docs)]
to be fulfilled in all scenarios, but will also report newmissing_docs
diagnostics for publicly reachable#[cfg(test)]
items, [integration test] (https://doc.rust-lang.org/cargo/reference/cargo-targets.html#integration-tests) crate-level documentation, and publicly reachable items in integration tests.[The
armv8r-none-eabihf
target now uses the Armv8-R required set of floating-point features.] (rust-lang/rust#130295)[Fix a soundness bug where rustc wouldn't detect unconstrained higher-ranked lifetimes in a
dyn Trait
's associated types that occur due to supertraits.] (rust-lang/rust#130367)[Update the minimum external LLVM version to 18.] (rust-lang/rust#130487)
[Remove
aarch64-fuchsia
andx86_64-fuchsia
target aliases in favor ofaarch64-unknown-fuchsia
andx86_64-unknown-fuchsia
respectively.] (rust-lang/rust#130657)[The ABI-level exception class of a Rust panic is now encoded with native-endian bytes, so it is legible in hex dumps.] (rust-lang/rust#130897)
[Visual Studio 2013 is no longer supported for MSVC targets.] (rust-lang/rust#131070)
[The sysroot no longer contains the
std
dynamic library in its top-levellib/
dir.] (rust-lang/rust#131188)
tmeijn pushed a commit to tmeijn/dotfiles that referenced this pull request
This MR contains the following updates:
Package | Update | Change |
---|---|---|
rust | minor | 1.82.0 -> 1.83.0 |
MR created with the help of el-capitano/tools/renovate-bot.
Proposed changes to behavior should be submitted there as MRs.
Release Notes
rust-lang/rust (rust)
v1.83.0
==========================
Language
- Stabilize
&mut
,*mut
,&Cell
, and*const Cell
in const. - Allow creating references to statics in
const
initializers. - Implement raw lifetimes and labels (
'r#ident
). - Define behavior when atomic and non-atomic reads race.
- Non-exhaustive structs may now be empty.
- Disallow implicit coercions from places of type
!
const extern
functions can now be defined for other calling conventions.- Stabilize
expr_2021
macro fragment specifier in all editions. - The
non_local_definitions
lint now fires on less code and warns by default.
Compiler
- Deprecate unsound
-Csoft-float
flag. - Add many new tier 3 targets:
Refer to Rust's [platform support page][platform-support-doc] for more information on Rust's tiered platform support.
Libraries
- Implement
PartialEq
forExitCode
. - Document that
catch_unwind
can deal with foreign exceptions without UB, although the exact behavior is unspecified. - Implement
Default
forHashMap
/HashSet
iterators that don't already have it. - Bump Unicode to version 16.0.0.
- Change documentation of
ptr::add
/sub
to not claim equivalence withoffset
.
Stabilized APIs
BufRead::skip_until
ControlFlow::break_value
ControlFlow::continue_value
ControlFlow::map_break
ControlFlow::map_continue
DebugList::finish_non_exhaustive
DebugMap::finish_non_exhaustive
DebugSet::finish_non_exhaustive
DebugTuple::finish_non_exhaustive
ErrorKind::ArgumentListTooLong
ErrorKind::Deadlock
ErrorKind::DirectoryNotEmpty
ErrorKind::ExecutableFileBusy
ErrorKind::FileTooLarge
ErrorKind::HostUnreachable
ErrorKind::IsADirectory
ErrorKind::NetworkDown
ErrorKind::NetworkUnreachable
ErrorKind::NotADirectory
ErrorKind::NotSeekable
ErrorKind::ReadOnlyFilesystem
ErrorKind::ResourceBusy
ErrorKind::StaleNetworkFileHandle
ErrorKind::StorageFull
ErrorKind::TooManyLinks
Option::get_or_insert_default
Waker::data
Waker::new
Waker::vtable
char::MIN
hash_map::Entry::insert_entry
hash_map::VacantEntry::insert_entry
These APIs are now stable in const contexts:
Cell::into_inner
Duration::as_secs_f32
Duration::as_secs_f64
Duration::div_duration_f32
Duration::div_duration_f64
MaybeUninit::as_mut_ptr
NonNull::as_mut
NonNull::copy_from
NonNull::copy_from_nonoverlapping
NonNull::copy_to
NonNull::copy_to_nonoverlapping
NonNull::slice_from_raw_parts
NonNull::write
NonNull::write_bytes
NonNull::write_unaligned
OnceCell::into_inner
Option::as_mut
Option::expect
Option::replace
Option::take
Option::unwrap
Option::unwrap_unchecked
Option::<&_>::copied
Option::<&mut _>::copied
Option::<Option<_>>::flatten
Option::<Result<_, _>>::transpose
RefCell::into_inner
Result::as_mut
Result::<&_, _>::copied
Result::<&mut _, _>::copied
Result::<Option<_>, _>::transpose
UnsafeCell::get_mut
UnsafeCell::into_inner
array::from_mut
char::encode_utf8
{float}::classify
{float}::is_finite
{float}::is_infinite
{float}::is_nan
{float}::is_normal
{float}::is_sign_negative
{float}::is_sign_positive
{float}::is_subnormal
{float}::from_bits
{float}::from_be_bytes
{float}::from_le_bytes
{float}::from_ne_bytes
{float}::to_bits
{float}::to_be_bytes
{float}::to_le_bytes
{float}::to_ne_bytes
mem::replace
ptr::replace
ptr::slice_from_raw_parts_mut
ptr::write
ptr::write_unaligned
<*const _>::copy_to
<*const _>::copy_to_nonoverlapping
<*mut _>::copy_from
<*mut _>::copy_from_nonoverlapping
<*mut _>::copy_to
<*mut _>::copy_to_nonoverlapping
<*mut _>::write
<*mut _>::write_bytes
<*mut _>::write_unaligned
slice::from_mut
slice::from_raw_parts_mut
<[_]>::first_mut
<[_]>::last_mut
<[_]>::first_chunk_mut
<[_]>::last_chunk_mut
<[_]>::split_at_mut
<[_]>::split_at_mut_checked
<[_]>::split_at_mut_unchecked
<[_]>::split_first_mut
<[_]>::split_last_mut
<[_]>::split_first_chunk_mut
<[_]>::split_last_chunk_mut
str::as_bytes_mut
str::as_mut_ptr
str::from_utf8_unchecked_mut
Cargo
- Introduced a new
CARGO_MANIFEST_PATH
environment variable, similar toCARGO_MANIFEST_DIR
but pointing directly to the manifest file. - Added
package.autolib
to the manifest, allowing[lib]
auto-discovery to be disabled. - Declare support level for each crate in Cargo's Charter / crate docs.
- Declare new Intentional Artifacts as 'small' changes.
Rustdoc
- The sidebar / hamburger menu table of contents now includes the
# headers
from the main item's doc comment. This is similar to a third-party feature provided by the rustdoc-search-enhancements browser extension.
Compatibility Notes
Warn against function pointers using unsupported ABI strings.
Check well-formedness of the source type's signature in fn pointer casts. This partly closes a soundness hole that comes when casting a function item to function pointer
Use equality instead of subtyping when resolving type dependent paths.
Linking on macOS now correctly includes Rust's default deployment target. Due to a linker bug, you might have to pass
MACOSX_DEPLOYMENT_TARGET
or fix your#[link]
attributes to point to the correct frameworks. See #129369.The future incompatibility lint
deprecated_cfg_attr_crate_type_name
has been made into a hard error. It was used to deny usage of#![crate_type]
and#![crate_name]
attributes in#![cfg_attr]
, which required a hack in the compiler to be able to change the used crate type and crate name after cfg expansion. Users can use--crate-type
instead of#![cfg_attr(..., crate_type = "...")]
and--crate-name
instead of#![cfg_attr(..., crate_name = "...")]
when runningrustc
/cargo rustc
on the command line. Use of those two attributes outside of#![cfg_attr]
continue to be fully supported.Until now, paths into the sysroot were always prefixed with
/rustc/$hash
in diagnostics, codegen, backtrace, e.g.thread 'main' panicked at 'hello world', map-panic.rs:2:50 stack backtrace: 0: std::panicking::begin_panic at /rustc/a55dd71d5fb0ec5a6a3a9e8c27b2127ba491ce52/library/std/src/panicking.rs:616:12 1: map_panic::main::{{closure}} at ./map-panic.rs:2:50 2: core::option::Option<T>::map at /rustc/a55dd71d5fb0ec5a6a3a9e8c27b2127ba491ce52/library/core/src/option.rs:929:29 3: map_panic::main at ./map-panic.rs:2:30 4: core::ops::function::FnOnce::call_once at /rustc/a55dd71d5fb0ec5a6a3a9e8c27b2127ba491ce52/library/core/src/ops/function.rs:248:5 note: Some details are omitted, run with `RUST_BACKTRACE=full` for a verbose backtrace.
We want to change this behaviour such that, when
rust-src
source files can be discovered, the virtual path is discarded and therefore the local path will be embedded, unless there is a--remap-path-prefix
that causes this local path to be remapped in the usual way.#129687 implements this behaviour, when
rust-src
is present at compile time,rustc
replaces/rustc/$hash
with a real path into the localrust-src
component with best effort. To sanitize this, users must explicitly supply--remap-path-prefix=<path to rust-src>=foo
or not have therust-src
component installed.The allow-by-default
missing_docs
lint used to disable itself when invoked throughrustc --test
/cargo test
, resulting in#[expect(missing_docs)]
emitting false positives due to the expectation being wrongly unfulfilled. This behavior has now been removed, which allows#[expect(missing_docs)]
to be fulfilled in all scenarios, but will also report newmissing_docs
diagnostics for publicly reachable#[cfg(test)]
items, integration test crate-level documentation, and publicly reachable items in integration tests.The
armv8r-none-eabihf
target now uses the Armv8-R required set of floating-point features.The sysroot no longer contains the
std
dynamic library in its top-levellib/
dir.
Configuration
📅 Schedule: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined).
🚦 Automerge: Disabled by config. Please merge this manually once you are satisfied.
♻ Rebasing: Whenever MR becomes conflicted, or you tick the rebase/retry checkbox.
🔕 Ignore: Close this MR and you won't be reminded about this update again.
- If you want to rebase/retry this MR, check this box
This MR has been generated by Renovate Bot.
hegza mentioned this pull request
netbsd-srcmastr pushed a commit to NetBSD/pkgsrc that referenced this pull request
Pkgsrc changes:
- Introduce use of TOOL* settings.
- On NetBSD, use patchelf in the install phase to fix up RPATHs.
- Reduce verbosity by dropping -v flag to x.py invocations.
- Remove patches related to rust-lang/rust#130110, which is now integrated upstream.
- Remove patch to vendor/cc-1.0.79, now integrated in the current vendored cc crate.
- Checksum updates.
Upstream changes:
Version 1.83.0 (2024-11-28)
Language
- [Stabilize
&mut
,*mut
,&Cell
, and*const Cell
in const.] (rust-lang/rust#129195) - [Allow creating references to statics in
const
initializers.] (rust-lang/rust#129759) - [Implement raw lifetimes and labels (
'r#ident
).] (rust-lang/rust#126452) - [Define behavior when atomic and non-atomic reads race.] (rust-lang/rust#128778)
- [Non-exhaustive structs may now be empty.] (rust-lang/rust#128934)
- [Disallow implicit coercions from places of type
!
] (rust-lang/rust#129392) - [
const extern
functions can now be defined for other calling conventions.] (rust-lang/rust#129753) - [Stabilize
expr_2021
macro fragment specifier in all editions.] (rust-lang/rust#129972) - [The
non_local_definitions
lint now fires on less code and warns by default.] (rust-lang/rust#127117)
Compiler
- [Deprecate unsound
-Csoft-float
flag.] (rust-lang/rust#129897) - Add many new tier 3 targets:
- [
aarch64_unknown_nto_qnx700
] (rust-lang/rust#127897) - [
arm64e-apple-tvos
] (rust-lang/rust#130614) - [
armv7-rtems-eabihf
] (rust-lang/rust#127021) - [
loongarch64-unknown-linux-ohos
] (rust-lang/rust#130750) - [
riscv32-wrs-vxworks
andriscv64-wrs-vxworks
] (rust-lang/rust#130549) - [
riscv32{e|em|emc}-unknown-none-elf
] (rust-lang/rust#130555) - [
x86_64-unknown-hurd-gnu
] (rust-lang/rust#128345) - [
x86_64-unknown-trusty
] (rust-lang/rust#130453)
- [
Refer to Rust's [platform support page][platform-support-doc] for more information on Rust's tiered platform support.
Libraries
- [Implement
PartialEq
forExitCode
.] (rust-lang/rust#127633) - [Document that
catch_unwind
can deal with foreign exceptions without UB, although the exact behavior is unspecified.] (rust-lang/rust#128321) - [Implement
Default
forHashMap
/HashSet
iterators that don't already have it.] (rust-lang/rust#128711) - [Bump Unicode to version 16.0.0.] (rust-lang/rust#130183)
- [Change documentation of
ptr::add
/sub
to not claim equivalence withoffset
.] (rust-lang/rust#130229).
Stabilized APIs
- [
BufRead::skip_until
] (https://doc.rust-lang.org/stable/std/io/trait.BufRead.html#method.skip_until) - [
ControlFlow::break_value
] (https://doc.rust-lang.org/stable/core/ops/enum.ControlFlow.html#method.break_value) - [
ControlFlow::continue_value
] (https://doc.rust-lang.org/stable/core/ops/enum.ControlFlow.html#method.continue_value) - [
ControlFlow::map_break
] (https://doc.rust-lang.org/stable/core/ops/enum.ControlFlow.html#method.map_break) - [
ControlFlow::map_continue
] (https://doc.rust-lang.org/stable/core/ops/enum.ControlFlow.html#method.map_continue) - [
DebugList::finish_non_exhaustive
] (https://doc.rust-lang.org/stable/core/fmt/struct.DebugList.html#method.finish_non_exhaustive) - [
DebugMap::finish_non_exhaustive
] (https://doc.rust-lang.org/stable/core/fmt/struct.DebugMap.html#method.finish_non_exhaustive) - [
DebugSet::finish_non_exhaustive
] (https://doc.rust-lang.org/stable/core/fmt/struct.DebugSet.html#method.finish_non_exhaustive) - [
DebugTuple::finish_non_exhaustive
] (https://doc.rust-lang.org/stable/core/fmt/struct.DebugTuple.html#method.finish_non_exhaustive) - [
ErrorKind::ArgumentListTooLong
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.ArgumentListTooLong) - [
ErrorKind::Deadlock
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.Deadlock) - [
ErrorKind::DirectoryNotEmpty
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.DirectoryNotEmpty) - [
ErrorKind::ExecutableFileBusy
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.ExecutableFileBusy) - [
ErrorKind::FileTooLarge
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.FileTooLarge) - [
ErrorKind::HostUnreachable
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.HostUnreachable) - [
ErrorKind::IsADirectory
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.IsADirectory) - [
ErrorKind::NetworkDown
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.NetworkDown) - [
ErrorKind::NetworkUnreachable
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.NetworkUnreachable) - [
ErrorKind::NotADirectory
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.NotADirectory) - [
ErrorKind::NotSeekable
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.NotSeekable) - [
ErrorKind::ReadOnlyFilesystem
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.ReadOnlyFilesystem) - [
ErrorKind::ResourceBusy
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.ResourceBusy) - [
ErrorKind::StaleNetworkFileHandle
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.StaleNetworkFileHandle) - [
ErrorKind::StorageFull
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.StorageFull) - [
ErrorKind::TooManyLinks
] (https://doc.rust-lang.org/stable/std/io/enum.ErrorKind.html#variant.TooManyLinks) - [
Option::get_or_insert_default
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.get_or_insert_default) - [
Waker::data
] (https://doc.rust-lang.org/stable/core/task/struct.Waker.html#method.data) - [
Waker::new
] (https://doc.rust-lang.org/stable/core/task/struct.Waker.html#method.new) - [
Waker::vtable
] (https://doc.rust-lang.org/stable/core/task/struct.Waker.html#method.vtable) - [
char::MIN
] (https://doc.rust-lang.org/stable/core/primitive.char.html#associatedconstant.MIN) - [
hash_map::Entry::insert_entry
] (https://doc.rust-lang.org/stable/std/collections/hash_map/enum.Entry.html#method.insert_entry) - [
hash_map::VacantEntry::insert_entry
] (https://doc.rust-lang.org/stable/std/collections/hash_map/struct.VacantEntry.html#method.insert_entry)
These APIs are now stable in const contexts:
- [
Cell::into_inner
] (https://doc.rust-lang.org/stable/core/cell/struct.Cell.html#method.into_inner) - [
Duration::as_secs_f32
] (https://doc.rust-lang.org/stable/core/time/struct.Duration.html#method.as_secs_f32) - [
Duration::as_secs_f64
] (https://doc.rust-lang.org/stable/core/time/struct.Duration.html#method.as_secs_f64) - [
Duration::div_duration_f32
] (https://doc.rust-lang.org/stable/core/time/struct.Duration.html#method.div_duration_f32) - [
Duration::div_duration_f64
] (https://doc.rust-lang.org/stable/core/time/struct.Duration.html#method.div_duration_f64) - [
MaybeUninit::as_mut_ptr
] (https://doc.rust-lang.org/stable/core/mem/union.MaybeUninit.html#method.as_mut_ptr) - [
NonNull::as_mut
] (https://doc.rust-lang.org/stable/core/ptr/struct.NonNull.html#method.as_mut) - [
NonNull::copy_from
] (https://doc.rust-lang.org/stable/core/ptr/struct.NonNull.html#method.copy_from) - [
NonNull::copy_from_nonoverlapping
] (https://doc.rust-lang.org/stable/core/ptr/struct.NonNull.html#method.copy_from_nonoverlapping) - [
NonNull::copy_to
] (https://doc.rust-lang.org/stable/core/ptr/struct.NonNull.html#method.copy_to) - [
NonNull::copy_to_nonoverlapping
] (https://doc.rust-lang.org/stable/core/ptr/struct.NonNull.html#method.copy_to_nonoverlapping) - [
NonNull::slice_from_raw_parts
] (https://doc.rust-lang.org/stable/core/ptr/struct.NonNull.html#method.slice_from_raw_parts) - [
NonNull::write
] (https://doc.rust-lang.org/stable/core/ptr/struct.NonNull.html#method.write) - [
NonNull::write_bytes
] (https://doc.rust-lang.org/stable/core/ptr/struct.NonNull.html#method.write_bytes) - [
NonNull::write_unaligned
] (https://doc.rust-lang.org/stable/core/ptr/struct.NonNull.html#method.write_unaligned) - [
OnceCell::into_inner
] (https://doc.rust-lang.org/stable/core/cell/struct.OnceCell.html#method.into_inner) - [
Option::as_mut
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.as_mut) - [
Option::expect
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.expect) - [
Option::replace
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.replace) - [
Option::take
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.take) - [
Option::unwrap
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.unwrap) - [
Option::unwrap_unchecked
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.unwrap_unchecked) - [
Option::<&_>::copied
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.copied) - [
Option::<&mut _>::copied
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.copied-1) - [
Option::<Option<_>>::flatten
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.flatten) - [
Option::<Result<_, _>>::transpose
] (https://doc.rust-lang.org/stable/core/option/enum.Option.html#method.transpose) - [
RefCell::into_inner
] (https://doc.rust-lang.org/stable/core/cell/struct.RefCell.html#method.into_inner) - [
Result::as_mut
] (https://doc.rust-lang.org/stable/core/result/enum.Result.html#method.as_mut) - [
Result::<&_, _>::copied
] (https://doc.rust-lang.org/stable/core/result/enum.Result.html#method.copied) - [
Result::<&mut _, _>::copied
] (https://doc.rust-lang.org/stable/core/result/enum.Result.html#method.copied-1) - [
Result::<Option<_>, _>::transpose
] (https://doc.rust-lang.org/stable/core/result/enum.Result.html#method.transpose) - [
UnsafeCell::get_mut
] (https://doc.rust-lang.org/stable/core/cell/struct.UnsafeCell.html#method.get_mut) - [
UnsafeCell::into_inner
] (https://doc.rust-lang.org/stable/core/cell/struct.UnsafeCell.html#method.into_inner) - [
array::from_mut
] (https://doc.rust-lang.org/stable/core/array/fn.from_mut.html) - [
char::encode_utf8
] (https://doc.rust-lang.org/stable/core/primitive.char.html#method.encode_utf8) - [
{float}::classify
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.classify) - [
{float}::is_finite
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.is_finite) - [
{float}::is_infinite
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.is_infinite) - [
{float}::is_nan
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.is_nan) - [
{float}::is_normal
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.is_normal) - [
{float}::is_sign_negative
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.is_sign_negative) - [
{float}::is_sign_positive
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.is_sign_positive) - [
{float}::is_subnormal
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.is_subnormal) - [
{float}::from_bits
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.from_bits) - [
{float}::from_be_bytes
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.from_be_bytes) - [
{float}::from_le_bytes
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.from_le_bytes) - [
{float}::from_ne_bytes
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.from_ne_bytes) - [
{float}::to_bits
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.to_bits) - [
{float}::to_be_bytes
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.to_be_bytes) - [
{float}::to_le_bytes
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.to_le_bytes) - [
{float}::to_ne_bytes
] (https://doc.rust-lang.org/stable/core/primitive.f64.html#method.to_ne_bytes) - [
mem::replace
] (https://doc.rust-lang.org/stable/core/mem/fn.replace.html) - [
ptr::replace
] (https://doc.rust-lang.org/stable/core/ptr/fn.replace.html) - [
ptr::slice_from_raw_parts_mut
] (https://doc.rust-lang.org/stable/core/ptr/fn.slice_from_raw_parts_mut.html) - [
ptr::write
] (https://doc.rust-lang.org/stable/core/ptr/fn.write.html) - [
ptr::write_unaligned
] (https://doc.rust-lang.org/stable/core/ptr/fn.write_unaligned.html) - [
<*const _>::copy_to
] (https://doc.rust-lang.org/stable/core/primitive.pointer.html#method.copy_to) - [
<*const _>::copy_to_nonoverlapping
] (https://doc.rust-lang.org/stable/core/primitive.pointer.html#method.copy_to_nonoverlapping) - [
<*mut _>::copy_from
] (https://doc.rust-lang.org/stable/core/primitive.pointer.html#method.copy_from) - [
<*mut _>::copy_from_nonoverlapping
] (https://doc.rust-lang.org/stable/core/primitive.pointer.html#method.copy_from_nonoverlapping) - [
<*mut _>::copy_to
] (https://doc.rust-lang.org/stable/core/primitive.pointer.html#method.copy_to-1) - [
<*mut _>::copy_to_nonoverlapping
] (https://doc.rust-lang.org/stable/core/primitive.pointer.html#method.copy_to_nonoverlapping-1) - [
<*mut _>::write
] (https://doc.rust-lang.org/stable/core/primitive.pointer.html#method.write) - [
<*mut _>::write_bytes
] (https://doc.rust-lang.org/stable/core/primitive.pointer.html#method.write_bytes) - [
<*mut _>::write_unaligned
] (https://doc.rust-lang.org/stable/core/primitive.pointer.html#method.write_unaligned) - [
slice::from_mut
] (https://doc.rust-lang.org/stable/core/slice/fn.from_mut.html) - [
slice::from_raw_parts_mut
] (https://doc.rust-lang.org/stable/core/slice/fn.from_raw_parts_mut.html) - [
<[_]>::first_mut
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.first_mut) - [
<[_]>::last_mut
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.last_mut) - [
<[_]>::first_chunk_mut
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.first_chunk_mut) - [
<[_]>::last_chunk_mut
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.last_chunk_mut) - [
<[_]>::split_at_mut
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.split_at_mut) - [
<[_]>::split_at_mut_checked
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.split_at_mut_checked) - [
<[_]>::split_at_mut_unchecked
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.split_at_mut_unchecked) - [
<[_]>::split_first_mut
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.split_first_mut) - [
<[_]>::split_last_mut
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.split_last_mut) - [
<[_]>::split_first_chunk_mut
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.split_first_chunk_mut) - [
<[_]>::split_last_chunk_mut
] (https://doc.rust-lang.org/stable/core/primitive.slice.html#method.split_last_chunk_mut) - [
str::as_bytes_mut
] (https://doc.rust-lang.org/stable/core/primitive.str.html#method.as_bytes_mut) - [
str::as_mut_ptr
] (https://doc.rust-lang.org/stable/core/primitive.str.html#method.as_mut_ptr) - [
str::from_utf8_unchecked_mut
] (https://doc.rust-lang.org/stable/core/str/fn.from_utf8_unchecked_mut.html)
Cargo
- [Introduced a new
CARGO_MANIFEST_PATH
environment variable, similar toCARGO_MANIFEST_DIR
but pointing directly to the manifest file.] (rust-lang/cargo#14404) - [Added
package.autolib
to the manifest, allowing[lib]
auto-discovery to be disabled.] (rust-lang/cargo#14591) - [Declare support level for each crate in Cargo's Charter / crate docs.] (rust-lang/cargo#14600)
- [Declare new Intentional Artifacts as 'small' changes.] (rust-lang/cargo#14599)
Rustdoc
- [The sidebar / hamburger menu table of contents now includes the
# headers
from the main item's doc comment] (rust-lang/rust#120736). This is similar to a third-party feature provided by the rustdoc-search-enhancements browser extension.
Compatibility Notes
[Warn against function pointers using unsupported ABI strings.] (rust-lang/rust#128784)
[Check well-formedness of the source type's signature in fn pointer casts.] (rust-lang/rust#129021) This partly closes a soundness hole that comes when casting a function item to function pointer
[Use equality instead of subtyping when resolving type dependent paths.] (rust-lang/rust#129073)
Linking on macOS now correctly includes Rust's default deployment target. Due to a linker bug, you might have to pass
MACOSX_DEPLOYMENT_TARGET
or fix your#[link]
attributes to point to the correct frameworks. See <rust-lang/rust#129369>.[Rust will now correctly raise an error for
repr(Rust)
written on non-struct
/enum
/union
items, since it previous did not have any effect.] (rust-lang/rust#129422)The future incompatibility lint
deprecated_cfg_attr_crate_type_name
[has been made into a hard error] (rust-lang/rust#129670). It was used to deny usage of#![crate_type]
and#![crate_name]
attributes in#![cfg_attr]
, which required a hack in the compiler to be able to change the used crate type and crate name after cfg expansion. Users can use--crate-type
instead of#![cfg_attr(..., crate_type = "...")]
and--crate-name
instead of#![cfg_attr(..., crate_name = "...")]
when runningrustc
/cargo rustc
on the command line. Use of those two attributes outside of#![cfg_attr]
continue to be fully supported.Until now, paths into the sysroot were always prefixed with
/rustc/$hash
in diagnostics, codegen, backtrace, e.g.thread 'main' panicked at 'hello world', map-panic.rs:2:50 stack backtrace: 0: std::panicking::begin_panic at /rustc/a55dd71d5fb0ec5a6a3a9e8c27b2127ba491ce52/library/std/src/panicking.rs:616:12 1: map_panic::main::{{closure}} at ./map-panic.rs:2:50 2: core::option::Option<T>::map at /rustc/a55dd71d5fb0ec5a6a3a9e8c27b2127ba491ce52/library/core/src/option.rs:929:29 3: map_panic::main at ./map-panic.rs:2:30 4: core::ops::function::FnOnce::call_once at /rustc/a55dd71d5fb0ec5a6a3a9e8c27b2127ba491ce52/library/core/src/ops/function.rs:248:5 note: Some details are omitted, run with `RUST_BACKTRACE=full` for a verbose backtrace.
[RFC 3127 said] (https://rust-lang.github.io/rfcs/3127-trim-paths.html#changing-handling-of-sysroot-path-in-rustc)
We want to change this behaviour such that, when
rust-src
source files can be discovered, the virtual path is discarded and therefore the local path will be embedded, unless there is a--remap-path-prefix
that causes this local path to be remapped in the usual way.#129687 implements this behaviour, when
rust-src
is present at compile time,rustc
replaces/rustc/$hash
with a real path into the localrust-src
component with best effort. To sanitize this, users must explicitly supply--remap-path-prefix=<path to rust-src>=foo
or not have therust-src
component installed.The allow-by-default
missing_docs
lint used to disable itself when invoked throughrustc --test
/cargo test
, resulting in#[expect(missing_docs)]
emitting false positives due to the expectation being wrongly unfulfilled. This behavior [has now been removed] (rust-lang/rust#130025), which allows#[expect(missing_docs)]
to be fulfilled in all scenarios, but will also report newmissing_docs
diagnostics for publicly reachable#[cfg(test)]
items, [integration test] (https://doc.rust-lang.org/cargo/reference/cargo-targets.html#integration-tests) crate-level documentation, and publicly reachable items in integration tests.[The
armv8r-none-eabihf
target now uses the Armv8-R required set of floating-point features.] (rust-lang/rust#130295)[Fix a soundness bug where rustc wouldn't detect unconstrained higher-ranked lifetimes in a
dyn Trait
's associated types that occur due to supertraits.] (rust-lang/rust#130367)[Update the minimum external LLVM version to 18.] (rust-lang/rust#130487)
[Remove
aarch64-fuchsia
andx86_64-fuchsia
target aliases in favor ofaarch64-unknown-fuchsia
andx86_64-unknown-fuchsia
respectively.] (rust-lang/rust#130657)[The ABI-level exception class of a Rust panic is now encoded with native-endian bytes, so it is legible in hex dumps.] (rust-lang/rust#130897)
[Visual Studio 2013 is no longer supported for MSVC targets.] (rust-lang/rust#131070)
[The sysroot no longer contains the
std
dynamic library in its top-levellib/
dir.] (rust-lang/rust#131188)
Labels
Target: RISC-V architecture
Marks issues that should be documented in the release notes of the next release.
Status: Waiting on bors to run and complete tests. Bors will change the label on completion.
Relevant to the bootstrap subteam: Rust's build system (x.py and src/bootstrap)
Relevant to the compiler team, which will review and decide on the PR/issue.