* write.c (relax_and_size_seg): Change to the segment we are
relaxing, in case md_convert_frag, called by cvt_frag_to_fill, wants to call fix_new. * config/tc-m68k.c (m68k_ip): Permit PC relative code if the segment of the symbol is the current segment, not just in text_section. (md_convert_frag_1): Don't call subseg_change. (md_estimate_size_before_relax): Likewise.
This commit is contained in:
parent
2e977a3ae4
commit
f00f5ecd1d
3 changed files with 23 additions and 21 deletions
|
@ -1,3 +1,14 @@
|
|||
Wed Sep 13 12:33:03 1995 Ian Lance Taylor <ian@cygnus.com>
|
||||
|
||||
* write.c (relax_and_size_seg): Change to the segment we are
|
||||
relaxing, in case md_convert_frag, called by cvt_frag_to_fill,
|
||||
wants to call fix_new.
|
||||
* config/tc-m68k.c (m68k_ip): Permit PC relative code if the
|
||||
segment of the symbol is the current segment, not just in
|
||||
text_section.
|
||||
(md_convert_frag_1): Don't call subseg_change.
|
||||
(md_estimate_size_before_relax): Likewise.
|
||||
|
||||
Tue Sep 12 10:36:40 1995 Doug Evans <dje@canuck.cygnus.com>
|
||||
|
||||
* config/tc-arm.c (md_atof): Fix debugging printf, and leave it
|
||||
|
|
|
@ -1832,8 +1832,7 @@ m68k_ip (instring)
|
|||
if (isvar (&opP->disp)
|
||||
&& !subs (&opP->disp)
|
||||
&& adds (&opP->disp)
|
||||
&& (S_GET_SEGMENT (adds (&opP->disp)) == text_section)
|
||||
&& now_seg == text_section
|
||||
&& S_GET_SEGMENT (adds (&opP->disp)) == now_seg
|
||||
&& cpu_of_arch (current_architecture) >= m68020
|
||||
&& !flag_long_jumps
|
||||
&& !strchr ("~%&$?", s[0]))
|
||||
|
@ -3453,7 +3452,6 @@ md_convert_frag_1 (fragP)
|
|||
{
|
||||
fragP->fr_opcode[0] = 0x4E;
|
||||
fragP->fr_opcode[1] = (char) 0xB9; /* JBSR with ABSL LONG offset */
|
||||
subseg_change (text_section, 0); /* @@ */
|
||||
|
||||
fix_new (fragP,
|
||||
fragP->fr_fix,
|
||||
|
@ -3471,7 +3469,6 @@ md_convert_frag_1 (fragP)
|
|||
{
|
||||
fragP->fr_opcode[0] = 0x4E;
|
||||
fragP->fr_opcode[1] = (char) 0xF9; /* JMP with ABSL LONG offset */
|
||||
subseg_change (text_section, 0); /* @@ */
|
||||
fix_new (fragP, fragP->fr_fix, 4, fragP->fr_symbol,
|
||||
fragP->fr_offset, 0, NO_RELOC);
|
||||
fragP->fr_fix += 4;
|
||||
|
@ -3500,7 +3497,6 @@ md_convert_frag_1 (fragP)
|
|||
*buffer_address++ = 0x4e; /* put in jmp long (0x4ef9) */
|
||||
*buffer_address++ = (char) 0xf9;
|
||||
fragP->fr_fix += 2; /* account for jmp instruction */
|
||||
subseg_change (text_section, 0);
|
||||
fix_new (fragP, fragP->fr_fix, 4, fragP->fr_symbol,
|
||||
fragP->fr_offset, 0, NO_RELOC);
|
||||
fragP->fr_fix += 4;
|
||||
|
@ -3518,7 +3514,6 @@ md_convert_frag_1 (fragP)
|
|||
*buffer_address++ = (char) 0xf9;
|
||||
|
||||
fragP->fr_fix += 6; /* account for bra/jmp instructions */
|
||||
subseg_change (text_section, 0);
|
||||
fix_new (fragP, fragP->fr_fix, 4, fragP->fr_symbol,
|
||||
fragP->fr_offset, 0, NO_RELOC);
|
||||
fragP->fr_fix += 4;
|
||||
|
@ -3539,7 +3534,6 @@ md_convert_frag_1 (fragP)
|
|||
/* The thing to do here is force it to ABSOLUTE LONG, since
|
||||
PCREL is really trying to shorten an ABSOLUTE address anyway */
|
||||
/* JF FOO This code has not been tested */
|
||||
subseg_change (text_section, 0);
|
||||
fix_new (fragP, fragP->fr_fix, 4, fragP->fr_symbol, fragP->fr_offset,
|
||||
0, NO_RELOC);
|
||||
if ((fragP->fr_opcode[1] & 0x3F) != 0x3A)
|
||||
|
@ -3552,7 +3546,6 @@ md_convert_frag_1 (fragP)
|
|||
ext = 0;
|
||||
break;
|
||||
case TAB (PCLEA, SHORT):
|
||||
subseg_change (text_section, 0);
|
||||
fix_new (fragP, (int) (fragP->fr_fix), 2, fragP->fr_symbol,
|
||||
fragP->fr_offset, 1, NO_RELOC);
|
||||
fragP->fr_opcode[1] &= ~0x3F;
|
||||
|
@ -3560,7 +3553,6 @@ md_convert_frag_1 (fragP)
|
|||
ext = 2;
|
||||
break;
|
||||
case TAB (PCLEA, LONG):
|
||||
subseg_change (text_section, 0);
|
||||
fixP = fix_new (fragP, (int) (fragP->fr_fix) + 2, 4, fragP->fr_symbol,
|
||||
fragP->fr_offset, 1, NO_RELOC);
|
||||
fixP->fx_pcrel_adjust = 2;
|
||||
|
@ -3585,7 +3577,6 @@ md_convert_frag_1 (fragP)
|
|||
ext = 0;
|
||||
break;
|
||||
case TAB (PCINDEX, SHORT):
|
||||
subseg_change (text_section, 0);
|
||||
disp += 2;
|
||||
assert (issword (disp));
|
||||
assert (fragP->fr_fix >= 2);
|
||||
|
@ -3598,7 +3589,6 @@ md_convert_frag_1 (fragP)
|
|||
ext = 2;
|
||||
break;
|
||||
case TAB (PCINDEX, LONG):
|
||||
subseg_change (text_section, 0);
|
||||
disp += 2;
|
||||
fixP = fix_new (fragP, (int) (fragP->fr_fix), 4, fragP->fr_symbol,
|
||||
fragP->fr_offset, (fragP->fr_opcode[1] & 077) == 073,
|
||||
|
@ -3674,7 +3664,6 @@ md_estimate_size_before_relax (fragP, segment)
|
|||
{
|
||||
fragP->fr_opcode[0] = 0x4E;
|
||||
fragP->fr_opcode[1] = (char) 0xB9; /* JBSR with ABSL LONG offset */
|
||||
subseg_change (text_section, 0);
|
||||
fix_new (fragP, fragP->fr_fix, 4,
|
||||
fragP->fr_symbol, fragP->fr_offset, 0, NO_RELOC);
|
||||
fragP->fr_fix += 4;
|
||||
|
@ -3684,7 +3673,6 @@ md_estimate_size_before_relax (fragP, segment)
|
|||
{
|
||||
fragP->fr_opcode[0] = 0x4E;
|
||||
fragP->fr_opcode[1] = (char) 0xF9; /* JMP with ABSL LONG offset */
|
||||
subseg_change (text_section, 0);
|
||||
fix_new (fragP, fragP->fr_fix, 4,
|
||||
fragP->fr_symbol, fragP->fr_offset, 0, NO_RELOC);
|
||||
fragP->fr_fix += 4;
|
||||
|
@ -3761,7 +3749,6 @@ md_estimate_size_before_relax (fragP, segment)
|
|||
buffer_address[0] = 0x4e; /* put in jmp long (0x4ef9) */
|
||||
buffer_address[1] = (char) 0xf8;
|
||||
fragP->fr_fix += 2; /* account for jmp instruction */
|
||||
subseg_change (text_section, 0);
|
||||
fix_new (fragP, fragP->fr_fix, 2, fragP->fr_symbol,
|
||||
fragP->fr_offset, 0, NO_RELOC);
|
||||
fragP->fr_fix += 2;
|
||||
|
@ -3773,7 +3760,6 @@ md_estimate_size_before_relax (fragP, segment)
|
|||
buffer_address[0] = 0x4e; /* put in jmp long (0x4ef9) */
|
||||
buffer_address[1] = (char) 0xf9;
|
||||
fragP->fr_fix += 2; /* account for jmp instruction */
|
||||
subseg_change (text_section, 0);
|
||||
fix_new (fragP, fragP->fr_fix, 4, fragP->fr_symbol,
|
||||
fragP->fr_offset, 0, NO_RELOC);
|
||||
fragP->fr_fix += 4;
|
||||
|
@ -3804,7 +3790,6 @@ md_estimate_size_before_relax (fragP, segment)
|
|||
buffer_address[4] = 0x4e; /* Put in Jump Word */
|
||||
buffer_address[5] = (char) 0xf8;
|
||||
fragP->fr_fix += 6; /* account for bra/jmp instruction */
|
||||
subseg_change (text_section, 0);
|
||||
fix_new (fragP, fragP->fr_fix, 2, fragP->fr_symbol,
|
||||
fragP->fr_offset, 0, NO_RELOC);
|
||||
fragP->fr_fix += 2;
|
||||
|
@ -3816,7 +3801,6 @@ md_estimate_size_before_relax (fragP, segment)
|
|||
buffer_address[4] = 0x4e; /* put in jmp long (0x4ef9) */
|
||||
buffer_address[5] = (char) 0xf9;
|
||||
fragP->fr_fix += 6; /* account for bra/jmp instruction */
|
||||
subseg_change (text_section, 0);
|
||||
fix_new (fragP, fragP->fr_fix, 4, fragP->fr_symbol,
|
||||
fragP->fr_offset, 0, NO_RELOC);
|
||||
fragP->fr_fix += 4;
|
||||
|
|
15
gas/write.c
15
gas/write.c
|
@ -130,6 +130,12 @@ fix_new_internal (frag, where, size, add_symbol, sub_symbol, offset, pcrel,
|
|||
fixP->fx_frag = frag;
|
||||
fixP->fx_where = where;
|
||||
fixP->fx_size = size;
|
||||
/* We've made fx_size a narrow field; check that it's wide enough. */
|
||||
if (fixP->fx_size != size)
|
||||
{
|
||||
as_bad ("field fx_size too small to hold %d", size);
|
||||
abort ();
|
||||
}
|
||||
fixP->fx_addsy = add_symbol;
|
||||
fixP->fx_subsy = sub_symbol;
|
||||
fixP->fx_offset = offset;
|
||||
|
@ -142,12 +148,11 @@ fix_new_internal (frag, where, size, add_symbol, sub_symbol, offset, pcrel,
|
|||
fixP->fx_pcrel_adjust = 0;
|
||||
fixP->fx_bit_fixP = 0;
|
||||
fixP->fx_addnumber = 0;
|
||||
fixP->tc_fix_data = NULL;
|
||||
fixP->fx_tcbit = 0;
|
||||
fixP->fx_done = 0;
|
||||
|
||||
#if defined (TC_I960) || defined (TC_NS32K)
|
||||
fixP->fx_bsr = 0;
|
||||
#ifdef TC_FIX_TYPE
|
||||
TC_INIT_FIX_DATA(fixP);
|
||||
#endif
|
||||
|
||||
as_where (&fixP->fx_file, &fixP->fx_line);
|
||||
|
@ -502,6 +507,8 @@ relax_and_size_seg (abfd, sec, xxx)
|
|||
int x;
|
||||
valueT size, newsize;
|
||||
|
||||
subseg_change (sec, 0);
|
||||
|
||||
flags = bfd_get_section_flags (abfd, sec);
|
||||
|
||||
seginfo = seg_info (sec);
|
||||
|
@ -2323,7 +2330,7 @@ fixup_segment (fixP, this_segment_type)
|
|||
as to whether or not a relocation will be needed to
|
||||
handle this fixup. */
|
||||
|
||||
if (TC_FORCE_RELOCATION (fixP))
|
||||
if (!TC_FORCE_RELOCATION (fixP))
|
||||
{
|
||||
fixP->fx_addsy = NULL;
|
||||
add_symbolP = NULL;
|
||||
|
|
Loading…
Reference in a new issue