about summary refs log tree commit diff
path: root/src/test/ui/llvm-asm/llvm-asm-indirect-memory.rs
blob: 556ad83a4ead8202d76062e286161a15efa49657 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
// run-pass

#![feature(llvm_asm)]

#[cfg(any(target_arch = "x86", target_arch = "x86_64"))]
fn read(ptr: &u32) -> u32 {
    let out: u32;
    unsafe {
        llvm_asm!("mov $1, $0" : "=r" (out) : "*m" (ptr));
    }
    out
}

#[cfg(any(target_arch = "x86", target_arch = "x86_64"))]
fn write(ptr: &mut u32, val: u32) {
    unsafe {
        llvm_asm!("mov $1, $0" : "=*m" (ptr) : "r" (val));
    }
}

#[cfg(any(target_arch = "x86", target_arch = "x86_64"))]
fn replace(ptr: &mut u32, val: u32) -> u32 {
    let out: u32;
    unsafe {
        llvm_asm!("mov $0, $1; mov $2, $0" : "+*m" (ptr), "=&r" (out) : "r" (val));
    }
    out
}

#[cfg(any(target_arch = "x86", target_arch = "x86_64"))]
pub fn main() {
    let a = 1;
    assert_eq!(read(&a), 1);
    let mut b = 2;
    write(&mut b, 3);
    assert_eq!(b, 3);
    let mut c = 4;
    assert_eq!(replace(&mut c, 5), 4);
    assert_eq!(c, 5);
}

#[cfg(not(any(target_arch = "x86", target_arch = "x86_64")))]
pub fn main() {}