view tests/mini/atomic1.d @ 1134:152bd2c804d0

Update comments now that LLVM PR3861 has been fixed. However, since conditionally removing the workaround makes the ABI dependent on LLVM version, I reconsidered that. (The same revision of LDC compiling for the same target should probably produce code that follows the same ABI, right?)
author Frits van Bommel <fvbommel wxs.nl>
date Tue, 24 Mar 2009 02:46:57 +0100
parents cecfee2d01a8
children
line wrap: on
line source

module mini.atomic1;

pragma(intrinsic, "llvm.atomic.swap.i#.p0i#")
    T atomic_swap(T)(T* ptr, T val);

void main()
{
    int i = 42;
    int j = atomic_swap(&i, 43);
    assert(j == 42);
    assert(i == 43);
}