Add (back) unsupported_calling_conventions lint to reject more invalid calling conventions by RalfJung · Pull Request #141435 · rust-lang/rust (original) (raw)
rustbot added S-waiting-on-review
Status: Awaiting review from the assignee but also interested parties.
Relevant to the compiler team, which will review and decide on the PR/issue.
labels
traviscross added P-lang-drag-1
Lang team prioritization drag level 1. https://rust-lang.zulipchat.com/#narrow/channel/410516-t-lang
and removed T-compiler
Relevant to the compiler team, which will review and decide on the PR/issue.
labels
traviscross changed the title
add (back) unsupported_calling_conventions lint to reject more invalid calling conventions Add (back) unsupported_calling_conventions lint to reject more invalid calling conventions
traviscross added I-lang-radar
Items that are on lang's radar and will need eventual work or consideration.
and removed I-lang-nominated
Nominated for discussion during a lang team meeting.
Lang team prioritization drag level 1. https://rust-lang.zulipchat.com/#narrow/channel/410516-t-lang
labels
RalfJung deleted the unsupported_calling_conventions branch
This was referenced
Jun 9, 2025
workingjubilee added a commit to workingjubilee/rustc that referenced this pull request
…cl-and-other-abis, r=RalfJung
compiler: Ease off the accelerator on unsupported_calling_conventions
This is to give us more time to discuss rust-lang#142330 without the ecosystem having an anxiety attack. I have withdrawn unsupported_calling_conventions from report-in-deps
I believe we should consider this a simple suspension of the decision in rust-lang#141435 to start this process, rather than a reversal. That is, we may continue with linting again. But I believe we are about to get a... reasonable amount of feedback just from currently available information and should allow ourselves time to process it.
workingjubilee added a commit to workingjubilee/rustc that referenced this pull request
…cl-and-other-abis, r=RalfJung
compiler: Ease off the accelerator on unsupported_calling_conventions
This is to give us more time to discuss rust-lang#142330 without the ecosystem having an anxiety attack. I have withdrawn unsupported_calling_conventions from report-in-deps
I believe we should consider this a simple suspension of the decision in rust-lang#141435 to start this process, rather than a reversal. That is, we may continue with linting again. But I believe we are about to get a... reasonable amount of feedback just from currently available information and should allow ourselves time to process it.
matthiaskrgr added a commit to matthiaskrgr/rust that referenced this pull request
…cl-and-other-abis, r=RalfJung
compiler: Ease off the accelerator on unsupported_calling_conventions
This is to give us more time to discuss rust-lang#142330 without the ecosystem having an anxiety attack. I have withdrawn unsupported_calling_conventions from report-in-deps
I believe we should consider this a simple suspension of the decision in rust-lang#141435 to start this process, rather than a reversal. That is, we may continue with linting again. But I believe we are about to get a... reasonable amount of feedback just from currently available information and should allow ourselves time to process it.
matthiaskrgr added a commit to matthiaskrgr/rust that referenced this pull request
…cl-and-other-abis, r=RalfJung
compiler: Ease off the accelerator on unsupported_calling_conventions
This is to give us more time to discuss rust-lang#142330 without the ecosystem having an anxiety attack. I have withdrawn unsupported_calling_conventions from report-in-deps
I believe we should consider this a simple suspension of the decision in rust-lang#141435 to start this process, rather than a reversal. That is, we may continue with linting again. But I believe we are about to get a... reasonable amount of feedback just from currently available information and should allow ourselves time to process it.
bors added a commit that referenced this pull request
…r-abis, r=RalfJung
compiler: Ease off the accelerator on unsupported_calling_conventions
This is to give us more time to discuss #142330 without the ecosystem having an anxiety attack. I have withdrawn unsupported_calling_conventions from report-in-deps
I believe we should consider this a simple suspension of the decision in #141435 to start this process, rather than a reversal. That is, we may continue with linting again. But I believe we are about to get a... reasonable amount of feedback just from currently available information and should allow ourselves time to process it.
matthiaskrgr added a commit to matthiaskrgr/rust that referenced this pull request
…cl-and-other-abis, r=RalfJung
compiler: Ease off the accelerator on unsupported_calling_conventions
This is to give us more time to discuss rust-lang#142330 without the ecosystem having an anxiety attack. I have withdrawn unsupported_calling_conventions from report-in-deps
I believe we should consider this a simple suspension of the decision in rust-lang#141435 to start this process, rather than a reversal. That is, we may continue with linting again. But I believe we are about to get a... reasonable amount of feedback just from currently available information and should allow ourselves time to process it.
bors added a commit that referenced this pull request
…r-abis, r=ChrisDenton,RalfJung
compiler: Ease off the accelerator on unsupported_calling_conventions
This is to give us more time to discuss #142330 without the ecosystem having an anxiety attack. I have withdrawn unsupported_calling_conventions from report-in-deps
I believe we should consider this a simple suspension of the decision in #141435 to start this process, rather than a reversal. That is, we may continue with linting again. But I believe we are about to get a... reasonable amount of feedback just from currently available information and should allow ourselves time to process it.
github-actions bot pushed a commit to rust-lang/rustc-dev-guide that referenced this pull request
…r-abis, r=ChrisDenton,RalfJung
compiler: Ease off the accelerator on unsupported_calling_conventions
This is to give us more time to discuss rust-lang/rust#142330 without the ecosystem having an anxiety attack. I have withdrawn unsupported_calling_conventions from report-in-deps
I believe we should consider this a simple suspension of the decision in rust-lang/rust#141435 to start this process, rather than a reversal. That is, we may continue with linting again. But I believe we are about to get a... reasonable amount of feedback just from currently available information and should allow ourselves time to process it.
workingjubilee added a commit to workingjubilee/rustc that referenced this pull request
…abi, r=jdonszelmann,RalfJung
Reject unsupported extern "{abi}"s consistently in all positions
Modify the handling of extern "{abi}" in the compiler so that it has consistent errors without regard to the position in the grammar.
What
Implement the following breakages:
- Promote
unsupported_fn_ptr_calling_conventionsfrom a warning to a hard error - Guarantee future edge-cases like trait declarations will not escape so that ABIs that have already been unusable in most positions will now be unusable in all positions. See "How" and "Why or Why Not" for more details.
In particular, these architecture-specific ABIs now only compile on their architectures[^4]:
- amdgpu: "gpu-kernel"
- arm: "aapcs", "C-cmse-nonsecure-entry", "C-cmse-nonsecure-call"
- avr: "avr-interrupt", "avr-non-blocking-interrupt"
- msp430: "msp430-interrupt"
- nvptx64: "gpu-kernel", "ptx-kernel"
- riscv32 and riscv64: "riscv-interrupt-m", "riscv-interrupt-s"
- x86: "thiscall"
- x86 and x86_64: "x86-interrupt"
- x86_64: "sysv64", "win64"
ABIs that are logically x86-specific but actually permitted on all Windows targets remain permitted on Windows, as before. For non-Windows targets, they error if we had previously done so in other positions.
How
We modify rustc_ast_lowering to prevent unsupported ABIs from leaking through the HIR without being checked for target support. They now emit hard errors for every case where we would return Invalid from AbiMap::canonize_abi. Previously ad-hoc checking on various HIR items required making sure we check every HIR item which could contain an extern "{abi}" string. This is a losing proposition compared to gating the lowering itself.
As a consequence, unsupported ABI strings error instead of triggering the warning unsupported_fn_ptr_calling_conventions. The code is also simpler compared to alternative implementations that might e.g. split on unstable vs. stable, only suffering some unavoidable complication to support the newly-revived unsupported_calling_conventions lint.[^5]
However, per rust-lang#86232 this does cause errors for rare usages of extern "{abi}" that were theoretically possible to write in Rust source, without previous warning or error. For instance, trait declarations without impls were never checked. These are the exact kinds of leakages that this new approach prevents.
This differs from the following PRs:
- rust-lang#141435 is orthogonal, as it adds a new lint for ABIs we have not warned on and are not touched by this PR
- rust-lang#141877 is subsumed by this, in that this simply cuts out bad functionality instead of adding epicycles for stable code
Why or Why Not
We already made the decision to issue the unsupported_fn_ptr_calling_conventions future compatibility warning. It has warned in dependencies since rust-lang#135767, which reached stable with Rust 1.87. That was released on 2025 May 17, and it is now June. As we already had erred on these ABI strings in most other positions, and warn on stable for function pointer types, this breakage has had reasonable foreshadowing.
Upgrading the warning to an error addresses a real problem. In some cases the Rust compiler can attempt to actually compute the ABI for calling a function with an unsupported ABI. We could accept this case and compute unsupported ABIs according to some other ABI, silently[^6]. However, this obviously exposes Rust to errors in codegen. We cannot lower directly to the "obvious", target-incorrect ABI and then trust code generators like LLVM to reliably error on these cases, either.
Other considerations include:
- We could refactor the compiler to defer ABI computations, but that seems like it would suffer the "whack-a-mole" problem close to linking instead of after parsing and expansion.
- We could run a deprecation cycle for the edge cases, but we would be warning highly marginal cases, like this trait declaration without a definition that cannot be implemented without error[^9].
pub trait UsedToSneakBy {
pub extern "gpu-kernel" fn sneaky();
}- The [crater run] on this PR's draft form suggests the primary issue is with implementations on function pointers, which has already been warned on, so it does not seem like we would be benefiting any real code.
- Converting this to a hard error now, in the same cycle that we ship the reanimation of the
unsupported_calling_conventionslint, means people who would otherwise have to deal with two lints only have to update their code in one batch. Of course, one of them is as breakage.
r? lang
Fixes rust-lang#86232 Fixes rust-lang#132430 Fixes rust-lang#138738 Fixes rust-lang#142107
[crater run]: rust-lang#142134 (comment)
[^9]: Upon any impl, even for provided fn within trait declarations, e.g. pub extern "gpu-kernel" fn sneaky() {}, different HIR types were used which would, in fact, get checked. Likewise for anything with function pointers. Thus we would be discussing deprecation cycles for code that is impotent or forewarned[^7].
[^4]: Some already will not compile, due to reaching ICEs or LLVM errors.
[^5]: That lint cannot be moved in a similar way yet because lints operate on HIR, so you cannot emit lints when the HIR has not been completely formed.
[^6]: We already do this for all AbiStr we cannot parse, pretending they are ExternAbi::Rust, but we also emit an error to prevent reaching too far into codegen.
[^7]: It actually did appear in two cases in rustc's test suite because we are a collection of Rust edge-cases by the simple fact that we don't care if the code actually runs. These cases are being excised in 643a9d2
rust-timer added a commit that referenced this pull request
Rollup merge of #142134 - workingjubilee:reject-unsupported-abi, r=jdonszelmann,RalfJung
Reject unsupported extern "{abi}"s consistently in all positions
Modify the handling of extern "{abi}" in the compiler so that it has consistent errors without regard to the position in the grammar.
What
Implement the following breakages:
- Promote
unsupported_fn_ptr_calling_conventionsfrom a warning to a hard error - Guarantee future edge-cases like trait declarations will not escape so that ABIs that have already been unusable in most positions will now be unusable in all positions. See "How" and "Why or Why Not" for more details.
In particular, these architecture-specific ABIs now only compile on their architectures[^4]:
- amdgpu: "gpu-kernel"
- arm: "aapcs", "C-cmse-nonsecure-entry", "C-cmse-nonsecure-call"
- avr: "avr-interrupt", "avr-non-blocking-interrupt"
- msp430: "msp430-interrupt"
- nvptx64: "gpu-kernel", "ptx-kernel"
- riscv32 and riscv64: "riscv-interrupt-m", "riscv-interrupt-s"
- x86: "thiscall"
- x86 and x86_64: "x86-interrupt"
- x86_64: "sysv64", "win64"
ABIs that are logically x86-specific but actually permitted on all Windows targets remain permitted on Windows, as before. For non-Windows targets, they error if we had previously done so in other positions.
How
We modify rustc_ast_lowering to prevent unsupported ABIs from leaking through the HIR without being checked for target support. They now emit hard errors for every case where we would return Invalid from AbiMap::canonize_abi. Previously ad-hoc checking on various HIR items required making sure we check every HIR item which could contain an extern "{abi}" string. This is a losing proposition compared to gating the lowering itself.
As a consequence, unsupported ABI strings error instead of triggering the warning unsupported_fn_ptr_calling_conventions. The code is also simpler compared to alternative implementations that might e.g. split on unstable vs. stable, only suffering some unavoidable complication to support the newly-revived unsupported_calling_conventions lint.[^5]
However, per #86232 this does cause errors for rare usages of extern "{abi}" that were theoretically possible to write in Rust source, without previous warning or error. For instance, trait declarations without impls were never checked. These are the exact kinds of leakages that this new approach prevents.
This differs from the following PRs:
- #141435 is orthogonal, as it adds a new lint for ABIs we have not warned on and are not touched by this PR
- #141877 is subsumed by this, in that this simply cuts out bad functionality instead of adding epicycles for stable code
Why or Why Not
We already made the decision to issue the unsupported_fn_ptr_calling_conventions future compatibility warning. It has warned in dependencies since #135767, which reached stable with Rust 1.87. That was released on 2025 May 17, and it is now June. As we already had erred on these ABI strings in most other positions, and warn on stable for function pointer types, this breakage has had reasonable foreshadowing.
Upgrading the warning to an error addresses a real problem. In some cases the Rust compiler can attempt to actually compute the ABI for calling a function with an unsupported ABI. We could accept this case and compute unsupported ABIs according to some other ABI, silently[^6]. However, this obviously exposes Rust to errors in codegen. We cannot lower directly to the "obvious", target-incorrect ABI and then trust code generators like LLVM to reliably error on these cases, either.
Other considerations include:
- We could refactor the compiler to defer ABI computations, but that seems like it would suffer the "whack-a-mole" problem close to linking instead of after parsing and expansion.
- We could run a deprecation cycle for the edge cases, but we would be warning highly marginal cases, like this trait declaration without a definition that cannot be implemented without error[^9].
pub trait UsedToSneakBy {
pub extern "gpu-kernel" fn sneaky();
}- The [crater run] on this PR's draft form suggests the primary issue is with implementations on function pointers, which has already been warned on, so it does not seem like we would be benefiting any real code.
- Converting this to a hard error now, in the same cycle that we ship the reanimation of the
unsupported_calling_conventionslint, means people who would otherwise have to deal with two lints only have to update their code in one batch. Of course, one of them is as breakage.
r? lang
Fixes #86232 Fixes #132430 Fixes #138738 Fixes #142107
[crater run]: #142134 (comment)
[^9]: Upon any impl, even for provided fn within trait declarations, e.g. pub extern "gpu-kernel" fn sneaky() {}, different HIR types were used which would, in fact, get checked. Likewise for anything with function pointers. Thus we would be discussing deprecation cycles for code that is impotent or forewarned[^7].
[^4]: Some already will not compile, due to reaching ICEs or LLVM errors.
[^5]: That lint cannot be moved in a similar way yet because lints operate on HIR, so you cannot emit lints when the HIR has not been completely formed.
[^6]: We already do this for all AbiStr we cannot parse, pretending they are ExternAbi::Rust, but we also emit an error to prevent reaching too far into codegen.
[^7]: It actually did appear in two cases in rustc's test suite because we are a collection of Rust edge-cases by the simple fact that we don't care if the code actually runs. These cases are being excised in 643a9d2
wip-sync pushed a commit to NetBSD/pkgsrc-wip that referenced this pull request
Pkgsrc changes:
- Adjust patches to adapt to upstream changes and new versions.
- assosicated checksums
Upstream changes relative to 1.88.0:
Version 1.89.0 (2025-08-07)
Language
- [Stabilize explicitly inferred const arguments (
feature(generic_arg_infer))] (rust-lang/rust#141610) - [Add a warn-by-default
mismatched_lifetime_syntaxeslint.] (rust-lang/rust#138677) This lint detects when the same lifetime is referred to by different syntax categories between function arguments and return values, which can be confusing to read, especially in unsafe code. This lint supersedes the warn-by-defaultelided_named_lifetimeslint. - [Expand
unpredictable_function_pointer_comparisonsto also lint on function pointer comparisons in external macros] (rust-lang/rust#134536) - [Make the
dangerous_implicit_autorefslint deny-by-default] (rust-lang/rust#141661) - [Stabilize the avx512 target features] (rust-lang/rust#138940)
- [Stabilize
klandwidekltarget features for x86] (rust-lang/rust#140766) - [Stabilize
sha512,sm3andsm4target features for x86] (rust-lang/rust#140767) - [Stabilize LoongArch target features
f,d,frecipe,lasx,lbt,lsx, andlvz] (rust-lang/rust#135015) - [Remove
i128andu128fromimproper_ctypes_definitions] (rust-lang/rust#137306) - [Stabilize
repr128(#[repr(u128)],#[repr(i128)])] (rust-lang/rust#138285) - [Allow
#![doc(test(attr(..)))]everywhere] (rust-lang/rust#140560) - [Extend temporary lifetime extension to also go through tuple struct and tuple variant constructors] (rust-lang/rust#140593)
Compiler
- [Default to non-leaf frame pointers on aarch64-linux] (rust-lang/rust#140832)
- [Enable non-leaf frame pointers for Arm64EC Windows] (rust-lang/rust#140862)
- [Set Apple frame pointers by architecture] (rust-lang/rust#141797)
Platform Support
- [Add new Tier-3 targets
loongarch32-unknown-noneandloongarch32-unknown-none-softfloat] (rust-lang/rust#142053)
Refer to Rust's platform support page for more information on Rust's tiered platform support.
Libraries
- [Specify the base path for
file!] (rust-lang/rust#134442) - [Allow storing
format_args!()in a variable] (rust-lang/rust#140748) - [Add
#[must_use]to[T; N]::map] (rust-lang/rust#140957) - [Implement
DerefMutforLazy{Cell,Lock}] (rust-lang/rust#129334) - [Implement
Defaultforarray::IntoIter] (rust-lang/rust#141574) - [Implement
Cloneforslice::ChunkBy] (rust-lang/rust#138016) - [Implement
io::Seekforio::Take] (rust-lang/rust#138023)
Stabilized APIs
- [
NonZero<char>] (https://doc.rust-lang.org/stable/std/num/struct.NonZero.html) - Many intrinsics for x86, not enumerated here
- AVX512 intrinsics
- [
SHA512,SM3andSM4intrinsics] (rust-lang/rust#126624)
- [
File::lock] (https://doc.rust-lang.org/stable/std/fs/struct.File.html#method.lock) - [
File::lock_shared] (https://doc.rust-lang.org/stable/std/fs/struct.File.html#method.lock_shared) - [
File::try_lock] (https://doc.rust-lang.org/stable/std/fs/struct.File.html#method.try_lock) - [
File::try_lock_shared] (https://doc.rust-lang.org/stable/std/fs/struct.File.html#method.try_lock_shared) - [
File::unlock] (https://doc.rust-lang.org/stable/std/fs/struct.File.html#method.unlock) - [
NonNull::from_ref] (https://doc.rust-lang.org/stable/std/ptr/struct.NonNull.html#method.from_ref) - [
NonNull::from_mut] (https://doc.rust-lang.org/stable/std/ptr/struct.NonNull.html#method.from_mut) - [
NonNull::without_provenance] (https://doc.rust-lang.org/stable/std/ptr/struct.NonNull.html#method.without_provenance) - [
NonNull::with_exposed_provenance] (https://doc.rust-lang.org/stable/std/ptr/struct.NonNull.html#method.with_exposed_provenance) - [
NonNull::expose_provenance] (https://doc.rust-lang.org/stable/std/ptr/struct.NonNull.html#method.expose_provenance) - [
OsString::leak] (https://doc.rust-lang.org/stable/std/ffi/struct.OsString.html#method.leak) - [
PathBuf::leak] (https://doc.rust-lang.org/stable/std/path/struct.PathBuf.html#method.leak) - [
Result::flatten] (https://doc.rust-lang.org/stable/std/result/enum.Result.html#method.flatten) - [
std::os::linux:🥅:TcpStreamExt::quickack] (https://doc.rust-lang.org/stable/std/os/linux/net/trait.TcpStreamExt.html#tymethod.quickack) - [
std::os::linux:🥅:TcpStreamExt::set_quickack] (https://doc.rust-lang.org/stable/std/os/linux/net/trait.TcpStreamExt.html#tymethod.set_quickack)
These previously stable APIs are now stable in const contexts:
- [
<[T; N]>::as_mut_slice] (https://doc.rust-lang.org/stable/std/primitive.array.html#method.as_mut_slice) - [
<[u8]>::eq_ignore_ascii_case] (https://doc.rust-lang.org/stable/std/primitive.slice.html#impl-%5Bu8%5D/method.eq_ignore_ascii_case) - [
str::eq_ignore_ascii_case] (https://doc.rust-lang.org/stable/std/primitive.str.html#impl-str/method.eq_ignore_ascii_case)
Cargo
[
cargo fixandcargo clippy --fixnow default to the same Cargo target selection as other build commands.] (rust-lang/cargo#15192) Previously it would apply to all targets (like binaries, examples, tests, etc.). The--editionflag still applies to all targets.[Stabilize doctest-xcompile.] (rust-lang/cargo#15462) Doctests are now tested when cross-compiling. Just like other tests, it will use the [
runnersetting] (https://doc.rust-lang.org/cargo/reference/config.html#targettriplerunner) to run the tests. If you need to disable tests for a target, you can use the [ignore doctest attribute] (https://doc.rust-lang.org/rustdoc/write-documentation/documentation-tests.html#ignoring-targets) to specify the targets to ignore.
Rustdoc
- [On mobile, make the sidebar full width and linewrap] (rust-lang/rust#139831). This makes long section and item names much easier to deal with on mobile.
Compatibility Notes
[Make
missing_fragment_specifieran unconditional error] (rust-lang/rust#128425)[Enabling the
neontarget feature onaarch64-unknown-none-softfloatcauses a warning] (rust-lang/rust#135160) because mixing code with and without that target feature is not properly supported by LLVM-
- Introduces a small breaking change affecting
?Sizedbounds on impls on recursive types which contain associated type projections. It is not expected to affect any existing published crates. Can be fixed by refactoring the involved types or opting into thesized_hierarchyunstable feature. See the [FCP report] (rust-lang/rust#137944 (comment)) for a code example.
- Introduces a small breaking change affecting
The warn-by-default
elided_named_lifetimeslint is [superseded by the warn-by-defaultmismatched_lifetime_syntaxeslint.] (rust-lang/rust#138677)[Error on recursive opaque types earlier in the type checker] (rust-lang/rust#139419)
[Type inference side effects from requiring element types of array repeat expressions are
Copyare now only available at the end of type checking] (rust-lang/rust#139635)[The deprecated accidentally-stable
std::intrinsics::{copy,copy_nonoverlapping,write_bytes}are now proper intrinsics] (rust-lang/rust#139916). There are no debug assertions guarding against UB, and they cannot be coerced to function pointers.[Remove long-deprecated
std::intrinsics::drop_in_place] (rust-lang/rust#140151)[Make well-formedness predicates no longer coinductive] (rust-lang/rust#140208)
[Remove hack when checking impl method compatibility] (rust-lang/rust#140557)
[Remove unnecessary type inference due to built-in trait object impls] (rust-lang/rust#141352)
[Lint against "stdcall", "fastcall", and "cdecl" on non-x86-32 targets] (rust-lang/rust#141435)
[Future incompatibility warnings relating to the never type (
!) are now reported in dependencies] (rust-lang/rust#141937)[Ensure
std::ptr::copy_*intrinsics also perform the static self-init checks] (rust-lang/rust#142575)
Internal Changes
These changes do not affect any public interfaces of Rust, but they represent significant improvements to the performance or internals of rustc and related tools.
- [Correctly un-remap compiler sources paths with the
rustc-devcomponent] (rust-lang/rust#142377)
tmeijn pushed a commit to tmeijn/dotfiles that referenced this pull request
This MR contains the following updates:
| Package | Update | Change |
|---|---|---|
| rust | minor | 1.88.0 -> 1.89.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.89.0
==========================
Language
- Stabilize explicitly inferred const arguments (
feature(generic_arg_infer)) - Add a warn-by-default
mismatched_lifetime_syntaxeslint. This lint detects when the same lifetime is referred to by different syntax categories between function arguments and return values, which can be confusing to read, especially in unsafe code. This lint supersedes the warn-by-defaultelided_named_lifetimeslint. - Expand
unpredictable_function_pointer_comparisonsto also lint on function pointer comparisons in external macros - Make the
dangerous_implicit_autorefslint deny-by-default - Stabilize the avx512 target features
- Stabilize
klandwidekltarget features for x86 - Stabilize
sha512,sm3andsm4target features for x86 - Stabilize LoongArch target features
f,d,frecipe,lasx,lbt,lsx, andlvz - Remove
i128andu128fromimproper_ctypes_definitions - Stabilize
repr128(#[repr(u128)],#[repr(i128)]) - Allow
#![doc(test(attr(..)))]everywhere - Extend temporary lifetime extension to also go through tuple struct and tuple variant constructors
extern "C"functions on thewasm32-unknown-unknowntarget now have a standards compliant ABI
Compiler
- Default to non-leaf frame pointers on aarch64-linux
- Enable non-leaf frame pointers for Arm64EC Windows
- Set Apple frame pointers by architecture
Platform Support
- Add new Tier-3 targets
loongarch32-unknown-noneandloongarch32-unknown-none-softfloat x86_64-apple-darwinis in the process of being demoted to Tier 2 with host tools
Refer to Rust's platform support page for more information on Rust's tiered platform support.
Libraries
- Specify the base path for
file! - Allow storing
format_args!()in a variable - Add
#[must_use]to[T; N]::map - Implement
DerefMutforLazy{Cell,Lock} - Implement
Defaultforarray::IntoIter - Implement
Cloneforslice::ChunkBy - Implement
io::Seekforio::Take
Stabilized APIs
NonZero<char>- Many intrinsics for x86, not enumerated here
File::lockFile::lock_sharedFile::try_lockFile::try_lock_sharedFile::unlockNonNull::from_refNonNull::from_mutNonNull::without_provenanceNonNull::with_exposed_provenanceNonNull::expose_provenanceOsString::leakPathBuf::leakResult::flattenstd::os::linux:🥅:TcpStreamExt::quickackstd::os::linux:🥅:TcpStreamExt::set_quickack
These previously stable APIs are now stable in const contexts:
Cargo
cargo fixandcargo clippy --fixnow default to the same Cargo target selection as other build commands. Previously it would apply to all targets (like binaries, examples, tests, etc.). The--editionflag still applies to all targets.- Stabilize doctest-xcompile. Doctests are now tested when cross-compiling. Just like other tests, it will use the
runnersetting to run the tests. If you need to disable tests for a target, you can use the ignore doctest attribute to specify the targets to ignore.
Rustdoc
- On mobile, make the sidebar full width and linewrap. This makes long section and item names much easier to deal with on mobile.
Compatibility Notes
- Make
missing_fragment_specifieran unconditional error - Enabling the
neontarget feature onaarch64-unknown-none-softfloatcauses a warning because mixing code with and without that target feature is not properly supported by LLVM - Sized Hierarchy: Part I
- Introduces a small breaking change affecting
?Sizedbounds on impls on recursive types which contain associated type projections. It is not expected to affect any existing published crates. Can be fixed by refactoring the involved types or opting into thesized_hierarchyunstable feature. See the [FCP report](rust-lang/rust#137944 (comment)) for a code example.
- Introduces a small breaking change affecting
- The warn-by-default
elided_named_lifetimeslint is superseded by the warn-by-defaultmismatched_lifetime_syntaxeslint. - Error on recursive opaque types earlier in the type checker
- Type inference side effects from requiring element types of array repeat expressions are
Copyare now only available at the end of type checking - The deprecated accidentally-stable
std::intrinsics::{copy,copy_nonoverlapping,write_bytes}are now proper intrinsics. There are no debug assertions guarding against UB, and they cannot be coerced to function pointers. - Remove long-deprecated
std::intrinsics::drop_in_place - Make well-formedness predicates no longer coinductive
- Remove hack when checking impl method compatibility
- Remove unnecessary type inference due to built-in trait object impls
- Lint against "stdcall", "fastcall", and "cdecl" on non-x86-32 targets
- Future incompatibility warnings relating to the never type (
!) are now reported in dependencies - Ensure
std::ptr::copy_*intrinsics also perform the static self-init checks extern "C"functions on thewasm32-unknown-unknowntarget now have a standards compliant ABI
Internal Changes
These changes do not affect any public interfaces of Rust, but they represent significant improvements to the performance or internals of rustc and related tools.
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.
netbsd-srcmastr pushed a commit to NetBSD/pkgsrc that referenced this pull request
Pkgsrc changes:
- Disable the build of NetBSD-*aarch64eb, since it now fails both to cross-build and to build natively. Ref. rust-lang/rust#146842
- Adjusted patches, checksum updates etc.
Upstream changes:
Version 1.90 (2025-09-18)
Language
- [Split up the
unknown_or_malformed_diagnostic_attributeslint] (rust-lang/rust#140717). This lint has been split up into four finer-grained lints, withunknown_or_malformed_diagnostic_attributesnow being the lint group that contains these lints:unknown_diagnostic_attributes: unknown to the current compilermisplaced_diagnostic_attributes: placed on the wrong itemmalformed_diagnostic_attributes: malformed attribute syntax or optionsmalformed_diagnostic_format_literals: malformed format string literal
- [Allow constants whose final value has references to mutable/external memory, but reject such constants as patterns] (rust-lang/rust#140942)
- [Allow volatile access to non-Rust memory, including address 0] (rust-lang/rust#141260)
Compiler
- [Use
lldby default onx86_64-unknown-linux-gnu] (rust-lang/rust#140525). - [Tier 3
musltargets now link dynamically by default] (rust-lang/rust#144410). Affected targets:mips64-unknown-linux-muslabi64powerpc64-unknown-linux-muslpowerpc-unknown-linux-muslpowerpc-unknown-linux-muslsperiscv32gc-unknown-linux-musls390x-unknown-linux-muslthumbv7neon-unknown-linux-musleabihf
Platform Support
- [Demote
x86_64-apple-darwinto Tier 2 with host tools] (rust-lang/rust#145252)
Refer to Rust's platform support page for more information on Rust's tiered platform support.
Libraries
- [Stabilize
u*::{checked,overflowing,saturating,wrapping}_sub_signed] (rust-lang/rust#126043) - [Allow comparisons between
CStr,CString, andCow<CStr>] (rust-lang/rust#137268) - [Remove some unsized tuple impls since unsized tuples can't be constructed] (rust-lang/rust#138340)
- [Set
MSG_NOSIGNALforUnixStream] (rust-lang/rust#140005) - [
proc_macro::Ident::newnow supports$crate.] (rust-lang/rust#141996) - [Guarantee the pointer returned from
Thread::into_rawhas at least 8 bytes of alignment] (rust-lang/rust#143859)
Stabilized APIs
- [
u{n}::checked_sub_signed] (https://doc.rust-lang.org/stable/std/primitive.usize.html#method.checked_sub_signed) - [
u{n}::overflowing_sub_signed] (https://doc.rust-lang.org/stable/std/primitive.usize.html#method.overflowing_sub_signed) - [
u{n}::saturating_sub_signed] (https://doc.rust-lang.org/stable/std/primitive.usize.html#method.saturating_sub_signed) - [
u{n}::wrapping_sub_signed] (https://doc.rust-lang.org/stable/std/primitive.usize.html#method.wrapping_sub_signed) - [
impl Copy for IntErrorKind] (https://doc.rust-lang.org/stable/std/num/enum.IntErrorKind.html#impl-Copy-for-IntErrorKind) - [
impl Hash for IntErrorKind] (https://doc.rust-lang.org/stable/std/num/enum.IntErrorKind.html#impl-Hash-for-IntErrorKind) - [
impl PartialEq<&CStr> for CStr] (https://doc.rust-lang.org/stable/std/ffi/struct.CStr.html#impl-PartialEq%3C%26CStr%3E-for-CStr) - [
impl PartialEq<CString> for CStr] (https://doc.rust-lang.org/stable/std/ffi/struct.CStr.html#impl-PartialEq%3CCString%3E-for-CStr) - [
impl PartialEq<Cow<CStr>> for CStr] (https://doc.rust-lang.org/stable/std/ffi/struct.CStr.html#impl-PartialEq%3CCow%3C'_,+CStr%3E%3E-for-CStr) - [
impl PartialEq<&CStr> for CString] (https://doc.rust-lang.org/stable/std/ffi/struct.CString.html#impl-PartialEq%3C%26CStr%3E-for-CString) - [
impl PartialEq<CStr> for CString] (https://doc.rust-lang.org/stable/std/ffi/struct.CString.html#impl-PartialEq%3CCStr%3E-for-CString) - [
impl PartialEq<Cow<CStr>> for CString] (https://doc.rust-lang.org/stable/std/ffi/struct.CString.html#impl-PartialEq%3CCow%3C'_,+CStr%3E%3E-for-CString) - [
impl PartialEq<&CStr> for Cow<CStr>] (https://doc.rust-lang.org/stable/std/borrow/enum.Cow.html#impl-PartialEq%3C%26CStr%3E-for-Cow%3C'_,+CStr%3E) - [
impl PartialEq<CStr> for Cow<CStr>] (https://doc.rust-lang.org/stable/std/borrow/enum.Cow.html#impl-PartialEq%3CCStr%3E-for-Cow%3C'_,+CStr%3E) - [
impl PartialEq<CString> for Cow<CStr>] (https://doc.rust-lang.org/stable/std/borrow/enum.Cow.html#impl-PartialEq%3CCString%3E-for-Cow%3C'_,+CStr%3E)
These previously stable APIs are now stable in const contexts:
- [
<[T]>::reverse] (https://doc.rust-lang.org/stable/std/primitive.slice.html#method.reverse) - [
f32::floor] (https://doc.rust-lang.org/stable/std/primitive.f32.html#method.floor) - [
f32::ceil] (https://doc.rust-lang.org/stable/std/primitive.f32.html#method.ceil) - [
f32::trunc] (https://doc.rust-lang.org/stable/std/primitive.f32.html#method.trunc) - [
f32::fract] (https://doc.rust-lang.org/stable/std/primitive.f32.html#method.fract) (https://doc.rust-lang.org/stable/std/primitive.f32.html#method.fract) - [
f32::round] (https://doc.rust-lang.org/stable/std/primitive.f32.html#method.round) - [
f32::round_ties_even] (https://doc.rust-lang.org/stable/std/primitive.f32.html#method.round_ties_even) - [
f64::floor] (https://doc.rust-lang.org/stable/std/primitive.f64.html#method.floor) - [
f64::ceil] (https://doc.rust-lang.org/stable/std/primitive.f64.html#method.ceil) - [
f64::trunc] (https://doc.rust-lang.org/stable/std/primitive.f64.html#method.trunc) - [
f64::fract] (https://doc.rust-lang.org/stable/std/primitive.f64.html#method.fract) - [
f64::round] (https://doc.rust-lang.org/stable/std/primitive.f64.html#method.round) - [
f64::round_ties_even] (https://doc.rust-lang.org/stable/std/primitive.f64.html#method.round_ties_even)
Cargo
- [Add
http.proxy-cainfoconfig for proxy certs] (rust-lang/cargo#15374) - [Use
gixforcargo package] (rust-lang/cargo#15534) - [feat(publish): Stabilize multi-package publishing] (rust-lang/cargo#15636)
Rustdoc
- [Add ways to collapse all impl blocks]
(rust-lang/rust#141663). Previously the
"Summary" button and "-" keyboard shortcut would never collapse
implblocks, now they do when shift is held - [Display unsafe attributes with
unsafe()wrappers] (rust-lang/rust#143662)
Compatibility Notes
- [Use
lldby default onx86_64-unknown-linux-gnu] (rust-lang/rust#140525). See also <https://blog.rust-lang.org/2025/09/01/rust-lld-on-1.90.0-stable/>. - [Make
core::iter::Fuse'sDefaultimpl constructI::default()internally as promised in the docs instead of always being empty] (rust-lang/rust#140985) - [Set
MSG_NOSIGNALforUnixStream] (rust-lang/rust#140005) This may change program behavior but results in the same behavior as other primitives (e.g., stdout, network sockets). Programs relying on signals to terminate them should update handling of sockets to handle errors on write by exiting. - [On Unix
std::env::home_dirwill use the fallback if theHOMEenvironment variable is empty] (rust-lang/rust#141840) - We now [reject unsupported
extern "{abi}"s consistently in all positions] (rust-lang/rust#142134). This primarily affects the use of implementing traits on anextern "{abi}"function pointer, likeextern "stdcall" fn(), on a platform that doesn't support that, like aarch64-unknown-linux-gnu. Direct usage of these unsupported ABI strings by declaring or defining functions was already rejected, so this is only a change for consistency. - [const-eval: error when initializing a static writes to that static] (rust-lang/rust#143084)
- [Check that the
proc_macro_derivemacro has correct arguments when applied to the crate root] (rust-lang/rust#143607)
Version 1.89.0 (2025-08-07)
Language
- [Stabilize explicitly inferred const arguments (
feature(generic_arg_infer))] (rust-lang/rust#141610) - [Add a warn-by-default
mismatched_lifetime_syntaxeslint.] (rust-lang/rust#138677) This lint detects when the same lifetime is referred to by different syntax categories between function arguments and return values, which can be confusing to read, especially in unsafe code. This lint supersedes the warn-by-defaultelided_named_lifetimeslint. - [Expand
unpredictable_function_pointer_comparisonsto also lint on function pointer comparisons in external macros] (rust-lang/rust#134536) - [Make the
dangerous_implicit_autorefslint deny-by-default] (rust-lang/rust#141661) - [Stabilize the avx512 target features] (rust-lang/rust#138940)
- [Stabilize
klandwidekltarget features for x86] (rust-lang/rust#140766) - [Stabilize
sha512,sm3andsm4target features for x86] (rust-lang/rust#140767) - [Stabilize LoongArch target features
f,d,frecipe,lasx,lbt,lsx, andlvz] (rust-lang/rust#135015) - [Remove
i128andu128fromimproper_ctypes_definitions] (rust-lang/rust#137306) - [Stabilize
repr128(#[repr(u128)],#[repr(i128)])] (rust-lang/rust#138285) - [Allow
#![doc(test(attr(..)))]everywhere] (rust-lang/rust#140560) - [Extend temporary lifetime extension to also go through tuple struct and tuple variant constructors] (rust-lang/rust#140593)
Compiler
- [Default to non-leaf frame pointers on aarch64-linux] (rust-lang/rust#140832)
- [Enable non-leaf frame pointers for Arm64EC Windows] (rust-lang/rust#140862)
- [Set Apple frame pointers by architecture] (rust-lang/rust#141797)
Platform Support
- [Add new Tier-3 targets
loongarch32-unknown-noneandloongarch32-unknown-none-softfloat] (rust-lang/rust#142053)
Refer to Rust's platform support page for more information on Rust's tiered platform support.
Libraries
- [Specify the base path for
file!] (rust-lang/rust#134442) - [Allow storing
format_args!()in a variable] (rust-lang/rust#140748) - [Add
#[must_use]to[T; N]::map] (rust-lang/rust#140957) - [Implement
DerefMutforLazy{Cell,Lock}] (rust-lang/rust#129334) - [Implement
Defaultforarray::IntoIter] (rust-lang/rust#141574) - [Implement
Cloneforslice::ChunkBy] (rust-lang/rust#138016) - [Implement
io::Seekforio::Take] (rust-lang/rust#138023)
Stabilized APIs
- [
NonZero<char>] (https://doc.rust-lang.org/stable/std/num/struct.NonZero.html) - Many intrinsics for x86, not enumerated here
- AVX512 intrinsics
- [
SHA512,SM3andSM4intrinsics] (rust-lang/rust#126624)
- [
File::lock] (https://doc.rust-lang.org/stable/std/fs/struct.File.html#method.lock) - [
File::lock_shared] (https://doc.rust-lang.org/stable/std/fs/struct.File.html#method.lock_shared) - [
File::try_lock] (https://doc.rust-lang.org/stable/std/fs/struct.File.html#method.try_lock) - [
File::try_lock_shared] (https://doc.rust-lang.org/stable/std/fs/struct.File.html#method.try_lock_shared) - [
File::unlock] (https://doc.rust-lang.org/stable/std/fs/struct.File.html#method.unlock) - [
NonNull::from_ref] (https://doc.rust-lang.org/stable/std/ptr/struct.NonNull.html#method.from_ref) - [
NonNull::from_mut] (https://doc.rust-lang.org/stable/std/ptr/struct.NonNull.html#method.from_mut) - [
NonNull::without_provenance] (https://doc.rust-lang.org/stable/std/ptr/struct.NonNull.html#method.without_provenance) - [
NonNull::with_exposed_provenance] (https://doc.rust-lang.org/stable/std/ptr/struct.NonNull.html#method.with_exposed_provenance) - [
NonNull::expose_provenance] (https://doc.rust-lang.org/stable/std/ptr/struct.NonNull.html#method.expose_provenance) - [
OsString::leak] (https://doc.rust-lang.org/stable/std/ffi/struct.OsString.html#method.leak) - [
PathBuf::leak] (https://doc.rust-lang.org/stable/std/path/struct.PathBuf.html#method.leak) - [
Result::flatten] (https://doc.rust-lang.org/stable/std/result/enum.Result.html#method.flatten) - [
std::os::linux:🥅:TcpStreamExt::quickack] (https://doc.rust-lang.org/stable/std/os/linux/net/trait.TcpStreamExt.html#tymethod.quickack) - [
std::os::linux:🥅:TcpStreamExt::set_quickack] (https://doc.rust-lang.org/stable/std/os/linux/net/trait.TcpStreamExt.html#tymethod.set_quickack)
These previously stable APIs are now stable in const contexts:
- [
<[T; N]>::as_mut_slice] (https://doc.rust-lang.org/stable/std/primitive.array.html#method.as_mut_slice) - [
<[u8]>::eq_ignore_ascii_case] (https://doc.rust-lang.org/stable/std/primitive.slice.html#impl-%5Bu8%5D/method.eq_ignore_ascii_case) - [
str::eq_ignore_ascii_case] (https://doc.rust-lang.org/stable/std/primitive.str.html#impl-str/method.eq_ignore_ascii_case)
Cargo
[
cargo fixandcargo clippy --fixnow default to the same Cargo target selection as other build commands.] (rust-lang/cargo#15192) Previously it would apply to all targets (like binaries, examples, tests, etc.). The--editionflag still applies to all targets.[Stabilize doctest-xcompile.] (rust-lang/cargo#15462) Doctests are now tested when cross-compiling. Just like other tests, it will use the [
runnersetting] (https://doc.rust-lang.org/cargo/reference/config.html#targettriplerunner) to run the tests. If you need to disable tests for a target, you can use the [ignore doctest attribute] (https://doc.rust-lang.org/rustdoc/write-documentation/documentation-tests.html#ignoring-targets) to specify the targets to ignore.
Rustdoc
- [On mobile, make the sidebar full width and linewrap] (rust-lang/rust#139831). This makes long section and item names much easier to deal with on mobile.
Compatibility Notes
[Make
missing_fragment_specifieran unconditional error] (rust-lang/rust#128425)[Enabling the
neontarget feature onaarch64-unknown-none-softfloatcauses a warning] (rust-lang/rust#135160) because mixing code with and without that target feature is not properly supported by LLVM-
- Introduces a small breaking change affecting
?Sizedbounds on impls on recursive types which contain associated type projections. It is not expected to affect any existing published crates. Can be fixed by refactoring the involved types or opting into thesized_hierarchyunstable feature. See the [FCP report] (rust-lang/rust#137944 (comment)) for a code example.
- Introduces a small breaking change affecting
The warn-by-default
elided_named_lifetimeslint is [superseded by the warn-by-defaultmismatched_lifetime_syntaxeslint.] (rust-lang/rust#138677)[Error on recursive opaque types earlier in the type checker] (rust-lang/rust#139419)
[Type inference side effects from requiring element types of array repeat expressions are
Copyare now only available at the end of type checking] (rust-lang/rust#139635)[The deprecated accidentally-stable
std::intrinsics::{copy,copy_nonoverlapping,write_bytes}are now proper intrinsics] (rust-lang/rust#139916). There are no debug assertions guarding against UB, and they cannot be coerced to function pointers.[Remove long-deprecated
std::intrinsics::drop_in_place] (rust-lang/rust#140151)[Make well-formedness predicates no longer coinductive] (rust-lang/rust#140208)
[Remove hack when checking impl method compatibility] (rust-lang/rust#140557)
[Remove unnecessary type inference due to built-in trait object impls] (rust-lang/rust#141352)
[Lint against "stdcall", "fastcall", and "cdecl" on non-x86-32 targets] (rust-lang/rust#141435)
[Future incompatibility warnings relating to the never type (
!) are now reported in dependencies] (rust-lang/rust#141937)[Ensure
std::ptr::copy_*intrinsics also perform the static self-init checks] (rust-lang/rust#142575)
Internal Changes
These changes do not affect any public interfaces of Rust, but they represent significant improvements to the performance or internals of rustc and related tools.
- [Correctly un-remap compiler sources paths with the
rustc-devcomponent] (rust-lang/rust#142377)
netbsd-srcmastr pushed a commit to NetBSD/pkgsrc that referenced this pull request
Pkgsrc changes:
- Disable the build of NetBSD-*aarch64eb, since it now fails both to cross-build and to build natively. Ref. rust-lang/rust#146842
- Adjusted patches, checksum updates etc.
Upstream changes:
Version 1.90 (2025-09-18)
Language
- [Split up the
unknown_or_malformed_diagnostic_attributeslint] (rust-lang/rust#140717). This lint has been split up into four finer-grained lints, withunknown_or_malformed_diagnostic_attributesnow being the lint group that contains these lints:unknown_diagnostic_attributes: unknown to the current compilermisplaced_diagnostic_attributes: placed on the wrong itemmalformed_diagnostic_attributes: malformed attribute syntax or optionsmalformed_diagnostic_format_literals: malformed format string literal
- [Allow constants whose final value has references to mutable/external memory, but reject such constants as patterns] (rust-lang/rust#140942)
- [Allow volatile access to non-Rust memory, including address 0] (rust-lang/rust#141260)
Compiler
- [Use
lldby default onx86_64-unknown-linux-gnu] (rust-lang/rust#140525). - [Tier 3
musltargets now link dynamically by default] (rust-lang/rust#144410). Affected targets:mips64-unknown-linux-muslabi64powerpc64-unknown-linux-muslpowerpc-unknown-linux-muslpowerpc-unknown-linux-muslsperiscv32gc-unknown-linux-musls390x-unknown-linux-muslthumbv7neon-unknown-linux-musleabihf
Platform Support
- [Demote
x86_64-apple-darwinto Tier 2 with host tools] (rust-lang/rust#145252)
Refer to Rust's platform support page for more information on Rust's tiered platform support.
Libraries
- [Stabilize
u*::{checked,overflowing,saturating,wrapping}_sub_signed] (rust-lang/rust#126043) - [Allow comparisons between
CStr,CString, andCow<CStr>] (rust-lang/rust#137268) - [Remove some unsized tuple impls since unsized tuples can't be constructed] (rust-lang/rust#138340)
- [Set
MSG_NOSIGNALforUnixStream] (rust-lang/rust#140005) - [
proc_macro::Ident::newnow supports$crate.] (rust-lang/rust#141996) - [Guarantee the pointer returned from
Thread::into_rawhas at least 8 bytes of alignment] (rust-lang/rust#143859)
Stabilized APIs
- [
u{n}::checked_sub_signed] (https://doc.rust-lang.org/stable/std/primitive.usize.html#method.checked_sub_signed) - [
u{n}::overflowing_sub_signed] (https://doc.rust-lang.org/stable/std/primitive.usize.html#method.overflowing_sub_signed) - [
u{n}::saturating_sub_signed] (https://doc.rust-lang.org/stable/std/primitive.usize.html#method.saturating_sub_signed) - [
u{n}::wrapping_sub_signed] (https://doc.rust-lang.org/stable/std/primitive.usize.html#method.wrapping_sub_signed) - [
impl Copy for IntErrorKind] (https://doc.rust-lang.org/stable/std/num/enum.IntErrorKind.html#impl-Copy-for-IntErrorKind) - [
impl Hash for IntErrorKind] (https://doc.rust-lang.org/stable/std/num/enum.IntErrorKind.html#impl-Hash-for-IntErrorKind) - [
impl PartialEq<&CStr> for CStr] (https://doc.rust-lang.org/stable/std/ffi/struct.CStr.html#impl-PartialEq%3C%26CStr%3E-for-CStr) - [
impl PartialEq<CString> for CStr] (https://doc.rust-lang.org/stable/std/ffi/struct.CStr.html#impl-PartialEq%3CCString%3E-for-CStr) - [
impl PartialEq<Cow<CStr>> for CStr] (https://doc.rust-lang.org/stable/std/ffi/struct.CStr.html#impl-PartialEq%3CCow%3C'_,+CStr%3E%3E-for-CStr) - [
impl PartialEq<&CStr> for CString] (https://doc.rust-lang.org/stable/std/ffi/struct.CString.html#impl-PartialEq%3C%26CStr%3E-for-CString) - [
impl PartialEq<CStr> for CString] (https://doc.rust-lang.org/stable/std/ffi/struct.CString.html#impl-PartialEq%3CCStr%3E-for-CString) - [
impl PartialEq<Cow<CStr>> for CString] (https://doc.rust-lang.org/stable/std/ffi/struct.CString.html#impl-PartialEq%3CCow%3C'_,+CStr%3E%3E-for-CString) - [
impl PartialEq<&CStr> for Cow<CStr>] (https://doc.rust-lang.org/stable/std/borrow/enum.Cow.html#impl-PartialEq%3C%26CStr%3E-for-Cow%3C'_,+CStr%3E) - [
impl PartialEq<CStr> for Cow<CStr>] (https://doc.rust-lang.org/stable/std/borrow/enum.Cow.html#impl-PartialEq%3CCStr%3E-for-Cow%3C'_,+CStr%3E) - [
impl PartialEq<CString> for Cow<CStr>] (https://doc.rust-lang.org/stable/std/borrow/enum.Cow.html#impl-PartialEq%3CCString%3E-for-Cow%3C'_,+CStr%3E)
These previously stable APIs are now stable in const contexts:
- [
<[T]>::reverse] (https://doc.rust-lang.org/stable/std/primitive.slice.html#method.reverse) - [
f32::floor] (https://doc.rust-lang.org/stable/std/primitive.f32.html#method.floor) - [
f32::ceil] (https://doc.rust-lang.org/stable/std/primitive.f32.html#method.ceil) - [
f32::trunc] (https://doc.rust-lang.org/stable/std/primitive.f32.html#method.trunc) - [
f32::fract] (https://doc.rust-lang.org/stable/std/primitive.f32.html#method.fract) (https://doc.rust-lang.org/stable/std/primitive.f32.html#method.fract) - [
f32::round] (https://doc.rust-lang.org/stable/std/primitive.f32.html#method.round) - [
f32::round_ties_even] (https://doc.rust-lang.org/stable/std/primitive.f32.html#method.round_ties_even) - [
f64::floor] (https://doc.rust-lang.org/stable/std/primitive.f64.html#method.floor) - [
f64::ceil] (https://doc.rust-lang.org/stable/std/primitive.f64.html#method.ceil) - [
f64::trunc] (https://doc.rust-lang.org/stable/std/primitive.f64.html#method.trunc) - [
f64::fract] (https://doc.rust-lang.org/stable/std/primitive.f64.html#method.fract) - [
f64::round] (https://doc.rust-lang.org/stable/std/primitive.f64.html#method.round) - [
f64::round_ties_even] (https://doc.rust-lang.org/stable/std/primitive.f64.html#method.round_ties_even)
Cargo
- [Add
http.proxy-cainfoconfig for proxy certs] (rust-lang/cargo#15374) - [Use
gixforcargo package] (rust-lang/cargo#15534) - [feat(publish): Stabilize multi-package publishing] (rust-lang/cargo#15636)
Rustdoc
- [Add ways to collapse all impl blocks]
(rust-lang/rust#141663). Previously the
"Summary" button and "-" keyboard shortcut would never collapse
implblocks, now they do when shift is held - [Display unsafe attributes with
unsafe()wrappers] (rust-lang/rust#143662)
Compatibility Notes
- [Use
lldby default onx86_64-unknown-linux-gnu] (rust-lang/rust#140525). See also <https://blog.rust-lang.org/2025/09/01/rust-lld-on-1.90.0-stable/>. - [Make
core::iter::Fuse'sDefaultimpl constructI::default()internally as promised in the docs instead of always being empty] (rust-lang/rust#140985) - [Set
MSG_NOSIGNALforUnixStream] (rust-lang/rust#140005) This may change program behavior but results in the same behavior as other primitives (e.g., stdout, network sockets). Programs relying on signals to terminate them should update handling of sockets to handle errors on write by exiting. - [On Unix
std::env::home_dirwill use the fallback if theHOMEenvironment variable is empty] (rust-lang/rust#141840) - We now [reject unsupported
extern "{abi}"s consistently in all positions] (rust-lang/rust#142134). This primarily affects the use of implementing traits on anextern "{abi}"function pointer, likeextern "stdcall" fn(), on a platform that doesn't support that, like aarch64-unknown-linux-gnu. Direct usage of these unsupported ABI strings by declaring or defining functions was already rejected, so this is only a change for consistency. - [const-eval: error when initializing a static writes to that static] (rust-lang/rust#143084)
- [Check that the
proc_macro_derivemacro has correct arguments when applied to the crate root] (rust-lang/rust#143607)
Version 1.89.0 (2025-08-07)
Language
- [Stabilize explicitly inferred const arguments (
feature(generic_arg_infer))] (rust-lang/rust#141610) - [Add a warn-by-default
mismatched_lifetime_syntaxeslint.] (rust-lang/rust#138677) This lint detects when the same lifetime is referred to by different syntax categories between function arguments and return values, which can be confusing to read, especially in unsafe code. This lint supersedes the warn-by-defaultelided_named_lifetimeslint. - [Expand
unpredictable_function_pointer_comparisonsto also lint on function pointer comparisons in external macros] (rust-lang/rust#134536) - [Make the
dangerous_implicit_autorefslint deny-by-default] (rust-lang/rust#141661) - [Stabilize the avx512 target features] (rust-lang/rust#138940)
- [Stabilize
klandwidekltarget features for x86] (rust-lang/rust#140766) - [Stabilize
sha512,sm3andsm4target features for x86] (rust-lang/rust#140767) - [Stabilize LoongArch target features
f,d,frecipe,lasx,lbt,lsx, andlvz] (rust-lang/rust#135015) - [Remove
i128andu128fromimproper_ctypes_definitions] (rust-lang/rust#137306) - [Stabilize
repr128(#[repr(u128)],#[repr(i128)])] (rust-lang/rust#138285) - [Allow
#![doc(test(attr(..)))]everywhere] (rust-lang/rust#140560) - [Extend temporary lifetime extension to also go through tuple struct and tuple variant constructors] (rust-lang/rust#140593)
Compiler
- [Default to non-leaf frame pointers on aarch64-linux] (rust-lang/rust#140832)
- [Enable non-leaf frame pointers for Arm64EC Windows] (rust-lang/rust#140862)
- [Set Apple frame pointers by architecture] (rust-lang/rust#141797)
Platform Support
- [Add new Tier-3 targets
loongarch32-unknown-noneandloongarch32-unknown-none-softfloat] (rust-lang/rust#142053)
Refer to Rust's platform support page for more information on Rust's tiered platform support.
Libraries
- [Specify the base path for
file!] (rust-lang/rust#134442) - [Allow storing
format_args!()in a variable] (rust-lang/rust#140748) - [Add
#[must_use]to[T; N]::map] (rust-lang/rust#140957) - [Implement
DerefMutforLazy{Cell,Lock}] (rust-lang/rust#129334) - [Implement
Defaultforarray::IntoIter] (rust-lang/rust#141574) - [Implement
Cloneforslice::ChunkBy] (rust-lang/rust#138016) - [Implement
io::Seekforio::Take] (rust-lang/rust#138023)
Stabilized APIs
- [
NonZero<char>] (https://doc.rust-lang.org/stable/std/num/struct.NonZero.html) - Many intrinsics for x86, not enumerated here
- AVX512 intrinsics
- [
SHA512,SM3andSM4intrinsics] (rust-lang/rust#126624)
- [
File::lock] (https://doc.rust-lang.org/stable/std/fs/struct.File.html#method.lock) - [
File::lock_shared] (https://doc.rust-lang.org/stable/std/fs/struct.File.html#method.lock_shared) - [
File::try_lock] (https://doc.rust-lang.org/stable/std/fs/struct.File.html#method.try_lock) - [
File::try_lock_shared] (https://doc.rust-lang.org/stable/std/fs/struct.File.html#method.try_lock_shared) - [
File::unlock] (https://doc.rust-lang.org/stable/std/fs/struct.File.html#method.unlock) - [
NonNull::from_ref] (https://doc.rust-lang.org/stable/std/ptr/struct.NonNull.html#method.from_ref) - [
NonNull::from_mut] (https://doc.rust-lang.org/stable/std/ptr/struct.NonNull.html#method.from_mut) - [
NonNull::without_provenance] (https://doc.rust-lang.org/stable/std/ptr/struct.NonNull.html#method.without_provenance) - [
NonNull::with_exposed_provenance] (https://doc.rust-lang.org/stable/std/ptr/struct.NonNull.html#method.with_exposed_provenance) - [
NonNull::expose_provenance] (https://doc.rust-lang.org/stable/std/ptr/struct.NonNull.html#method.expose_provenance) - [
OsString::leak] (https://doc.rust-lang.org/stable/std/ffi/struct.OsString.html#method.leak) - [
PathBuf::leak] (https://doc.rust-lang.org/stable/std/path/struct.PathBuf.html#method.leak) - [
Result::flatten] (https://doc.rust-lang.org/stable/std/result/enum.Result.html#method.flatten) - [
std::os::linux:🥅:TcpStreamExt::quickack] (https://doc.rust-lang.org/stable/std/os/linux/net/trait.TcpStreamExt.html#tymethod.quickack) - [
std::os::linux:🥅:TcpStreamExt::set_quickack] (https://doc.rust-lang.org/stable/std/os/linux/net/trait.TcpStreamExt.html#tymethod.set_quickack)
These previously stable APIs are now stable in const contexts:
- [
<[T; N]>::as_mut_slice] (https://doc.rust-lang.org/stable/std/primitive.array.html#method.as_mut_slice) - [
<[u8]>::eq_ignore_ascii_case] (https://doc.rust-lang.org/stable/std/primitive.slice.html#impl-%5Bu8%5D/method.eq_ignore_ascii_case) - [
str::eq_ignore_ascii_case] (https://doc.rust-lang.org/stable/std/primitive.str.html#impl-str/method.eq_ignore_ascii_case)
Cargo
[
cargo fixandcargo clippy --fixnow default to the same Cargo target selection as other build commands.] (rust-lang/cargo#15192) Previously it would apply to all targets (like binaries, examples, tests, etc.). The--editionflag still applies to all targets.[Stabilize doctest-xcompile.] (rust-lang/cargo#15462) Doctests are now tested when cross-compiling. Just like other tests, it will use the [
runnersetting] (https://doc.rust-lang.org/cargo/reference/config.html#targettriplerunner) to run the tests. If you need to disable tests for a target, you can use the [ignore doctest attribute] (https://doc.rust-lang.org/rustdoc/write-documentation/documentation-tests.html#ignoring-targets) to specify the targets to ignore.
Rustdoc
- [On mobile, make the sidebar full width and linewrap] (rust-lang/rust#139831). This makes long section and item names much easier to deal with on mobile.
Compatibility Notes
[Make
missing_fragment_specifieran unconditional error] (rust-lang/rust#128425)[Enabling the
neontarget feature onaarch64-unknown-none-softfloatcauses a warning] (rust-lang/rust#135160) because mixing code with and without that target feature is not properly supported by LLVM-
- Introduces a small breaking change affecting
?Sizedbounds on impls on recursive types which contain associated type projections. It is not expected to affect any existing published crates. Can be fixed by refactoring the involved types or opting into thesized_hierarchyunstable feature. See the [FCP report] (rust-lang/rust#137944 (comment)) for a code example.
- Introduces a small breaking change affecting
The warn-by-default
elided_named_lifetimeslint is [superseded by the warn-by-defaultmismatched_lifetime_syntaxeslint.] (rust-lang/rust#138677)[Error on recursive opaque types earlier in the type checker] (rust-lang/rust#139419)
[Type inference side effects from requiring element types of array repeat expressions are
Copyare now only available at the end of type checking] (rust-lang/rust#139635)[The deprecated accidentally-stable
std::intrinsics::{copy,copy_nonoverlapping,write_bytes}are now proper intrinsics] (rust-lang/rust#139916). There are no debug assertions guarding against UB, and they cannot be coerced to function pointers.[Remove long-deprecated
std::intrinsics::drop_in_place] (rust-lang/rust#140151)[Make well-formedness predicates no longer coinductive] (rust-lang/rust#140208)
[Remove hack when checking impl method compatibility] (rust-lang/rust#140557)
[Remove unnecessary type inference due to built-in trait object impls] (rust-lang/rust#141352)
[Lint against "stdcall", "fastcall", and "cdecl" on non-x86-32 targets] (rust-lang/rust#141435)
[Future incompatibility warnings relating to the never type (
!) are now reported in dependencies] (rust-lang/rust#141937)[Ensure
std::ptr::copy_*intrinsics also perform the static self-init checks] (rust-lang/rust#142575)
Internal Changes
These changes do not affect any public interfaces of Rust, but they represent significant improvements to the performance or internals of rustc and related tools.
- [Correctly un-remap compiler sources paths with the
rustc-devcomponent] (rust-lang/rust#142377)