aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRichard Sandiford <rsandifo@redhat.com>2004-09-20 06:54:52 +0000
committerRichard Sandiford <rsandifo@gcc.gnu.org>2004-09-20 06:54:52 +0000
commit073cbad3bb0ebe7a29e11acc51d08543f5b1dbd7 (patch)
tree3b4fc4f9a8b7cd419627994ceb2a9a76d6813d29 /gcc
parent95c53c62a0ead38459084c66a708af8c8097f00d (diff)
downloadgcc-073cbad3bb0ebe7a29e11acc51d08543f5b1dbd7.zip
gcc-073cbad3bb0ebe7a29e11acc51d08543f5b1dbd7.tar.gz
gcc-073cbad3bb0ebe7a29e11acc51d08543f5b1dbd7.tar.bz2
re PR target/17565 ([3.3 only] asms in delay slots)
PR target/17565 * config/mips/mips.md (define_asm_attributes): Set can_delay to no. From-SVN: r87744
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog5
-rw-r--r--gcc/config/mips/mips.md3
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gcc.target/mips/asm-1.c14
4 files changed, 25 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 6f6582d..45f7fe7 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,8 @@
+2004-09-20 Richard Sandiford <rsandifo@redhat.com>
+
+ PR target/17565
+ * config/mips/mips.md (define_asm_attributes): Set can_delay to no.
+
2004-09-20 Jan Hubicka <jh@suse.cz>
* predict.c (estimate_probability): Remove unnecesary code.
diff --git a/gcc/config/mips/mips.md b/gcc/config/mips/mips.md
index fb50b3b..b8239ed 100644
--- a/gcc/config/mips/mips.md
+++ b/gcc/config/mips/mips.md
@@ -310,7 +310,8 @@
;; Describe a user's asm statement.
(define_asm_attributes
- [(set_attr "type" "multi")])
+ [(set_attr "type" "multi")
+ (set_attr "can_delay" "no")])
;; This mode macro allows 32-bit and 64-bit GPR patterns to be generated
;; from the same template.
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 199ae8e..8548b47 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2004-09-20 Richard Sandiford <rsandifo@redhat.com>
+
+ * gcc.target/mips/asm-1.c: New test.
+
2004-09-19 Ira Rosen <irar@il.ibm.com>
* gcc.dg/vect/vect-13.c: Now vectorized on ppc*.
diff --git a/gcc/testsuite/gcc.target/mips/asm-1.c b/gcc/testsuite/gcc.target/mips/asm-1.c
new file mode 100644
index 0000000..1a64e87
--- /dev/null
+++ b/gcc/testsuite/gcc.target/mips/asm-1.c
@@ -0,0 +1,14 @@
+/* PR target/17565. GCC used to put the asm into the delay slot
+ of the call. */
+/* { dg-do assemble } */
+/* { dg-options "-O" } */
+int foo (int n)
+{
+ register int k asm ("$16") = n;
+ if (k > 0)
+ {
+ bar ();
+ asm ("li %0,0x12345678" : "=r" (k));
+ }
+ return k;
+}