@@ -581,8 +581,7 @@ impl AtomicBool {
581
581
/// `failure` describes the required ordering for the load operation that takes place when
582
582
/// the comparison fails. Using [`Acquire`] as success ordering makes the store part
583
583
/// of this operation [`Relaxed`], and using [`Release`] makes the successful load
584
- /// [`Relaxed`]. The failure ordering can only be [`SeqCst`], [`Acquire`] or [`Relaxed`]
585
- /// and must be equivalent to or weaker than the success ordering.
584
+ /// [`Relaxed`]. The failure ordering can only be [`SeqCst`], [`Acquire`] or [`Relaxed`].
586
585
///
587
586
/// **Note:** This method is only available on platforms that support atomic
588
587
/// operations on `u8`.
@@ -640,8 +639,7 @@ impl AtomicBool {
640
639
/// `failure` describes the required ordering for the load operation that takes place when
641
640
/// the comparison fails. Using [`Acquire`] as success ordering makes the store part
642
641
/// of this operation [`Relaxed`], and using [`Release`] makes the successful load
643
- /// [`Relaxed`]. The failure ordering can only be [`SeqCst`], [`Acquire`] or [`Relaxed`]
644
- /// and must be equivalent to or weaker than the success ordering.
642
+ /// [`Relaxed`]. The failure ordering can only be [`SeqCst`], [`Acquire`] or [`Relaxed`].
645
643
///
646
644
/// **Note:** This method is only available on platforms that support atomic
647
645
/// operations on `u8`.
@@ -941,8 +939,7 @@ impl AtomicBool {
941
939
/// Using [`Acquire`] as success ordering makes the store part of this
942
940
/// operation [`Relaxed`], and using [`Release`] makes the final successful
943
941
/// load [`Relaxed`]. The (failed) load ordering can only be [`SeqCst`],
944
- /// [`Acquire`] or [`Relaxed`] and must be equivalent to or weaker than the
945
- /// success ordering.
942
+ /// [`Acquire`] or [`Relaxed`].
946
943
///
947
944
/// **Note:** This method is only available on platforms that support atomic
948
945
/// operations on `u8`.
@@ -1301,8 +1298,7 @@ impl<T> AtomicPtr<T> {
1301
1298
/// `failure` describes the required ordering for the load operation that takes place when
1302
1299
/// the comparison fails. Using [`Acquire`] as success ordering makes the store part
1303
1300
/// of this operation [`Relaxed`], and using [`Release`] makes the successful load
1304
- /// [`Relaxed`]. The failure ordering can only be [`SeqCst`], [`Acquire`] or [`Relaxed`]
1305
- /// and must be equivalent to or weaker than the success ordering.
1301
+ /// [`Relaxed`]. The failure ordering can only be [`SeqCst`], [`Acquire`] or [`Relaxed`].
1306
1302
///
1307
1303
/// **Note:** This method is only available on platforms that support atomic
1308
1304
/// operations on pointers.
@@ -1347,8 +1343,7 @@ impl<T> AtomicPtr<T> {
1347
1343
/// `failure` describes the required ordering for the load operation that takes place when
1348
1344
/// the comparison fails. Using [`Acquire`] as success ordering makes the store part
1349
1345
/// of this operation [`Relaxed`], and using [`Release`] makes the successful load
1350
- /// [`Relaxed`]. The failure ordering can only be [`SeqCst`], [`Acquire`] or [`Relaxed`]
1351
- /// and must be equivalent to or weaker than the success ordering.
1346
+ /// [`Relaxed`]. The failure ordering can only be [`SeqCst`], [`Acquire`] or [`Relaxed`].
1352
1347
///
1353
1348
/// **Note:** This method is only available on platforms that support atomic
1354
1349
/// operations on pointers.
@@ -1404,8 +1399,7 @@ impl<T> AtomicPtr<T> {
1404
1399
/// Using [`Acquire`] as success ordering makes the store part of this
1405
1400
/// operation [`Relaxed`], and using [`Release`] makes the final successful
1406
1401
/// load [`Relaxed`]. The (failed) load ordering can only be [`SeqCst`],
1407
- /// [`Acquire`] or [`Relaxed`] and must be equivalent to or weaker than the
1408
- /// success ordering.
1402
+ /// [`Acquire`] or [`Relaxed`].
1409
1403
///
1410
1404
/// **Note:** This method is only available on platforms that support atomic
1411
1405
/// operations on pointers.
@@ -2227,8 +2221,7 @@ macro_rules! atomic_int {
2227
2221
/// `failure` describes the required ordering for the load operation that takes place when
2228
2222
/// the comparison fails. Using [`Acquire`] as success ordering makes the store part
2229
2223
/// of this operation [`Relaxed`], and using [`Release`] makes the successful load
2230
- /// [`Relaxed`]. The failure ordering can only be [`SeqCst`], [`Acquire`] or [`Relaxed`]
2231
- /// and must be equivalent to or weaker than the success ordering.
2224
+ /// [`Relaxed`]. The failure ordering can only be [`SeqCst`], [`Acquire`] or [`Relaxed`].
2232
2225
///
2233
2226
/// **Note**: This method is only available on platforms that support atomic operations on
2234
2227
#[ doc = concat!( "[`" , $s_int_type, "`]." ) ]
@@ -2279,8 +2272,7 @@ macro_rules! atomic_int {
2279
2272
/// `failure` describes the required ordering for the load operation that takes place when
2280
2273
/// the comparison fails. Using [`Acquire`] as success ordering makes the store part
2281
2274
/// of this operation [`Relaxed`], and using [`Release`] makes the successful load
2282
- /// [`Relaxed`]. The failure ordering can only be [`SeqCst`], [`Acquire`] or [`Relaxed`]
2283
- /// and must be equivalent to or weaker than the success ordering.
2275
+ /// [`Relaxed`]. The failure ordering can only be [`SeqCst`], [`Acquire`] or [`Relaxed`].
2284
2276
///
2285
2277
/// **Note**: This method is only available on platforms that support atomic operations on
2286
2278
#[ doc = concat!( "[`" , $s_int_type, "`]." ) ]
@@ -2517,8 +2509,7 @@ macro_rules! atomic_int {
2517
2509
///
2518
2510
/// Using [`Acquire`] as success ordering makes the store part
2519
2511
/// of this operation [`Relaxed`], and using [`Release`] makes the final successful load
2520
- /// [`Relaxed`]. The (failed) load ordering can only be [`SeqCst`], [`Acquire`] or [`Relaxed`]
2521
- /// and must be equivalent to or weaker than the success ordering.
2512
+ /// [`Relaxed`]. The (failed) load ordering can only be [`SeqCst`], [`Acquire`] or [`Relaxed`].
2522
2513
///
2523
2514
/// **Note**: This method is only available on platforms that support atomic operations on
2524
2515
#[ doc = concat!( "[`" , $s_int_type, "`]." ) ]
@@ -3035,22 +3026,29 @@ unsafe fn atomic_compare_exchange<T: Copy>(
3035
3026
let ( val, ok) = unsafe {
3036
3027
match ( success, failure) {
3037
3028
( Relaxed , Relaxed ) => intrinsics:: atomic_cxchg_relaxed_relaxed ( dst, old, new) ,
3038
- //(Relaxed, Acquire) => intrinsics::atomic_cxchg_relaxed_acquire(dst, old, new),
3039
- //(Relaxed, SeqCst) => intrinsics::atomic_cxchg_relaxed_seqcst(dst, old, new),
3029
+ #[ cfg( not( bootstrap) ) ]
3030
+ ( Relaxed , Acquire ) => intrinsics:: atomic_cxchg_relaxed_acquire ( dst, old, new) ,
3031
+ #[ cfg( not( bootstrap) ) ]
3032
+ ( Relaxed , SeqCst ) => intrinsics:: atomic_cxchg_relaxed_seqcst ( dst, old, new) ,
3040
3033
( Acquire , Relaxed ) => intrinsics:: atomic_cxchg_acquire_relaxed ( dst, old, new) ,
3041
3034
( Acquire , Acquire ) => intrinsics:: atomic_cxchg_acquire_acquire ( dst, old, new) ,
3042
- //(Acquire, SeqCst) => intrinsics::atomic_cxchg_acquire_seqcst(dst, old, new),
3035
+ #[ cfg( not( bootstrap) ) ]
3036
+ ( Acquire , SeqCst ) => intrinsics:: atomic_cxchg_acquire_seqcst ( dst, old, new) ,
3043
3037
( Release , Relaxed ) => intrinsics:: atomic_cxchg_release_relaxed ( dst, old, new) ,
3044
- //(Release, Acquire) => intrinsics::atomic_cxchg_release_acquire(dst, old, new),
3045
- //(Release, SeqCst) => intrinsics::atomic_cxchg_release_seqcst(dst, old, new),
3038
+ #[ cfg( not( bootstrap) ) ]
3039
+ ( Release , Acquire ) => intrinsics:: atomic_cxchg_release_acquire ( dst, old, new) ,
3040
+ #[ cfg( not( bootstrap) ) ]
3041
+ ( Release , SeqCst ) => intrinsics:: atomic_cxchg_release_seqcst ( dst, old, new) ,
3046
3042
( AcqRel , Relaxed ) => intrinsics:: atomic_cxchg_acqrel_relaxed ( dst, old, new) ,
3047
3043
( AcqRel , Acquire ) => intrinsics:: atomic_cxchg_acqrel_acquire ( dst, old, new) ,
3048
- //(AcqRel, SeqCst) => intrinsics::atomic_cxchg_acqrel_seqcst(dst, old, new),
3044
+ #[ cfg( not( bootstrap) ) ]
3045
+ ( AcqRel , SeqCst ) => intrinsics:: atomic_cxchg_acqrel_seqcst ( dst, old, new) ,
3049
3046
( SeqCst , Relaxed ) => intrinsics:: atomic_cxchg_seqcst_relaxed ( dst, old, new) ,
3050
3047
( SeqCst , Acquire ) => intrinsics:: atomic_cxchg_seqcst_acquire ( dst, old, new) ,
3051
3048
( SeqCst , SeqCst ) => intrinsics:: atomic_cxchg_seqcst_seqcst ( dst, old, new) ,
3052
3049
( _, AcqRel ) => panic ! ( "there is no such thing as an acquire-release failure ordering" ) ,
3053
3050
( _, Release ) => panic ! ( "there is no such thing as a release failure ordering" ) ,
3051
+ #[ cfg( bootstrap) ]
3054
3052
_ => panic ! ( "a failure ordering can't be stronger than a success ordering" ) ,
3055
3053
}
3056
3054
} ;
@@ -3070,22 +3068,29 @@ unsafe fn atomic_compare_exchange_weak<T: Copy>(
3070
3068
let ( val, ok) = unsafe {
3071
3069
match ( success, failure) {
3072
3070
( Relaxed , Relaxed ) => intrinsics:: atomic_cxchgweak_relaxed_relaxed ( dst, old, new) ,
3073
- //(Relaxed, Acquire) => intrinsics::atomic_cxchgweak_relaxed_acquire(dst, old, new),
3074
- //(Relaxed, SeqCst) => intrinsics::atomic_cxchgweak_relaxed_seqcst(dst, old, new),
3071
+ #[ cfg( not( bootstrap) ) ]
3072
+ ( Relaxed , Acquire ) => intrinsics:: atomic_cxchgweak_relaxed_acquire ( dst, old, new) ,
3073
+ #[ cfg( not( bootstrap) ) ]
3074
+ ( Relaxed , SeqCst ) => intrinsics:: atomic_cxchgweak_relaxed_seqcst ( dst, old, new) ,
3075
3075
( Acquire , Relaxed ) => intrinsics:: atomic_cxchgweak_acquire_relaxed ( dst, old, new) ,
3076
3076
( Acquire , Acquire ) => intrinsics:: atomic_cxchgweak_acquire_acquire ( dst, old, new) ,
3077
- //(Acquire, SeqCst) => intrinsics::atomic_cxchgweak_acquire_seqcst(dst, old, new),
3077
+ #[ cfg( not( bootstrap) ) ]
3078
+ ( Acquire , SeqCst ) => intrinsics:: atomic_cxchgweak_acquire_seqcst ( dst, old, new) ,
3078
3079
( Release , Relaxed ) => intrinsics:: atomic_cxchgweak_release_relaxed ( dst, old, new) ,
3079
- //(Release, Acquire) => intrinsics::atomic_cxchgweak_release_acquire(dst, old, new),
3080
- //(Release, SeqCst) => intrinsics::atomic_cxchgweak_release_seqcst(dst, old, new),
3080
+ #[ cfg( not( bootstrap) ) ]
3081
+ ( Release , Acquire ) => intrinsics:: atomic_cxchgweak_release_acquire ( dst, old, new) ,
3082
+ #[ cfg( not( bootstrap) ) ]
3083
+ ( Release , SeqCst ) => intrinsics:: atomic_cxchgweak_release_seqcst ( dst, old, new) ,
3081
3084
( AcqRel , Relaxed ) => intrinsics:: atomic_cxchgweak_acqrel_relaxed ( dst, old, new) ,
3082
3085
( AcqRel , Acquire ) => intrinsics:: atomic_cxchgweak_acqrel_acquire ( dst, old, new) ,
3083
- //(AcqRel, SeqCst) => intrinsics::atomic_cxchgweak_acqrel_seqcst(dst, old, new),
3086
+ #[ cfg( not( bootstrap) ) ]
3087
+ ( AcqRel , SeqCst ) => intrinsics:: atomic_cxchgweak_acqrel_seqcst ( dst, old, new) ,
3084
3088
( SeqCst , Relaxed ) => intrinsics:: atomic_cxchgweak_seqcst_relaxed ( dst, old, new) ,
3085
3089
( SeqCst , Acquire ) => intrinsics:: atomic_cxchgweak_seqcst_acquire ( dst, old, new) ,
3086
3090
( SeqCst , SeqCst ) => intrinsics:: atomic_cxchgweak_seqcst_seqcst ( dst, old, new) ,
3087
3091
( _, AcqRel ) => panic ! ( "there is no such thing as an acquire-release failure ordering" ) ,
3088
3092
( _, Release ) => panic ! ( "there is no such thing as a release failure ordering" ) ,
3093
+ #[ cfg( bootstrap) ]
3089
3094
_ => panic ! ( "a failure ordering can't be stronger than a success ordering" ) ,
3090
3095
}
3091
3096
} ;
0 commit comments