aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorbadumbatish <tanghocle456@gmail.com>2024-08-31 23:37:19 -0700
committerArthur Cohen <arthur.cohen@embecosm.com>2025-03-19 15:32:08 +0100
commitca839781c9e121d80b19844b36967c2e14eaacb3 (patch)
treec064a5951e13178afd8c059d5a8644e1d7d407d2 /gcc
parentf4f546c9881c47923c7d37e8cf7a9bc35f37489c (diff)
downloadgcc-ca839781c9e121d80b19844b36967c2e14eaacb3.zip
gcc-ca839781c9e121d80b19844b36967c2e14eaacb3.tar.gz
gcc-ca839781c9e121d80b19844b36967c2e14eaacb3.tar.bz2
gccrs: Provide new asm test case for amd64
gcc/testsuite/ChangeLog: * rust/execute/torture/inline_asm_mov_x_5.rs: Move to... * rust/execute/torture/inline_asm_mov_x_5_ARM.rs: ...here. * rust/execute/torture/inline_asm_mov_x_5_x86_64.rs: New test.
Diffstat (limited to 'gcc')
-rw-r--r--gcc/testsuite/rust/execute/torture/inline_asm_mov_x_5_ARM.rs (renamed from gcc/testsuite/rust/execute/torture/inline_asm_mov_x_5.rs)1
-rw-r--r--gcc/testsuite/rust/execute/torture/inline_asm_mov_x_5_x86_64.rs24
2 files changed, 25 insertions, 0 deletions
diff --git a/gcc/testsuite/rust/execute/torture/inline_asm_mov_x_5.rs b/gcc/testsuite/rust/execute/torture/inline_asm_mov_x_5_ARM.rs
index 4f1555e..4e76260 100644
--- a/gcc/testsuite/rust/execute/torture/inline_asm_mov_x_5.rs
+++ b/gcc/testsuite/rust/execute/torture/inline_asm_mov_x_5_ARM.rs
@@ -1,3 +1,4 @@
+/* { dg-do run { target arm*-*-* } } */
/* { dg-output "5\r*\n" }*/
#![feature(rustc_attrs)]
diff --git a/gcc/testsuite/rust/execute/torture/inline_asm_mov_x_5_x86_64.rs b/gcc/testsuite/rust/execute/torture/inline_asm_mov_x_5_x86_64.rs
new file mode 100644
index 0000000..c6086e0
--- /dev/null
+++ b/gcc/testsuite/rust/execute/torture/inline_asm_mov_x_5_x86_64.rs
@@ -0,0 +1,24 @@
+/* { dg-do run { target x86_64*-*-* } } */
+/* { dg-output "5\r*\n" }*/
+
+#![feature(rustc_attrs)]
+#[rustc_builtin_macro]
+macro_rules! asm {
+ () => {};
+}
+
+extern "C" {
+ fn printf(s: *const i8, ...);
+}
+
+fn main() -> i32 {
+ let mut _x: i32 = 0;
+ unsafe {
+ asm!(
+ "mov $5, {}",
+ out(reg) _x
+ );
+ printf("%d\n\0" as *const str as *const i8, _x);
+ }
+ 0
+}