diff options
author | Martin Sebor <msebor@redhat.com> | 2019-02-18 16:31:17 +0000 |
---|---|---|
committer | Martin Sebor <msebor@gcc.gnu.org> | 2019-02-18 09:31:17 -0700 |
commit | e2ebb05cd478db489afa019d4b12e116754a267e (patch) | |
tree | dcbec44fef694c0a6ed863c0f6271bb424e0d9df /gcc/tree.c | |
parent | eb8c4926c5bcec83ec7d4198e46bc9efe9a26f17 (diff) | |
download | gcc-e2ebb05cd478db489afa019d4b12e116754a267e.zip gcc-e2ebb05cd478db489afa019d4b12e116754a267e.tar.gz gcc-e2ebb05cd478db489afa019d4b12e116754a267e.tar.bz2 |
PR middle-end/89294 - ICE in valid_constant_size_p
gcc/c-family/ChangeLog:
PR middle-end/89294
* c-common.c (invalid_array_size_error): Handle cst_size_not_constant.
gcc/ChangeLog:
PR middle-end/89294
* tree.c (valid_constant_size_p): Avoid assuming size is a constant
expression.
* tree.h (cst_size_error): Add the cst_size_not_constant enumerator.
From-SVN: r268990
Diffstat (limited to 'gcc/tree.c')
-rw-r--r-- | gcc/tree.c | 8 |
1 files changed, 7 insertions, 1 deletions
@@ -7521,7 +7521,13 @@ valid_constant_size_p (const_tree size, cst_size_error *perr /* = NULL */) if (!perr) perr = &error; - if (TREE_OVERFLOW (size)) + if (TREE_CODE (size) != INTEGER_CST) + { + *perr = cst_size_not_constant; + return false; + } + + if (TREE_OVERFLOW_P (size)) { *perr = cst_size_overflow; return false; |