This repository was archived by the owner on Apr 28, 2025. It is now read-only.
File tree Expand file tree Collapse file tree 7 files changed +34
-11
lines changed
crates/compiler-builtins-smoke-test Expand file tree Collapse file tree 7 files changed +34
-11
lines changed Original file line number Diff line number Diff line change @@ -24,6 +24,11 @@ unstable = ["unstable-intrinsics"]
2424unstable-intrinsics = []
2525
2626# Used to prevent using any intrinsics or arch-specific code.
27+ #
28+ # HACK: this is a negative feature which is generally a bad idea in Cargo, but
29+ # we need it to be able to forbid other features when this crate is used in
30+ # Rust dependencies. Setting this overrides all features that may enable
31+ # hard float operations.
2732force-soft-floats = []
2833
2934[workspace ]
Original file line number Diff line number Diff line change @@ -3,7 +3,6 @@ use std::env;
33fn main ( ) {
44 println ! ( "cargo:rerun-if-changed=build.rs" ) ;
55 println ! ( "cargo:rustc-check-cfg=cfg(assert_no_panic)" ) ;
6- println ! ( "cargo:rustc-check-cfg=cfg(feature, values(\" unstable\" ))" ) ;
76
87 println ! ( "cargo:rustc-check-cfg=cfg(feature, values(\" checked\" ))" ) ;
98
@@ -14,4 +13,18 @@ fn main() {
1413 println ! ( "cargo:rustc-cfg=assert_no_panic" ) ;
1514 }
1615 }
16+
17+ configure_intrinsics ( ) ;
18+ }
19+
20+ /// Simplify the feature logic for enabling intrinsics so code only needs to use
21+ /// `cfg(intrinsics_enabled)`.
22+ fn configure_intrinsics ( ) {
23+ println ! ( "cargo:rustc-check-cfg=cfg(intrinsics_enabled)" ) ;
24+
25+ // Disabled by default; `unstable-intrinsics` enables again; `force-soft-floats` overrides
26+ // to disable.
27+ if cfg ! ( feature = "unstable-intrinsics" ) && !cfg ! ( feature = "force-soft-floats" ) {
28+ println ! ( "cargo:rustc-cfg=intrinsics_enabled" ) ;
29+ }
1730}
Original file line number Diff line number Diff line change @@ -46,6 +46,10 @@ if [ "$(uname -a)" = "Linux" ]; then
4646 extra_flags=" $extra_flags --features libm-test/test-musl-serialized"
4747fi
4848
49+ # Make sure we can build with overriding features. We test the indibidual
50+ # features it controls separately.
51+ cargo check --features " force-soft-floats"
52+
4953if [ " ${BUILD_ONLY:- } " = " 1" ]; then
5054 cmd=" cargo build --target $target --package libm"
5155 $cmd
Original file line number Diff line number Diff line change @@ -15,3 +15,9 @@ unstable = []
1515unstable-intrinsics = []
1616checked = []
1717force-soft-floats = []
18+
19+ [lints .rust ]
20+ unexpected_cfgs = { level = " warn" , check-cfg = [
21+ " cfg(assert_no_panic)" ,
22+ " cfg(intrinsics_enabled)" ,
23+ ] }
Load Diff This file was deleted.
Original file line number Diff line number Diff line change 11//! libm in pure Rust
22#![ no_std]
3- #![ cfg_attr( feature = "unstable-intrinsics" , allow( internal_features) ) ]
4- #![ cfg_attr( feature = "unstable-intrinsics" , feature( core_intrinsics) ) ]
3+ #![ cfg_attr( intrinsics_enabled , allow( internal_features) ) ]
4+ #![ cfg_attr( intrinsics_enabled , feature( core_intrinsics) ) ]
55#![ allow( clippy:: assign_op_pattern) ]
66#![ allow( clippy:: deprecated_cfg_attr) ]
77#![ allow( clippy:: eq_op) ]
Original file line number Diff line number Diff line change @@ -60,14 +60,14 @@ macro_rules! i {
6060// the time of this writing this is only used in a few places, and once
6161// rust-lang/rust#72751 is fixed then this macro will no longer be necessary and
6262// the native `/` operator can be used and panics won't be codegen'd.
63- #[ cfg( any( debug_assertions, not( feature = "unstable-intrinsics" ) ) ) ]
63+ #[ cfg( any( debug_assertions, not( intrinsics_enabled ) ) ) ]
6464macro_rules! div {
6565 ( $a: expr, $b: expr) => {
6666 $a / $b
6767 } ;
6868}
6969
70- #[ cfg( all( not( debug_assertions) , feature = "unstable-intrinsics" ) ) ]
70+ #[ cfg( all( not( debug_assertions) , intrinsics_enabled ) ) ]
7171macro_rules! div {
7272 ( $a: expr, $b: expr) => {
7373 unsafe { core:: intrinsics:: unchecked_div( $a, $b) }
@@ -76,9 +76,7 @@ macro_rules! div {
7676
7777macro_rules! llvm_intrinsically_optimized {
7878 ( #[ cfg( $( $clause: tt) * ) ] $e: expr) => {
79- #[ cfg( all(
80- feature = "unstable-intrinsics" , not( feature = "force-soft-floats" ) , $( $clause) *
81- ) ) ]
79+ #[ cfg( all( intrinsics_enabled, not( feature = "force-soft-floats" ) , $( $clause) * ) ) ]
8280 {
8381 if true { // thwart the dead code lint
8482 $e
You can’t perform that action at this time.
0 commit comments