mirror of
https://github.com/espressif/binutils-gdb.git
synced 2025-06-24 04:00:07 +08:00
gas/RISC-V: adjust assembler for opcode table re-ordering
PR gas/29940 With the single-operand JAL entry now sitting ahead of the two-operand one, the parsing of a two-operand insn would first try to parse an 'a'- style operand, resulting in the insertion of bogus (and otherwise unused) undefined symbols in the symbol table, having register names. Since 'a' is used as 1st operand only with J and JAL, and since JAL is the only insn _also_ allowing for a register as 1st operand (and then there being a 2nd one), special case this parsing aspect right there. Reviewed-by: Palmer Dabbelt <palmer@rivosinc.com>
This commit is contained in:
@ -3266,6 +3266,17 @@ riscv_ip (char *str, struct riscv_cl_insn *ip, expressionS *imm_expr,
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
case 'a': /* 20-bit PC-relative offset. */
|
case 'a': /* 20-bit PC-relative offset. */
|
||||||
|
/* Like in my_getSmallExpression() we need to avoid emitting
|
||||||
|
a stray undefined symbol if the 1st JAL entry doesn't match,
|
||||||
|
but the 2nd (with 2 operands) might. */
|
||||||
|
if (oparg == insn->args)
|
||||||
|
{
|
||||||
|
asargStart = asarg;
|
||||||
|
if (reg_lookup (&asarg, RCLASS_GPR, NULL)
|
||||||
|
&& (*asarg == ',' || (ISSPACE (*asarg) && asarg[1] == ',')))
|
||||||
|
break;
|
||||||
|
asarg = asargStart;
|
||||||
|
}
|
||||||
jump:
|
jump:
|
||||||
my_getExpression (imm_expr, asarg);
|
my_getExpression (imm_expr, asarg);
|
||||||
asarg = expr_end;
|
asarg = expr_end;
|
||||||
|
Reference in New Issue
Block a user