aboutsummaryrefslogtreecommitdiff
path: root/libgcc
diff options
context:
space:
mode:
authorRichard Sandiford <richard.sandiford@arm.com>2020-01-18 10:59:10 +0000
committerRichard Sandiford <richard.sandiford@arm.com>2020-01-27 10:53:34 +0000
commit150760dd6dd1899705790183d646fa5fc004554e (patch)
tree3b067c8902f0587db70d5992d8f42e36f4e93e49 /libgcc
parent7974a14692cec3ecafed24bc275df803373f3230 (diff)
downloadgcc-150760dd6dd1899705790183d646fa5fc004554e.zip
gcc-150760dd6dd1899705790183d646fa5fc004554e.tar.gz
gcc-150760dd6dd1899705790183d646fa5fc004554e.tar.bz2
cselib: Fix handling of multireg values for call insns [PR93170]
g:3bd2918594dae34ae84f mishandled the case in which only the tail end of a multireg hard register is invalidated by the call. Walking all the entries should be both safer and more precise. Avoiding cselib_invalidate_regno also means that we no longer walk the same list multiple times (which is something we did before g:3bd2918594dae34ae84f too). 2020-01-27 Richard Sandiford <richard.sandiford@arm.com> gcc/ PR rtl-optimization/93170 * cselib.c (cselib_invalidate_regno_val): New function, split out from... (cselib_invalidate_regno): ...here. (cselib_invalidated_by_call_p): New function. (cselib_process_insn): Iterate over all the hard-register entries in REG_VALUES and invalidate any that cross call-clobbered registers. gcc/testsuite/ * gcc.dg/torture/pr93170.c: New test.
Diffstat (limited to 'libgcc')
0 files changed, 0 insertions, 0 deletions