From 4fe7ef963907aafdb4e47bce11f8d1ca49a6bd5e Mon Sep 17 00:00:00 2001 From: Stephane Carrez Date: Thu, 1 Nov 2001 09:56:17 +0000 Subject: * config/tc-m68hc11.c (build_jump_insn): Allocate worst case storage for bra/bsr and use frag_variant(), this ensure that the possible 16-bit BFD_RELOC_16 will be in the same frag. --- gas/config/tc-m68hc11.c | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) (limited to 'gas/config') diff --git a/gas/config/tc-m68hc11.c b/gas/config/tc-m68hc11.c index 43fe878..0c7ccab 100644 --- a/gas/config/tc-m68hc11.c +++ b/gas/config/tc-m68hc11.c @@ -1519,12 +1519,14 @@ build_jump_insn (opcode, operands, nb_operands, jmp_mode) /* bra/bsr made be changed into jmp/jsr. */ else if (code == M6811_BSR || code == M6811_BRA || code == M6812_BSR) { - opcode = m68hc11_new_insn (2); + /* Allocate worst case storage. */ + opcode = m68hc11_new_insn (3); number_to_chars_bigendian (opcode, code, 1); number_to_chars_bigendian (opcode + 1, 0, 1); - frag_var (rs_machine_dependent, 2, 1, - ENCODE_RELAX (STATE_PC_RELATIVE, STATE_UNDF), - operands[0].exp.X_add_symbol, (offsetT) n, opcode); + frag_variant (rs_machine_dependent, 1, 1, + ENCODE_RELAX (STATE_PC_RELATIVE, STATE_UNDF), + operands[0].exp.X_add_symbol, (offsetT) n, + opcode); } else if (current_architecture & cpu6812) { -- cgit v1.1