aboutsummaryrefslogtreecommitdiff
path: root/gcc/tree-vectorizer.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2020-06-24 10:40:02 +0200
committerJakub Jelinek <jakub@redhat.com>2020-06-24 10:41:04 +0200
commit01e10b0ee77e82cb331414c569e02dc7a2c4999e (patch)
tree4fd662b22fa60263df1fe1b0596242a88aa0655d /gcc/tree-vectorizer.c
parentf0008858dec9b16da153b948834abb20b9f1ab32 (diff)
downloadgcc-01e10b0ee77e82cb331414c569e02dc7a2c4999e.zip
gcc-01e10b0ee77e82cb331414c569e02dc7a2c4999e.tar.gz
gcc-01e10b0ee77e82cb331414c569e02dc7a2c4999e.tar.bz2
fold-const: Fix A <= 0 ? A : -A folding [PR95810]
We folded A <= 0 ? A : -A into -ABS (A), which is for signed integral types incorrect - can invoke on INT_MIN UB twice, once on ABS and once on its negation. The following patch fixes it by instead folding it to (type)-ABSU (A). 2020-06-24 Jakub Jelinek <jakub@redhat.com> PR middle-end/95810 * fold-const.c (fold_cond_expr_with_comparison): Optimize A <= 0 ? A : -A into (type)-absu(A) rather than -abs(A). * gcc.dg/ubsan/pr95810.c: New test.
Diffstat (limited to 'gcc/tree-vectorizer.c')
0 files changed, 0 insertions, 0 deletions