From: Alan Modra Date: Sun, 27 May 2001 11:57:25 +0000 (+0000) Subject: * config/tc-m68k.c (md_assemble): Ensure variable part of frag is X-Git-Tag: dberlin-typesystem-branchpoint~424 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=fbe572f93e9b2403e76e0bf809ae1706a56c9758;p=external%2Fbinutils.git * config/tc-m68k.c (md_assemble): Ensure variable part of frag is allocated in the same chunk as the fixed part. --- diff --git a/gas/ChangeLog b/gas/ChangeLog index ebc5b4a..8564e7f 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -1,3 +1,8 @@ +2001-05-27 Alan Modra + + * config/tc-m68k.c (md_assemble): Ensure variable part of frag is + allocated in the same chunk as the fixed part. + 2001-05-26 Alan Modra * write.c (relax_segment ): Calculate growth using diff --git a/gas/config/tc-m68k.c b/gas/config/tc-m68k.c index 842510f..62382ec 100644 --- a/gas/config/tc-m68k.c +++ b/gas/config/tc-m68k.c @@ -3664,6 +3664,21 @@ md_assemble (str) } /* There's some frag hacking */ + { + /* Calculate the max frag size. */ + int wid; + + wid = 2 * the_ins.fragb[0].fragoff; + for (n = 1; n < the_ins.nfrag; n++) + wid += 2 * (the_ins.numo - the_ins.fragb[n - 1].fragoff); + /* frag_var part. */ + wid += 10; + /* Make sure the whole insn fits in one chunk, in particular that + the var part is attached, as we access one byte before the + variable frag for byte branches. */ + frag_grow (wid); + } + for (n = 0, fromP = &the_ins.opcode[0]; n < the_ins.nfrag; n++) { int wid;