aboutsummaryrefslogtreecommitdiff
path: root/gcc/builtins.c
diff options
context:
space:
mode:
authorMartin Sebor <msebor@redhat.com>2019-04-04 22:38:10 +0000
committerMartin Sebor <msebor@gcc.gnu.org>2019-04-04 16:38:10 -0600
commit1a9b15a7d76ee3ee2cd960698a84e34ec10c2bf0 (patch)
treeb55605cb740d88748c0349945fe87a7b06634d12 /gcc/builtins.c
parent9a0cbb60d28042893135cee60ad28a48a7e2235d (diff)
downloadgcc-1a9b15a7d76ee3ee2cd960698a84e34ec10c2bf0.zip
gcc-1a9b15a7d76ee3ee2cd960698a84e34ec10c2bf0.tar.gz
gcc-1a9b15a7d76ee3ee2cd960698a84e34ec10c2bf0.tar.bz2
PR middle-end/89957 - ICE calling strnlen with an int128_t bound in a known range
PR middle-end/89957 - ICE calling strnlen with an int128_t bound in a known range PR middle-end/89911 - [9 Regression] ICE in get_attr_nonstring_decl gcc/ChangeLog: PR middle-end/89957 PR middle-end/89911 * builtins.c (expand_builtin_strnlen): Make sure wi::ltu_p operands have the same precision since the function crashes otherwise. * calls.c (maybe_warn_nonstring_arg): Avoid assuming strnlen() call has non-zero arguments. gcc/testsuite/ChangeLog: PR middle-end/89957 PR middle-end/89911 * gcc.dg/Wstringop-overflow-13.c: New test. From-SVN: r270154
Diffstat (limited to 'gcc/builtins.c')
-rw-r--r--gcc/builtins.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/gcc/builtins.c b/gcc/builtins.c
index daf5830..d37d73f 100644
--- a/gcc/builtins.c
+++ b/gcc/builtins.c
@@ -3151,7 +3151,7 @@ expand_builtin_strnlen (tree exp, rtx target, machine_mode target_mode)
return NULL_RTX;
if (!TREE_NO_WARNING (exp)
- && wi::ltu_p (wi::to_wide (maxobjsize), min)
+ && wi::ltu_p (wi::to_wide (maxobjsize, min.get_precision ()), min)
&& warning_at (loc, OPT_Wstringop_overflow_,
"%K%qD specified bound [%wu, %wu] "
"exceeds maximum object size %E",