Tue Sep 19 14:02:21 1995 steve chamberlain <sac@slash.cygnus.com>

* peicode.h (coff_swap_scnhdr_out): Get sizes for BSS right.
	(pr 8045)
This commit is contained in:
Steve Chamberlain 1995-09-19 21:04:02 +00:00
parent f74b6b5f53
commit 500d7394cf
2 changed files with 27 additions and 16 deletions

View File

@ -1,3 +1,8 @@
Tue Sep 19 14:02:21 1995 steve chamberlain <sac@slash.cygnus.com>
* peicode.h (coff_swap_scnhdr_out): Get sizes for BSS right.
(pr 8045)
Mon Sep 18 14:35:01 1995 Arne H. Juul <arnej@pvv.unit.no>
* config.bfd (mips-dec-netbsd*): New target.

View File

@ -902,7 +902,8 @@ PTR out;
struct internal_scnhdr *scnhdr_int = (struct internal_scnhdr *)in;
SCNHDR *scnhdr_ext = (SCNHDR *)out;
unsigned int ret = sizeof (SCNHDR);
bfd_vma s;
bfd_vma ps;
bfd_vma ss;
memcpy(scnhdr_ext->s_name, scnhdr_int->s_name, sizeof(scnhdr_int->s_name));
@ -912,21 +913,26 @@ PTR out;
- pe_data(abfd)->pe_opthdr.ImageBase),
(bfd_byte *) scnhdr_ext->s_vaddr);
/* Note that we're really stuffing in the raw size into here. */
PUT_SCNHDR_SIZE (abfd, scnhdr_int->s_size,
(bfd_byte *) scnhdr_ext->s_size);
/* NT wants the size data to be rounded up to the next NT_FILE_ALIGNMENT
value except for the BSS section, its s_size should be 0 */
if (strcmp (scnhdr_int->s_name, _BSS) == 0)
s = 0;
else
s = scnhdr_int->s_paddr;
PUT_SCNHDR_PADDR (abfd, s, (bfd_byte *) scnhdr_ext->s_paddr);
if (strcmp (scnhdr_int->s_name, _BSS) == 0)
{
ps = scnhdr_int->s_size;
ss = 0;
}
else
{
ps = scnhdr_int->s_paddr;
ss = scnhdr_int->s_size;
}
PUT_SCNHDR_SIZE (abfd, ss,
(bfd_byte *) scnhdr_ext->s_size);
PUT_SCNHDR_PADDR (abfd, ps, (bfd_byte *) scnhdr_ext->s_paddr);
PUT_SCNHDR_SCNPTR (abfd, scnhdr_int->s_scnptr,
(bfd_byte *) scnhdr_ext->s_scnptr);