]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
RISC-V] add TC for save-restore cfi directives.
authorFei Gao <gaofei@eswincomputing.com>
Tue, 6 Jun 2023 02:14:33 +0000 (20:14 -0600)
committerJeff Law <jlaw@ventanamicro.com>
Tue, 6 Jun 2023 02:15:59 +0000 (20:15 -0600)
gcc/testsuite/ChangeLog:

* gcc.target/riscv/save-restore-cfi.c: New test to check save-restore
cfi directives.

gcc/testsuite/gcc.target/riscv/save-restore-cfi.c [new file with mode: 0644]

diff --git a/gcc/testsuite/gcc.target/riscv/save-restore-cfi.c b/gcc/testsuite/gcc.target/riscv/save-restore-cfi.c
new file mode 100644 (file)
index 0000000..a39f306
--- /dev/null
@@ -0,0 +1,17 @@
+/* { dg-do compile } */
+/* { dg-options "-g -Os -march=rv32imafc -mabi=ilp32f -msave-restore -mcmodel=medlow" } */
+/* { dg-skip-if "" { *-*-* } {"-O2" "-O1" "-O0" "-Og" "-O3" "-Oz" "-flto"} } */
+/* { dg-final { scan-assembler-times {\.cfi_def_cfa_offset 16} 2} } */
+/* { dg-final { scan-assembler-times {\.cfi_def_cfa_offset 32} 1} } */
+/* { dg-final { scan-assembler-times {\.cfi_def_cfa_offset 0} 1} } */
+
+char my_getchar();
+float getf();
+
+int foo()
+{
+  int s0 = my_getchar();
+  float f0 = getf();
+  int b = my_getchar();
+  return f0 + s0 + b;
+}