https://gcc.gnu.org/bugzilla/show_bug.cgi?id=83392
--- Comment #6 from Jakub Jelinek <jakub at gcc dot gnu.org> --- When I try to fix this using: --- gcc/sanopt.c.jj 2018-03-02 00:15:54.670780980 +0100 +++ gcc/sanopt.c 2018-03-13 16:35:38.333020680 +0100 @@ -486,12 +486,17 @@ maybe_optimize_ubsan_ptr_ifn (sanopt_ctx HOST_WIDE_INT bitpos; base = get_inner_reference (base, &bitsize, &pbitpos, &offset, &mode, &unsignedp, &reversep, &volatilep); - if (offset == NULL_TREE + if ((offset == NULL_TREE || TREE_CODE (offset) == INTEGER_CST) && DECL_P (base) && pbitpos.is_constant (&bitpos)) { gcc_assert (!DECL_REGISTER (base)); - offset_int expr_offset = bitpos / BITS_PER_UNIT; + offset_int expr_offset; + if (offset) + expr_offset = wi::to_offset (offset) + bitpos / BITS_PER_UNIT; + else + expr_offset = bitpos / BITS_PER_UNIT; + expr_offset = wi::sext (expr_offset, POINTER_SIZE); offset_int total_offset = expr_offset + cur_offset; if (total_offset != wi::sext (total_offset, POINTER_SIZE)) { then ptr-overflow-sanitization-1.c FAILs for -m32 like before (i.e. 14 times, would need to adjust testcase), but -m64 FAILs 13 times compared to previous 17 times.