c/110454 - ICE with bogus TYPE_PRECISION use
Checks
Commit Message
The following sinks TYPE_PRECISION to properly guarded use places.
Bootstrapped and tested on x86_64-unknown-linux-gnu, pushed as
obvious.
PR c/110454
gcc/c/
* c-typeck.cc (convert_argument): Sink formal_prec compute
to where TYPE_PRECISION is valid to use.
* gcc.dg/Wtraditional-conversion-3.c: New testcase.
---
gcc/c/c-typeck.cc | 5 +++--
gcc/testsuite/gcc.dg/Wtraditional-conversion-3.c | 9 +++++++++
2 files changed, 12 insertions(+), 2 deletions(-)
create mode 100644 gcc/testsuite/gcc.dg/Wtraditional-conversion-3.c
@@ -3385,8 +3385,6 @@ convert_argument (location_t ploc, tree function, tree fundecl,
conversions. */
if (warn_traditional_conversion || warn_traditional)
{
- unsigned int formal_prec = TYPE_PRECISION (type);
-
if (INTEGRAL_TYPE_P (type)
&& SCALAR_FLOAT_TYPE_P (valtype))
warning_at (ploc, OPT_Wtraditional_conversion,
@@ -3429,6 +3427,8 @@ convert_argument (location_t ploc, tree function, tree fundecl,
else if (SCALAR_FLOAT_TYPE_P (type)
&& SCALAR_FLOAT_TYPE_P (valtype))
{
+ unsigned int formal_prec = TYPE_PRECISION (type);
+
/* Warn if any argument is passed as `float',
since without a prototype it would be `double'. */
if (formal_prec == TYPE_PRECISION (float_type_node)
@@ -3472,6 +3472,7 @@ convert_argument (location_t ploc, tree function, tree fundecl,
&& INTEGRAL_TYPE_P (type)
&& INTEGRAL_TYPE_P (valtype))
{
+ unsigned int formal_prec = TYPE_PRECISION (type);
tree would_have_been = default_conversion (val);
tree type1 = TREE_TYPE (would_have_been);
new file mode 100644
@@ -0,0 +1,9 @@
+/* { dg-options "-Wtraditional-conversion -Wno-psabi" } */
+
+typedef int __attribute__((__vector_size__ (4))) V;
+
+void
+foo (V v)
+{
+ foo (v);
+}