]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
gccrs: Provide new asm test case for amd64
authorbadumbatish <tanghocle456@gmail.com>
Sun, 1 Sep 2024 06:37:19 +0000 (23:37 -0700)
committerArthur Cohen <arthur.cohen@embecosm.com>
Wed, 19 Mar 2025 14:32:08 +0000 (15:32 +0100)
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.

gcc/testsuite/rust/execute/torture/inline_asm_mov_x_5_ARM.rs [moved from gcc/testsuite/rust/execute/torture/inline_asm_mov_x_5.rs with 90% similarity]
gcc/testsuite/rust/execute/torture/inline_asm_mov_x_5_x86_64.rs [new file with mode: 0644]

similarity index 90%
rename from gcc/testsuite/rust/execute/torture/inline_asm_mov_x_5.rs
rename to gcc/testsuite/rust/execute/torture/inline_asm_mov_x_5_ARM.rs
index 4f1555e6f2d3244cead1118af09c71514a871d0e..4e762608230f5ccc3c7e12875af7696ab9a921cb 100644 (file)
@@ -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 (file)
index 0000000..c6086e0
--- /dev/null
@@ -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
+}