diff options
author | Joseph Myers <joseph@codesourcery.com> | 2011-10-12 12:56:03 +0100 |
---|---|---|
committer | Joseph Myers <jsm28@gcc.gnu.org> | 2011-10-12 12:56:03 +0100 |
commit | a2d5091a51e15ef05478b68013ca3df36010a7a2 (patch) | |
tree | f9da918ccf98c870d0761a3947118511d0015444 /gcc/convert.c | |
parent | 58e9ddb14d9930d4b9fc80549031231605f4f228 (diff) | |
download | gcc-a2d5091a51e15ef05478b68013ca3df36010a7a2.zip gcc-a2d5091a51e15ef05478b68013ca3df36010a7a2.tar.gz gcc-a2d5091a51e15ef05478b68013ca3df36010a7a2.tar.bz2 |
re PR c/50565 (initializer element is not computable at load time)
PR c/50565
* convert.c (convert_to_integer): Do not narrow operands of
pointer subtraction.
testsuite:
* gcc.c-torture/compile/pr50565-1.c,
gcc.c-torture/compile/pr50565-2.c: New tests.
From-SVN: r179845
Diffstat (limited to 'gcc/convert.c')
-rw-r--r-- | gcc/convert.c | 9 |
1 files changed, 9 insertions, 0 deletions
diff --git a/gcc/convert.c b/gcc/convert.c index a647193..f04b204 100644 --- a/gcc/convert.c +++ b/gcc/convert.c @@ -745,6 +745,15 @@ convert_to_integer (tree type, tree expr) tree arg0 = get_unwidened (TREE_OPERAND (expr, 0), type); tree arg1 = get_unwidened (TREE_OPERAND (expr, 1), type); + /* Do not try to narrow operands of pointer subtraction; + that will interfere with other folding. */ + if (ex_form == MINUS_EXPR + && CONVERT_EXPR_P (arg0) + && CONVERT_EXPR_P (arg1) + && POINTER_TYPE_P (TREE_TYPE (TREE_OPERAND (arg0, 0))) + && POINTER_TYPE_P (TREE_TYPE (TREE_OPERAND (arg1, 0)))) + break; + if (outprec >= BITS_PER_WORD || TRULY_NOOP_TRUNCATION (outprec, inprec) || inprec > TYPE_PRECISION (TREE_TYPE (arg0)) |