From 91951af61f96399405771bd886cb2aba5ba1a3cb Mon Sep 17 00:00:00 2001 From: Ian Lance Taylor Date: Tue, 6 May 1997 16:19:04 +0000 Subject: * config/tc-i386.c (md_section_align): If a.out and BFD, force section size to be aligned. --- gas/ChangeLog | 5 +++++ gas/config/tc-i386.c | 16 +++++++++++++++- 2 files changed, 20 insertions(+), 1 deletion(-) (limited to 'gas') diff --git a/gas/ChangeLog b/gas/ChangeLog index 889e391..38add04 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -1,3 +1,8 @@ +Tue May 6 12:18:09 1997 Ian Lance Taylor + + * config/tc-i386.c (md_section_align): If a.out and BFD, force + section size to be aligned. + Mon May 5 17:16:55 1997 Ian Lance Taylor * cond.c: Include "macro.h". diff --git a/gas/config/tc-i386.c b/gas/config/tc-i386.c index 4a20a7e..1b4424d 100644 --- a/gas/config/tc-i386.c +++ b/gas/config/tc-i386.c @@ -2981,7 +2981,21 @@ md_section_align (segment, size) segT segment; valueT size; { - return size; /* Byte alignment is fine */ +#ifdef OBJ_AOUT +#ifdef BFD_ASSEMBLER + /* For a.out, force the section size to be aligned. If we don't do + this, BFD will align it for us, but it will not write out the + final bytes of the section. This may be a bug in BFD, but it is + easier to fix it here since that is how the other a.out targets + work. */ + int align; + + align = bfd_get_section_alignment (stdoutput, segment); + size = ((size + (1 << align) - 1) & ((valueT) -1 << align)); +#endif +#endif + + return size; } /* Exactly what point is a PC-relative offset relative TO? On the -- cgit v1.1