From 3e8b0d55dcaac6f40f63ff5ff2c258e86f25f0fd Mon Sep 17 00:00:00 2001 From: pbrook Date: Fri, 19 Nov 2004 13:12:38 +0000 Subject: [PATCH] PR target/17735 * varasm.c (default_assemble_integer): Allow pointer-sized values. Expand comment. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@90918 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/ChangeLog | 6 ++++++ gcc/varasm.c | 5 +++-- 2 files changed, 9 insertions(+), 2 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index aef41d6..93484e0 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2004-11-19 Paul Brook + + PR target/17735 + * varasm.c (default_assemble_integer): Allow pointer-sized values. + Expand comment. + 2004-11-19 Nick Clifton * config/stormy16/stormy16.c (combine_bnp): Add code to handle diff --git a/gcc/varasm.c b/gcc/varasm.c index 6019b5a..aaf9e53 100644 --- a/gcc/varasm.c +++ b/gcc/varasm.c @@ -2026,8 +2026,9 @@ default_assemble_integer (rtx x ATTRIBUTE_UNUSED, int aligned_p ATTRIBUTE_UNUSED) { const char *op = integer_asm_op (size, aligned_p); - /* Avoid GAS bugs for values > word size. */ - if (size > UNITS_PER_WORD) + /* Avoid GAS bugs for large values. Specifically negative values whose + absolute value fits in a bfd_vma, but not in a bfd_signed_vma. */ + if (size > UNITS_PER_WORD && size > POINTER_SIZE / BITS_PER_UNIT) return false; return op && (assemble_integer_with_op (op, x), true); } -- 2.7.4