Skip to content

Commit 3e7edfe

Browse files
committed
---
yaml --- r: 67263 b: refs/heads/master c: 5102853 h: refs/heads/master i: 67261: 01103c5 67259: 61f5be6 67255: 43a0816 67247: f889dd3 67231: ef59723 67199: 30c83ab v: v3
1 parent 9e5bd75 commit 3e7edfe

File tree

2 files changed

+13
-1
lines changed

2 files changed

+13
-1
lines changed

[refs]

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,5 +1,5 @@
11
---
2-
refs/heads/master: 3ee423858a23f3a3eccddf9b8b36bfe64660397b
2+
refs/heads/master: 51028532d790db476b102ebdda40bb9b1a7f8106
33
refs/heads/snap-stage1: e33de59e47c5076a89eadeb38f4934f58a3618a6
44
refs/heads/snap-stage3: 18e3db7392d2d0697b7e27d6d986139960144d85
55
refs/heads/try: 7b78b52e602bb3ea8174f9b2006bff3315f03ef9

trunk/src/libstd/unstable/atomics.rs

Lines changed: 12 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -68,8 +68,10 @@ pub struct AtomicOption<T> {
6868
}
6969

7070
pub enum Ordering {
71+
Relaxed,
7172
Release,
7273
Acquire,
74+
AcqRel,
7375
SeqCst
7476
}
7577

@@ -318,6 +320,7 @@ pub unsafe fn atomic_store<T>(dst: &mut T, val: T, order:Ordering) {
318320

319321
match order {
320322
Release => intrinsics::atomic_store_rel(dst, val),
323+
Relaxed => intrinsics::atomic_store_relaxed(dst, val),
321324
_ => intrinsics::atomic_store(dst, val)
322325
}
323326
}
@@ -328,6 +331,7 @@ pub unsafe fn atomic_load<T>(dst: &T, order:Ordering) -> T {
328331

329332
cast::transmute(match order {
330333
Acquire => intrinsics::atomic_load_acq(dst),
334+
Relaxed => intrinsics::atomic_load_relaxed(dst),
331335
_ => intrinsics::atomic_load(dst)
332336
})
333337
}
@@ -340,6 +344,8 @@ pub unsafe fn atomic_swap<T>(dst: &mut T, val: T, order: Ordering) -> T {
340344
cast::transmute(match order {
341345
Acquire => intrinsics::atomic_xchg_acq(dst, val),
342346
Release => intrinsics::atomic_xchg_rel(dst, val),
347+
AcqRel => intrinsics::atomic_xchg_acqrel(dst, val),
348+
Relaxed => intrinsics::atomic_xchg_relaxed(dst, val),
343349
_ => intrinsics::atomic_xchg(dst, val)
344350
})
345351
}
@@ -353,6 +359,8 @@ pub unsafe fn atomic_add<T>(dst: &mut T, val: T, order: Ordering) -> T {
353359
cast::transmute(match order {
354360
Acquire => intrinsics::atomic_xadd_acq(dst, val),
355361
Release => intrinsics::atomic_xadd_rel(dst, val),
362+
AcqRel => intrinsics::atomic_xadd_acqrel(dst, val),
363+
Relaxed => intrinsics::atomic_xadd_relaxed(dst, val),
356364
_ => intrinsics::atomic_xadd(dst, val)
357365
})
358366
}
@@ -366,6 +374,8 @@ pub unsafe fn atomic_sub<T>(dst: &mut T, val: T, order: Ordering) -> T {
366374
cast::transmute(match order {
367375
Acquire => intrinsics::atomic_xsub_acq(dst, val),
368376
Release => intrinsics::atomic_xsub_rel(dst, val),
377+
AcqRel => intrinsics::atomic_xsub_acqrel(dst, val),
378+
Relaxed => intrinsics::atomic_xsub_relaxed(dst, val),
369379
_ => intrinsics::atomic_xsub(dst, val)
370380
})
371381
}
@@ -379,6 +389,8 @@ pub unsafe fn atomic_compare_and_swap<T>(dst:&mut T, old:T, new:T, order: Orderi
379389
cast::transmute(match order {
380390
Acquire => intrinsics::atomic_cxchg_acq(dst, old, new),
381391
Release => intrinsics::atomic_cxchg_rel(dst, old, new),
392+
AcqRel => intrinsics::atomic_cxchg_acqrel(dst, old, new),
393+
Relaxed => intrinsics::atomic_cxchg_relaxed(dst, old, new),
382394
_ => intrinsics::atomic_cxchg(dst, old, new),
383395
})
384396
}

0 commit comments

Comments
 (0)