Skip to content

Commit 59c5191

Browse files
committed
Add test for inline asm indirect memory operands
1 parent 1805e5f commit 59c5191

File tree

1 file changed

+39
-0
lines changed

1 file changed

+39
-0
lines changed
+39
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,39 @@
1+
// Copyright 2015 The Rust Project Developers. See the COPYRIGHT
2+
// file at the top-level directory of this distribution and at
3+
// http://rust-lang.org/COPYRIGHT.
4+
//
5+
// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or
6+
// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license
7+
// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your
8+
// option. This file may not be copied, modified, or distributed
9+
// except according to those terms.
10+
11+
#![feature(asm)]
12+
13+
#[cfg(any(target_arch = "x86", target_arch = "x86_64"))]
14+
fn read(ptr: &u32) -> u32 {
15+
let out: u32;
16+
unsafe {
17+
asm!("mov $1, $0" : "=r" (out) : "*m" (ptr));
18+
}
19+
out
20+
}
21+
22+
#[cfg(any(target_arch = "x86", target_arch = "x86_64"))]
23+
fn write(ptr: &mut u32, val: u32) {
24+
unsafe {
25+
asm!("mov $1, $0" :: "=*m" (ptr), "r" (val));
26+
}
27+
}
28+
29+
#[cfg(any(target_arch = "x86", target_arch = "x86_64"))]
30+
pub fn main() {
31+
let a = 1;
32+
let mut b = 2;
33+
assert_eq!(read(&a), 1);
34+
write(&mut b, 3);
35+
assert_eq!(b, 3);
36+
}
37+
38+
#[cfg(not(any(target_arch = "x86", target_arch = "x86_64")))]
39+
pub fn main() {}

0 commit comments

Comments
 (0)