While working on complex lowering, I noticed that the
testcase pr42196-3.c had some interesting code in it
and most likely a copy and pasto. Since this testcase
was added back in 2009, I rather add a new testcase
rather than changing the old one.
The testcase was doing:
```
if (b)
{
f1 = __real__ u.cf;
f1 = __imag__ u.cf;
}
else
{
f1 = __real__ u.ci;
f1 = __imag__ u.ci;
}
r = bar (f1, f2);
```
I suspect the second f1 in both sides of the conditional
were supposed to be f2. So the new testcase does that.
Tested on x86_64-linux-gnu and pushed as obvious.
PR tree-optimization/42196
gcc/testsuite/ChangeLog:
* gcc.c-torture/compile/pr42196-4.c: New test.
Signed-off-by: Andrew Pinski <[email protected]>
---
.../gcc.c-torture/compile/pr42196-4.c | 27 +++++++++++++++++++
1 file changed, 27 insertions(+)
create mode 100644 gcc/testsuite/gcc.c-torture/compile/pr42196-4.c
diff --git a/gcc/testsuite/gcc.c-torture/compile/pr42196-4.c
b/gcc/testsuite/gcc.c-torture/compile/pr42196-4.c
new file mode 100644
index 00000000000..d7e526cef08
--- /dev/null
+++ b/gcc/testsuite/gcc.c-torture/compile/pr42196-4.c
@@ -0,0 +1,27 @@
+union U
+{
+ __complex__ int ci;
+ __complex__ float cf;
+};
+
+float gd;
+extern float bar (float, float);
+
+float foo (int b, union U u)
+{
+ float f1, f2, r;
+
+ if (b)
+ {
+ f1 = __real__ u.cf;
+ f2 = __imag__ u.cf;
+ }
+ else
+ {
+ f1 = __real__ u.ci;
+ f2 = __imag__ u.ci;
+ }
+
+ r = bar (f1, f2);
+ return r;
+}
--
2.43.0