diff options
author | Alan Modra <amodra@bigpond.net.au> | 2010-08-02 13:19:44 +0000 |
---|---|---|
committer | Alan Modra <amodra@bigpond.net.au> | 2010-08-02 13:19:44 +0000 |
commit | a034df24db5b70f4f3202e8a019431ed3de4fa57 (patch) | |
tree | a5eadfb5c75a585dbc36c8b90817b7ef4a962107 /gas/expr.c | |
parent | 5c66e47e123c32d60c30c11c65818b6bccd594c2 (diff) | |
download | binutils-redhat-a034df24db5b70f4f3202e8a019431ed3de4fa57.tar.gz |
PR gas/11867
* expr.c (operand <'-' and '~'>): Widen bignums.
(operand <'!'>): Correct bignum result and convert to O_constant.
* read.c (emit_expr): Don't assert on .byte bignum. Don't display
bignum truncated warning for sign extended bignums.
Diffstat (limited to 'gas/expr.c')
-rw-r--r-- | gas/expr.c | 21 |
1 files changed, 14 insertions, 7 deletions
diff --git a/gas/expr.c b/gas/expr.c index a6910bf91e..53952b56fa 100644 --- a/gas/expr.c +++ b/gas/expr.c @@ -1056,6 +1056,15 @@ operand (expressionS *expressionP, enum expr_mode mode) { for (i = 0; i < expressionP->X_add_number; ++i) generic_bignum[i] = ~generic_bignum[i]; + + /* Extend the bignum to at least the size of .octa. */ + if (expressionP->X_add_number < SIZE_OF_LARGE_NUMBER) + { + expressionP->X_add_number = SIZE_OF_LARGE_NUMBER; + for (; i < expressionP->X_add_number; ++i) + generic_bignum[i] = ~(LITTLENUM_TYPE) 0; + } + if (c == '-') for (i = 0; i < expressionP->X_add_number; ++i) { @@ -1066,14 +1075,12 @@ operand (expressionS *expressionP, enum expr_mode mode) } else if (c == '!') { - int nonzero = 0; for (i = 0; i < expressionP->X_add_number; ++i) - { - if (generic_bignum[i]) - nonzero = 1; - generic_bignum[i] = 0; - } - generic_bignum[0] = nonzero; + if (generic_bignum[i] != 0) + break; + expressionP->X_add_number = i >= expressionP->X_add_number; + expressionP->X_op = O_constant; + expressionP->X_unsigned = 1; } } else if (expressionP->X_op != O_illegal |