diff options
author | Vladimir Makarov <vmakarov@redhat.com> | 1998-08-20 16:10:35 +0000 |
---|---|---|
committer | Vladimir Makarov <vmakarov@redhat.com> | 1998-08-20 16:10:35 +0000 |
commit | bb89d84ac7d7b5090ebdf8c9b7ca9b8b8906c6fd (patch) | |
tree | 574b60da0ef1ebb3d3c87142e393027901273b94 /gas/expr.c | |
parent | c0ca074b5d71a817f6a063f7b7eb79c9cf9080a5 (diff) | |
download | gdb-bb89d84ac7d7b5090ebdf8c9b7ca9b8b8906c6fd.zip gdb-bb89d84ac7d7b5090ebdf8c9b7ca9b8b8906c6fd.tar.gz gdb-bb89d84ac7d7b5090ebdf8c9b7ca9b8b8906c6fd.tar.bz2 |
* expr.c (operand): Check correctly that there is no advance in
operand after atof_generic in order to decide "is it label 0f or
floating point number".
PR16670
Diffstat (limited to 'gas/expr.c')
-rw-r--r-- | gas/expr.c | 19 |
1 files changed, 18 insertions, 1 deletions
@@ -64,6 +64,7 @@ symbolS * make_expr_symbol (expressionP) expressionS *expressionP; { + expressionS zero; const char *fake; symbolS *symbolP; struct expr_symbol_line *n; @@ -72,6 +73,22 @@ make_expr_symbol (expressionP) && expressionP->X_add_number == 0) return expressionP->X_add_symbol; + if (expressionP->X_op == O_big) + { + /* This won't work, because the actual value is stored in + generic_floating_point_number or generic_bignum, and we are + going to lose it if we haven't already. */ + if (expressionP->X_add_number > 0) + as_bad (_("bignum invalid; zero assumed")); + else + as_bad (_("floating point number invalid; zero assumed")); + zero.X_op = O_constant; + zero.X_add_number = 0; + zero.X_unsigned = 0; + clean_up_expression (&zero); + expressionP = &zero; + } + fake = FAKE_LABEL_NAME; /* Putting constant symbols in absolute_section rather than @@ -907,7 +924,7 @@ operand (expressionP) { case 0: case ERROR_EXPONENT_OVERFLOW: - if (*cp == 'f' || *cp == 'b') + if (cp[-1] == 'f' || cp[-1] == 'b') /* looks like a difference expression */ goto is_0f_label; else |