https://gcc.gnu.org/g:cb06e4a961b85a06e666f03124f9bd0f99e79f8c

commit r15-10186-gcb06e4a961b85a06e666f03124f9bd0f99e79f8c
Author: Richard Biener <rguent...@suse.de>
Date:   Thu Jul 31 13:04:49 2025 +0200

    tree-optimization/121323 - UBSAN error in ao_ref_init_from_ptr_and_range
    
    We should check the offset fits a HWI when multiplied to be in bits.
    
            PR tree-optimization/121323
            * tree-ssa-alias.cc (ao_ref_init_from_ptr_and_range): Check
            the pointer offset fits in a HWI when represented in bits.
    
    (cherry picked from commit 0be8ffbc854410b65d45a72e843dc18b13fc7b0f)

Diff:
---
 gcc/tree-ssa-alias.cc | 4 +++-
 1 file changed, 3 insertions(+), 1 deletion(-)

diff --git a/gcc/tree-ssa-alias.cc b/gcc/tree-ssa-alias.cc
index 9dd1780867d4..f60ed09514e9 100644
--- a/gcc/tree-ssa-alias.cc
+++ b/gcc/tree-ssa-alias.cc
@@ -901,7 +901,9 @@ ao_ref_init_from_ptr_and_range (ao_ref *ref, tree ptr,
   if (TREE_CODE (ptr) == ADDR_EXPR)
     {
       ref->base = get_addr_base_and_unit_offset (TREE_OPERAND (ptr, 0), &t);
-      if (ref->base)
+      if (ref->base
+         && coeffs_in_range_p (t, -HOST_WIDE_INT_MAX / BITS_PER_UNIT,
+                               HOST_WIDE_INT_MAX / BITS_PER_UNIT))
        ref->offset = BITS_PER_UNIT * t;
       else
        {

Reply via email to