summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorolegendo <olegendo@138bc75d-0d04-0410-961f-82ee72b054a4>2012-03-15 01:18:04 +0000
committerolegendo <olegendo@138bc75d-0d04-0410-961f-82ee72b054a4>2012-03-15 01:18:04 +0000
commit662ea1facdf51eb124328476fc54e923976f886f (patch)
treeeb9acef30852fecf683f5270dcedde64dbc35cd7
parentec8afb2e27a60f1d5d8611c8267c60e43a03a0ce (diff)
downloadppe42-gcc-662ea1facdf51eb124328476fc54e923976f886f.tar.gz
ppe42-gcc-662ea1facdf51eb124328476fc54e923976f886f.zip
* gcc.target/sh/fpul-usage-1.c: New.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@185406 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--gcc/testsuite/ChangeLog4
-rw-r--r--gcc/testsuite/gcc.target/sh/fpul-usage-1.c24
2 files changed, 28 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 64e8e9c43d0..9d57d21fcd7 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,7 @@
+2012-03-15 Oleg Endo <olegendo@gcc.gnu.org>
+
+ * gcc.target/sh/fpul-usage-1.c: New.
+
2012-03-14 Oleg Endo <olegendo@gcc.gnu.org>
PR target/49468
diff --git a/gcc/testsuite/gcc.target/sh/fpul-usage-1.c b/gcc/testsuite/gcc.target/sh/fpul-usage-1.c
new file mode 100644
index 00000000000..394e7ef81ca
--- /dev/null
+++ b/gcc/testsuite/gcc.target/sh/fpul-usage-1.c
@@ -0,0 +1,24 @@
+/* Check that the FPUL register is used when reading a float as an int and
+ vice versa, as opposed to pushing and popping the values over the stack. */
+/* { dg-do compile { target "sh*-*-*" } } */
+/* { dg-options "-O1" } */
+/* { dg-skip-if "" { "sh*-*-*" } { "-m1" "-m2" "-m4al" "*nofpu" "-m4-340*" "-m4-400*" "-m4-500*" "-m5*" } { "" } } */
+/* { dg-final { scan-assembler "fpul" } } */
+/* { dg-final { scan-assembler-not "r15" } } */
+
+int
+float_as_int (float val)
+{
+ union { float f; int i; } u;
+ u.f = val;
+ return u.i;
+}
+
+float
+int_as_float (int val)
+{
+ union { float f; int i; } u;
+ u.i = val;
+ return u.f;
+}
+
OpenPOWER on IntegriCloud