diff options
author | Andrew Pinski <pinskia@gmail.com> | 2023-10-14 13:18:00 -0700 |
---|---|---|
committer | Andrew Pinski <pinskia@gmail.com> | 2023-10-18 15:11:38 -0700 |
commit | 11e6bcedb41359c69ee790f38b04033d236336a8 (patch) | |
tree | ac2032a72b9d8f36bc500b2f4642cb1562874833 /gcc/c | |
parent | 3ec8ecb8e92faec889bc6f7aeac9ff59e82b4f7f (diff) | |
download | gcc-11e6bcedb41359c69ee790f38b04033d236336a8.zip gcc-11e6bcedb41359c69ee790f38b04033d236336a8.tar.gz gcc-11e6bcedb41359c69ee790f38b04033d236336a8.tar.bz2 |
Fix ICE due to c_safe_arg_type_equiv_p not checking for error_mark node
This is a simple error recovery issue when c_safe_arg_type_equiv_p
was added in r8-5312-gc65e18d3331aa999. The issue is that after
an error, an argument type (of a function type) might turn
into an error mark node and c_safe_arg_type_equiv_p was not ready
for that. So this just adds a check for error operand for its
arguments before getting the main variant.
OK? Bootstrapped and tested on x86_64-linux-gnu with no regressions.
PR c/101285
gcc/c/ChangeLog:
* c-typeck.cc (c_safe_arg_type_equiv_p): Return true for error
operands early.
gcc/testsuite/ChangeLog:
* gcc.dg/pr101285-1.c: New test.
Diffstat (limited to 'gcc/c')
-rw-r--r-- | gcc/c/c-typeck.cc | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/gcc/c/c-typeck.cc b/gcc/c/c-typeck.cc index e55e887..6e044b4 100644 --- a/gcc/c/c-typeck.cc +++ b/gcc/c/c-typeck.cc @@ -5960,6 +5960,9 @@ handle_warn_cast_qual (location_t loc, tree type, tree otype) static bool c_safe_arg_type_equiv_p (tree t1, tree t2) { + if (error_operand_p (t1) || error_operand_p (t2)) + return true; + t1 = TYPE_MAIN_VARIANT (t1); t2 = TYPE_MAIN_VARIANT (t2); |