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>
continue;
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:
my_getExpression (imm_expr, asarg);
asarg = expr_end;