From: Jakub Jelinek Date: Tue, 30 May 2017 07:12:08 +0000 (+0200) Subject: backport: re PR c/67410 (c/c-typeck.c references out of bounds array) X-Git-Tag: releases/gcc-5.5.0~312 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=32b2c4954ad0518764ba9418ab3bbf7c99633a5e;p=thirdparty%2Fgcc.git backport: re PR c/67410 (c/c-typeck.c references out of bounds array) Backported from mainline 2016-08-12 Jakub Jelinek Martin Liska PR c/67410 * c-typeck.c (set_nonincremental_init_from_string): Use / instead of % to determine val element to change. Assert that wchar_bytes * charwidth fits into val array. * gcc.dg/pr67410.c: New test. From-SVN: r248596 --- diff --git a/gcc/c/ChangeLog b/gcc/c/ChangeLog index ca0fd0dc4b8f..bdc6b43856f5 100644 --- a/gcc/c/ChangeLog +++ b/gcc/c/ChangeLog @@ -1,6 +1,14 @@ 2017-05-30 Jakub Jelinek Backported from mainline + 2016-08-12 Jakub Jelinek + Martin Liska + + PR c/67410 + * c-typeck.c (set_nonincremental_init_from_string): Use / instead of + % to determine val element to change. Assert that + wchar_bytes * charwidth fits into val array. + 2016-08-11 Jakub Jelinek PR c/72816 diff --git a/gcc/c/c-typeck.c b/gcc/c/c-typeck.c index 15a1fc9b315f..8f3086e38f9e 100644 --- a/gcc/c/c-typeck.c +++ b/gcc/c/c-typeck.c @@ -8248,6 +8248,8 @@ set_nonincremental_init_from_string (tree str, wchar_bytes = TYPE_PRECISION (TREE_TYPE (TREE_TYPE (str))) / BITS_PER_UNIT; charwidth = TYPE_PRECISION (char_type_node); + gcc_assert ((size_t) wchar_bytes * charwidth + <= ARRAY_SIZE (val) * HOST_BITS_PER_WIDE_INT); type = TREE_TYPE (constructor_type); p = TREE_STRING_POINTER (str); end = p + TREE_STRING_LENGTH (str); @@ -8273,7 +8275,7 @@ set_nonincremental_init_from_string (tree str, bitpos = (wchar_bytes - byte - 1) * charwidth; else bitpos = byte * charwidth; - val[bitpos % HOST_BITS_PER_WIDE_INT] + val[bitpos / HOST_BITS_PER_WIDE_INT] |= ((unsigned HOST_WIDE_INT) ((unsigned char) *p++)) << (bitpos % HOST_BITS_PER_WIDE_INT); } diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index eccc05634545..4f031a919ad2 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,6 +1,11 @@ 2017-05-30 Jakub Jelinek Backported from mainline + 2016-08-12 Jakub Jelinek + + PR c/67410 + * gcc.dg/pr67410.c: New test. + 2016-08-11 Jakub Jelinek PR c++/72868 diff --git a/gcc/testsuite/gcc.dg/pr67410.c b/gcc/testsuite/gcc.dg/pr67410.c new file mode 100644 index 000000000000..ff3c4f16867d --- /dev/null +++ b/gcc/testsuite/gcc.dg/pr67410.c @@ -0,0 +1,15 @@ +/* PR c/67410 */ +/* { dg-do run } */ +/* { dg-options "-std=gnu11" } */ + +struct { + __CHAR16_TYPE__ s[2]; +} a[] = { u"ff", [0].s[0] = u'x', [1] = u"\u1234\u4567", [1].s[0] = u'\u89ab' }; + +int +main () +{ + if (a[0].s[0] != u'x' || a[0].s[1] != u'f' || a[1].s[0] != u'\u89ab' || a[1].s[1] != u'\u4567') + __builtin_abort (); + return 0; +}