1 /* A.out "format 1" file handling code for BFD.
2 Copyright (C) 1990-2014 Free Software Foundation, Inc.
3 Written by Cygnus Support.
4
5 This file is part of BFD, the Binary File Descriptor library.
6
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3 of the License, or
10 (at your option) any later version.
11
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with this program; if not, write to the Free Software
19 Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
20 MA 02110-1301, USA. */
21
22 #include "sysdep.h"
23 #include "bfd.h"
24 #include "libbfd.h"
25
26 #include "aout/sun4.h"
27 #include "libaout.h" /* BFD a.out internal data structures. */
28
29 #include "aout/aout64.h"
30 #include "aout/stab_gnu.h"
31 #include "aout/ar.h"
32
33 /* This is needed to reject a NewsOS file, e.g. in
34 gdb/testsuite/gdb.t10/crossload.exp. <kingdon@cygnus.com>
35 I needed to add M_UNKNOWN to recognize a 68000 object, so this will
36 probably no longer reject a NewsOS object. <ian@cygnus.com>. */
37 #ifndef MACHTYPE_OK
38 #define MACHTYPE_OK(mtype) \
39 (((mtype) == M_SPARC && bfd_lookup_arch (bfd_arch_sparc, 0) != NULL) \
40 || (((mtype) == M_UNKNOWN || (mtype) == M_68010 || (mtype) == M_68020) \
41 && bfd_lookup_arch (bfd_arch_m68k, 0) != NULL))
42 #endif
43
44 /* The file @code{aoutf1.h} contains the code for BFD's
45 a.out back end. Control over the generated back end is given by these
46 two preprocessor names:
47 @table @code
48 @item ARCH_SIZE
49 This value should be either 32 or 64, depending upon the size of an
50 int in the target format. It changes the sizes of the structs which
51 perform the memory/disk mapping of structures.
52
53 The 64 bit backend may only be used if the host compiler supports 64
54 ints (eg long long with gcc), by defining the name @code{BFD_HOST_64_BIT} in @code{bfd.h}.
55 With this name defined, @emph{all} bfd operations are performed with 64bit
56 arithmetic, not just those to a 64bit target.
57
58 @item TARGETNAME
59 The name put into the target vector.
60 @item
61 @end table. */
62
63 #if ARCH_SIZE == 64
64 #define sunos_set_arch_mach sunos_64_set_arch_mach
65 #define sunos_write_object_contents aout_64_sunos4_write_object_contents
66 #else
67 #define sunos_set_arch_mach sunos_32_set_arch_mach
68 #define sunos_write_object_contents aout_32_sunos4_write_object_contents
69 #endif
70
71 /* Merge backend data into the output file.
72 This is necessary on sparclet-aout where we want the resultant machine
73 number to be M_SPARCLET if any input file is M_SPARCLET. */
74
75 #define MY_bfd_merge_private_bfd_data sunos_merge_private_bfd_data
76
77 static bfd_boolean
sunos_merge_private_bfd_data(bfd * ibfd,bfd * obfd)78 sunos_merge_private_bfd_data (bfd *ibfd, bfd *obfd)
79 {
80 if (bfd_get_flavour (ibfd) != bfd_target_aout_flavour
81 || bfd_get_flavour (obfd) != bfd_target_aout_flavour)
82 return TRUE;
83
84 if (bfd_get_arch (obfd) == bfd_arch_sparc)
85 {
86 if (bfd_get_mach (obfd) < bfd_get_mach (ibfd))
87 bfd_set_arch_mach (obfd, bfd_arch_sparc, bfd_get_mach (ibfd));
88 }
89
90 return TRUE;
91 }
92
93 /* This is either sunos_32_set_arch_mach or sunos_64_set_arch_mach,
94 depending upon ARCH_SIZE. */
95
96 static void
sunos_set_arch_mach(bfd * abfd,enum machine_type machtype)97 sunos_set_arch_mach (bfd *abfd, enum machine_type machtype)
98 {
99 /* Determine the architecture and machine type of the object file. */
100 enum bfd_architecture arch;
101 unsigned long machine;
102
103 switch (machtype)
104 {
105 case M_UNKNOWN:
106 /* Some Sun3s make magic numbers without cpu types in them, so
107 we'll default to the 68000. */
108 arch = bfd_arch_m68k;
109 machine = bfd_mach_m68000;
110 break;
111
112 case M_68010:
113 case M_HP200:
114 arch = bfd_arch_m68k;
115 machine = bfd_mach_m68010;
116 break;
117
118 case M_68020:
119 case M_HP300:
120 arch = bfd_arch_m68k;
121 machine = bfd_mach_m68020;
122 break;
123
124 case M_SPARC:
125 arch = bfd_arch_sparc;
126 machine = 0;
127 break;
128
129 case M_SPARCLET:
130 arch = bfd_arch_sparc;
131 machine = bfd_mach_sparc_sparclet;
132 break;
133
134 case M_SPARCLITE_LE:
135 arch = bfd_arch_sparc;
136 machine = bfd_mach_sparc_sparclite_le;
137 break;
138
139 case M_386:
140 case M_386_DYNIX:
141 arch = bfd_arch_i386;
142 machine = 0;
143 break;
144
145 case M_HPUX:
146 arch = bfd_arch_m68k;
147 machine = 0;
148 break;
149
150 default:
151 arch = bfd_arch_obscure;
152 machine = 0;
153 break;
154 }
155 bfd_set_arch_mach (abfd, arch, machine);
156 }
157
158 #define SET_ARCH_MACH(ABFD, EXEC) \
159 NAME(sunos,set_arch_mach) (ABFD, N_MACHTYPE (EXEC)); \
160 choose_reloc_size(ABFD);
161
162 /* Determine the size of a relocation entry, based on the architecture. */
163
164 static void
choose_reloc_size(bfd * abfd)165 choose_reloc_size (bfd *abfd)
166 {
167 switch (bfd_get_arch (abfd))
168 {
169 case bfd_arch_sparc:
170 obj_reloc_entry_size (abfd) = RELOC_EXT_SIZE;
171 break;
172 default:
173 obj_reloc_entry_size (abfd) = RELOC_STD_SIZE;
174 break;
175 }
176 }
177
178 /* Write an object file in SunOS format. Section contents have
179 already been written. We write the file header, symbols, and
180 relocation. The real name of this function is either
181 aout_64_sunos4_write_object_contents or
182 aout_32_sunos4_write_object_contents, depending upon ARCH_SIZE. */
183
184 static bfd_boolean
sunos_write_object_contents(bfd * abfd)185 sunos_write_object_contents (bfd *abfd)
186 {
187 struct external_exec exec_bytes;
188 struct internal_exec *execp = exec_hdr (abfd);
189
190 /* Magic number, maestro, please! */
191 switch (bfd_get_arch (abfd))
192 {
193 case bfd_arch_m68k:
194 switch (bfd_get_mach (abfd))
195 {
196 case bfd_mach_m68000:
197 N_SET_MACHTYPE (*execp, M_UNKNOWN);
198 break;
199 case bfd_mach_m68010:
200 N_SET_MACHTYPE (*execp, M_68010);
201 break;
202 default:
203 case bfd_mach_m68020:
204 N_SET_MACHTYPE (*execp, M_68020);
205 break;
206 }
207 break;
208 case bfd_arch_sparc:
209 switch (bfd_get_mach (abfd))
210 {
211 case bfd_mach_sparc_sparclet:
212 N_SET_MACHTYPE (*execp, M_SPARCLET);
213 break;
214 case bfd_mach_sparc_sparclite_le:
215 N_SET_MACHTYPE (*execp, M_SPARCLITE_LE);
216 break;
217 default:
218 N_SET_MACHTYPE (*execp, M_SPARC);
219 break;
220 }
221 break;
222 case bfd_arch_i386:
223 N_SET_MACHTYPE (*execp, M_386);
224 break;
225 default:
226 N_SET_MACHTYPE (*execp, M_UNKNOWN);
227 }
228
229 choose_reloc_size (abfd);
230
231 N_SET_FLAGS (*execp, aout_backend_info (abfd)->exec_hdr_flags);
232
233 N_SET_DYNAMIC (*execp, (long)(bfd_get_file_flags (abfd) & DYNAMIC));
234
235 WRITE_HEADERS (abfd, execp);
236
237 return TRUE;
238 }
239
240 /* Core files. */
241
242 #define CORE_MAGIC 0x080456
243 #define CORE_NAMELEN 16
244
245 /* The core structure is taken from the Sun documentation.
246 Unfortunately, they don't document the FPA structure, or at least I
247 can't find it easily. Fortunately the core header contains its own
248 length. So this shouldn't cause problems, except for c_ucode, which
249 so far we don't use but is easy to find with a little arithmetic. */
250
251 /* But the reg structure can be gotten from the SPARC processor handbook.
252 This really should be in a GNU include file though so that gdb can use
253 the same info. */
254 struct regs
255 {
256 int r_psr;
257 int r_pc;
258 int r_npc;
259 int r_y;
260 int r_g1;
261 int r_g2;
262 int r_g3;
263 int r_g4;
264 int r_g5;
265 int r_g6;
266 int r_g7;
267 int r_o0;
268 int r_o1;
269 int r_o2;
270 int r_o3;
271 int r_o4;
272 int r_o5;
273 int r_o6;
274 int r_o7;
275 };
276
277 /* Taken from Sun documentation: */
278
279 /* FIXME: It's worse than we expect. This struct contains TWO substructs
280 neither of whose size we know, WITH STUFF IN BETWEEN THEM! We can't
281 even portably access the stuff in between! */
282
283 struct external_sparc_core
284 {
285 int c_magic; /* Corefile magic number. */
286 int c_len; /* Sizeof (struct core). */
287 #define SPARC_CORE_LEN 432
288 struct regs c_regs; /* General purpose registers -- MACHDEP SIZE. */
289 struct external_exec c_aouthdr; /* A.out header. */
290 int c_signo; /* Killing signal, if any. */
291 int c_tsize; /* Text size (bytes). */
292 int c_dsize; /* Data size (bytes). */
293 int c_ssize; /* Stack size (bytes). */
294 char c_cmdname[CORE_NAMELEN + 1]; /* Command name. */
295 double fp_stuff[1]; /* External FPU state (size unknown by us). */
296 /* The type "double" is critical here, for alignment.
297 SunOS declares a struct here, but the struct's
298 alignment is double since it contains doubles. */
299 int c_ucode; /* Exception no. from u_code. */
300 /* This member is not accessible by name since
301 we don't portably know the size of fp_stuff. */
302 };
303
304 /* Core files generated by the BCP (the part of Solaris which allows
305 it to run SunOS4 a.out files). */
306 struct external_solaris_bcp_core
307 {
308 int c_magic; /* Corefile magic number. */
309 int c_len; /* Sizeof (struct core). */
310 #define SOLARIS_BCP_CORE_LEN 456
311 struct regs c_regs; /* General purpose registers -- MACHDEP SIZE. */
312 int c_exdata_vp; /* Exdata structure. */
313 int c_exdata_tsize;
314 int c_exdata_dsize;
315 int c_exdata_bsize;
316 int c_exdata_lsize;
317 int c_exdata_nshlibs;
318 short c_exdata_mach;
319 short c_exdata_mag;
320 int c_exdata_toffset;
321 int c_exdata_doffset;
322 int c_exdata_loffset;
323 int c_exdata_txtorg;
324 int c_exdata_datorg;
325 int c_exdata_entloc;
326 int c_signo; /* Killing signal, if any. */
327 int c_tsize; /* Text size (bytes). */
328 int c_dsize; /* Data size (bytes). */
329 int c_ssize; /* Stack size (bytes). */
330 char c_cmdname[CORE_NAMELEN + 1]; /* Command name. */
331 double fp_stuff[1]; /* External FPU state (size unknown by us). */
332 /* The type "double" is critical here, for alignment.
333 SunOS declares a struct here, but the struct's
334 alignment is double since it contains doubles. */
335 int c_ucode; /* Exception no. from u_code. */
336 /* This member is not accessible by name since
337 we don't portably know the size of fp_stuff. */
338 };
339
340 struct external_sun3_core
341 {
342 int c_magic; /* Corefile magic number. */
343 int c_len; /* Sizeof (struct core). */
344 #define SUN3_CORE_LEN 826 /* As of SunOS 4.1.1. */
345 int c_regs[18]; /* General purpose registers -- MACHDEP SIZE. */
346 struct external_exec c_aouthdr; /* A.out header. */
347 int c_signo; /* Killing signal, if any. */
348 int c_tsize; /* Text size (bytes). */
349 int c_dsize; /* Data size (bytes). */
350 int c_ssize; /* Stack size (bytes). */
351 char c_cmdname[CORE_NAMELEN + 1]; /* Command name. */
352 double fp_stuff[1]; /* External FPU state (size unknown by us). */
353 /* The type "double" is critical here, for alignment.
354 SunOS declares a struct here, but the struct's
355 alignment is double since it contains doubles. */
356 int c_ucode; /* Exception no. from u_code. */
357 /* This member is not accessible by name since
358 we don't portably know the size of fp_stuff. */
359 };
360
361 struct internal_sunos_core
362 {
363 int c_magic; /* Corefile magic number. */
364 int c_len; /* Sizeof (struct core). */
365 long c_regs_pos; /* File offset of General purpose registers. */
366 int c_regs_size; /* Size of General purpose registers. */
367 struct internal_exec c_aouthdr; /* A.out header. */
368 int c_signo; /* Killing signal, if any. */
369 int c_tsize; /* Text size (bytes). */
370 int c_dsize; /* Data size (bytes). */
371 bfd_vma c_data_addr; /* Data start (address). */
372 int c_ssize; /* Stack size (bytes). */
373 bfd_vma c_stacktop; /* Stack top (address). */
374 char c_cmdname[CORE_NAMELEN + 1]; /* Command name. */
375 long fp_stuff_pos; /* File offset of external FPU state (regs). */
376 int fp_stuff_size; /* Size of it. */
377 int c_ucode; /* Exception no. from u_code. */
378 };
379
380 /* Byte-swap in the Sun-3 core structure. */
381
382 static void
swapcore_sun3(bfd * abfd,char * ext,struct internal_sunos_core * intcore)383 swapcore_sun3 (bfd *abfd, char *ext, struct internal_sunos_core *intcore)
384 {
385 struct external_sun3_core *extcore = (struct external_sun3_core *) ext;
386
387 intcore->c_magic = H_GET_32 (abfd, &extcore->c_magic);
388 intcore->c_len = H_GET_32 (abfd, &extcore->c_len);
389 intcore->c_regs_pos = offsetof (struct external_sun3_core, c_regs);
390 intcore->c_regs_size = sizeof (extcore->c_regs);
391 #if ARCH_SIZE == 64
392 aout_64_swap_exec_header_in
393 #else
394 aout_32_swap_exec_header_in
395 #endif
396 (abfd, &extcore->c_aouthdr, &intcore->c_aouthdr);
397 intcore->c_signo = H_GET_32 (abfd, &extcore->c_signo);
398 intcore->c_tsize = H_GET_32 (abfd, &extcore->c_tsize);
399 intcore->c_dsize = H_GET_32 (abfd, &extcore->c_dsize);
400 intcore->c_data_addr = N_DATADDR (intcore->c_aouthdr);
401 intcore->c_ssize = H_GET_32 (abfd, &extcore->c_ssize);
402 memcpy (intcore->c_cmdname, extcore->c_cmdname, sizeof (intcore->c_cmdname));
403 intcore->fp_stuff_pos = offsetof (struct external_sun3_core, fp_stuff);
404 /* FP stuff takes up whole rest of struct, except c_ucode. */
405 intcore->fp_stuff_size = intcore->c_len - (sizeof extcore->c_ucode) -
406 offsetof (struct external_sun3_core, fp_stuff);
407 /* Ucode is the last thing in the struct -- just before the end. */
408 intcore->c_ucode = H_GET_32 (abfd,
409 (intcore->c_len
410 - sizeof (extcore->c_ucode)
411 + (unsigned char *) extcore));
412 intcore->c_stacktop = 0x0E000000; /* By experimentation. */
413 }
414
415 /* Byte-swap in the Sparc core structure. */
416
417 static void
swapcore_sparc(bfd * abfd,char * ext,struct internal_sunos_core * intcore)418 swapcore_sparc (bfd *abfd, char *ext, struct internal_sunos_core *intcore)
419 {
420 struct external_sparc_core *extcore = (struct external_sparc_core *) ext;
421
422 intcore->c_magic = H_GET_32 (abfd, &extcore->c_magic);
423 intcore->c_len = H_GET_32 (abfd, &extcore->c_len);
424 intcore->c_regs_pos = offsetof (struct external_sparc_core, c_regs);
425 intcore->c_regs_size = sizeof (extcore->c_regs);
426 #if ARCH_SIZE == 64
427 aout_64_swap_exec_header_in
428 #else
429 aout_32_swap_exec_header_in
430 #endif
431 (abfd, &extcore->c_aouthdr, &intcore->c_aouthdr);
432 intcore->c_signo = H_GET_32 (abfd, &extcore->c_signo);
433 intcore->c_tsize = H_GET_32 (abfd, &extcore->c_tsize);
434 intcore->c_dsize = H_GET_32 (abfd, &extcore->c_dsize);
435 intcore->c_data_addr = N_DATADDR (intcore->c_aouthdr);
436 intcore->c_ssize = H_GET_32 (abfd, &extcore->c_ssize);
437 memcpy (intcore->c_cmdname, extcore->c_cmdname, sizeof (intcore->c_cmdname));
438 intcore->fp_stuff_pos = offsetof (struct external_sparc_core, fp_stuff);
439 /* FP stuff takes up whole rest of struct, except c_ucode. */
440 intcore->fp_stuff_size = intcore->c_len - (sizeof extcore->c_ucode) -
441 offsetof (struct external_sparc_core, fp_stuff);
442 /* Ucode is the last thing in the struct -- just before the end. */
443 intcore->c_ucode = H_GET_32 (abfd,
444 (intcore->c_len
445 - sizeof (extcore->c_ucode)
446 + (unsigned char *) extcore));
447
448 /* Supposedly the user stack grows downward from the bottom of kernel memory.
449 Presuming that this remains true, this definition will work. */
450 /* Now sun has provided us with another challenge. The value is different
451 for sparc2 and sparc10 (both running SunOS 4.1.3). We pick one or
452 the other based on the current value of the stack pointer. This
453 loses (a) if the stack pointer has been clobbered, or (b) if the stack
454 is larger than 128 megabytes.
455
456 It's times like these you're glad they're switching to ELF.
457
458 Note that using include files or nlist on /vmunix would be wrong,
459 because we want the value for this core file, no matter what kind of
460 machine we were compiled on or are running on. */
461 #define SPARC_USRSTACK_SPARC2 ((bfd_vma)0xf8000000)
462 #define SPARC_USRSTACK_SPARC10 ((bfd_vma)0xf0000000)
463 {
464 bfd_vma sp = H_GET_32 (abfd, &extcore->c_regs.r_o6);
465 if (sp < SPARC_USRSTACK_SPARC10)
466 intcore->c_stacktop = SPARC_USRSTACK_SPARC10;
467 else
468 intcore->c_stacktop = SPARC_USRSTACK_SPARC2;
469 }
470 }
471
472 /* Byte-swap in the Solaris BCP core structure. */
473
474 static void
swapcore_solaris_bcp(bfd * abfd,char * ext,struct internal_sunos_core * intcore)475 swapcore_solaris_bcp (bfd *abfd, char *ext, struct internal_sunos_core *intcore)
476 {
477 struct external_solaris_bcp_core *extcore =
478 (struct external_solaris_bcp_core *) ext;
479
480 intcore->c_magic = H_GET_32 (abfd, &extcore->c_magic);
481 intcore->c_len = H_GET_32 (abfd, &extcore->c_len);
482 intcore->c_regs_pos = offsetof (struct external_solaris_bcp_core, c_regs);
483 intcore->c_regs_size = sizeof (extcore->c_regs);
484
485 /* The Solaris BCP exdata structure does not contain an a_syms field,
486 so we are unable to synthesize an internal exec header.
487 Luckily we are able to figure out the start address of the data section,
488 which is the only thing needed from the internal exec header,
489 from the exdata structure.
490
491 As of Solaris 2.3, BCP core files for statically linked executables
492 are buggy. The exdata structure is not properly filled in, and
493 the data section is written from address zero instead of the data
494 start address. */
495 memset ((void *) &intcore->c_aouthdr, 0, sizeof (struct internal_exec));
496 intcore->c_data_addr = H_GET_32 (abfd, &extcore->c_exdata_datorg);
497 intcore->c_signo = H_GET_32 (abfd, &extcore->c_signo);
498 intcore->c_tsize = H_GET_32 (abfd, &extcore->c_tsize);
499 intcore->c_dsize = H_GET_32 (abfd, &extcore->c_dsize);
500 intcore->c_ssize = H_GET_32 (abfd, &extcore->c_ssize);
501 memcpy (intcore->c_cmdname, extcore->c_cmdname, sizeof (intcore->c_cmdname));
502 intcore->fp_stuff_pos =
503 offsetof (struct external_solaris_bcp_core, fp_stuff);
504 /* FP stuff takes up whole rest of struct, except c_ucode. */
505 intcore->fp_stuff_size = intcore->c_len - (sizeof extcore->c_ucode) -
506 offsetof (struct external_solaris_bcp_core, fp_stuff);
507 /* Ucode is the last thing in the struct -- just before the end */
508 intcore->c_ucode = H_GET_32 (abfd,
509 (intcore->c_len
510 - sizeof (extcore->c_ucode)
511 + (unsigned char *) extcore));
512
513 /* Supposedly the user stack grows downward from the bottom of kernel memory.
514 Presuming that this remains true, this definition will work. */
515 /* Now sun has provided us with another challenge. The value is different
516 for sparc2 and sparc10 (both running SunOS 4.1.3). We pick one or
517 the other based on the current value of the stack pointer. This
518 loses (a) if the stack pointer has been clobbered, or (b) if the stack
519 is larger than 128 megabytes.
520
521 It's times like these you're glad they're switching to ELF.
522
523 Note that using include files or nlist on /vmunix would be wrong,
524 because we want the value for this core file, no matter what kind of
525 machine we were compiled on or are running on. */
526 #define SPARC_USRSTACK_SPARC2 ((bfd_vma)0xf8000000)
527 #define SPARC_USRSTACK_SPARC10 ((bfd_vma)0xf0000000)
528 {
529 bfd_vma sp = H_GET_32 (abfd, &extcore->c_regs.r_o6);
530 if (sp < SPARC_USRSTACK_SPARC10)
531 intcore->c_stacktop = SPARC_USRSTACK_SPARC10;
532 else
533 intcore->c_stacktop = SPARC_USRSTACK_SPARC2;
534 }
535 }
536
537 /* Need this cast because ptr is really void *. */
538 #define core_hdr(bfd) ((bfd)->tdata.sun_core_data)
539 #define core_datasec(bfd) (core_hdr (bfd)->data_section)
540 #define core_stacksec(bfd) (core_hdr (bfd)->stack_section)
541 #define core_regsec(bfd) (core_hdr (bfd)->reg_section)
542 #define core_reg2sec(bfd) (core_hdr (bfd)->reg2_section)
543
544 /* These are stored in the bfd's tdata. */
545 struct sun_core_struct
546 {
547 struct internal_sunos_core *hdr; /* Core file header. */
548 asection *data_section;
549 asection *stack_section;
550 asection *reg_section;
551 asection *reg2_section;
552 };
553
554 static const bfd_target *
sunos4_core_file_p(bfd * abfd)555 sunos4_core_file_p (bfd *abfd)
556 {
557 unsigned char longbuf[4]; /* Raw bytes of various header fields. */
558 bfd_size_type core_size, amt;
559 unsigned long core_mag;
560 struct internal_sunos_core *core;
561 char *extcore;
562 struct mergem
563 {
564 struct sun_core_struct suncoredata;
565 struct internal_sunos_core internal_sunos_core;
566 char external_core[1];
567 } *mergem;
568 flagword flags;
569
570 if (bfd_bread ((void *) longbuf, (bfd_size_type) sizeof (longbuf), abfd)
571 != sizeof (longbuf))
572 return NULL;
573 core_mag = H_GET_32 (abfd, longbuf);
574
575 if (core_mag != CORE_MAGIC)
576 return NULL;
577
578 /* SunOS core headers can vary in length; second word is size; */
579 if (bfd_bread ((void *) longbuf, (bfd_size_type) sizeof (longbuf), abfd)
580 != sizeof (longbuf))
581 return NULL;
582 core_size = H_GET_32 (abfd, longbuf);
583 /* Sanity check. */
584 if (core_size > 20000)
585 return NULL;
586
587 if (bfd_seek (abfd, (file_ptr) 0, SEEK_SET) != 0)
588 return NULL;
589
590 amt = core_size + sizeof (struct mergem);
591 mergem = bfd_zalloc (abfd, amt);
592 if (mergem == NULL)
593 return NULL;
594
595 extcore = mergem->external_core;
596
597 if ((bfd_bread ((void *) extcore, core_size, abfd)) != core_size)
598 {
599 loser:
600 bfd_release (abfd, (char *) mergem);
601 abfd->tdata.any = NULL;
602 bfd_section_list_clear (abfd);
603 return NULL;
604 }
605
606 /* Validate that it's a core file we know how to handle, due to sun
607 botching the positioning of registers and other fields in a machine
608 dependent way. */
609 core = &mergem->internal_sunos_core;
610 switch (core_size)
611 {
612 case SPARC_CORE_LEN:
613 swapcore_sparc (abfd, extcore, core);
614 break;
615 case SUN3_CORE_LEN:
616 swapcore_sun3 (abfd, extcore, core);
617 break;
618 case SOLARIS_BCP_CORE_LEN:
619 swapcore_solaris_bcp (abfd, extcore, core);
620 break;
621 default:
622 bfd_set_error (bfd_error_system_call); /* FIXME. */
623 goto loser;
624 }
625
626 abfd->tdata.sun_core_data = &mergem->suncoredata;
627 abfd->tdata.sun_core_data->hdr = core;
628
629 /* Create the sections. */
630 flags = SEC_ALLOC + SEC_LOAD + SEC_HAS_CONTENTS;
631 core_stacksec (abfd) = bfd_make_section_anyway_with_flags (abfd, ".stack",
632 flags);
633 if (core_stacksec (abfd) == NULL)
634 /* bfd_release frees everything allocated after it's arg. */
635 goto loser;
636
637 flags = SEC_ALLOC + SEC_LOAD + SEC_HAS_CONTENTS;
638 core_datasec (abfd) = bfd_make_section_anyway_with_flags (abfd, ".data",
639 flags);
640 if (core_datasec (abfd) == NULL)
641 goto loser;
642
643 flags = SEC_HAS_CONTENTS;
644 core_regsec (abfd) = bfd_make_section_anyway_with_flags (abfd, ".reg",
645 flags);
646 if (core_regsec (abfd) == NULL)
647 goto loser;
648
649 flags = SEC_HAS_CONTENTS;
650 core_reg2sec (abfd) = bfd_make_section_anyway_with_flags (abfd, ".reg2",
651 flags);
652 if (core_reg2sec (abfd) == NULL)
653 goto loser;
654
655 core_stacksec (abfd)->size = core->c_ssize;
656 core_datasec (abfd)->size = core->c_dsize;
657 core_regsec (abfd)->size = core->c_regs_size;
658 core_reg2sec (abfd)->size = core->fp_stuff_size;
659
660 core_stacksec (abfd)->vma = (core->c_stacktop - core->c_ssize);
661 core_datasec (abfd)->vma = core->c_data_addr;
662 core_regsec (abfd)->vma = 0;
663 core_reg2sec (abfd)->vma = 0;
664
665 core_stacksec (abfd)->filepos = core->c_len + core->c_dsize;
666 core_datasec (abfd)->filepos = core->c_len;
667 /* We'll access the regs afresh in the core file, like any section: */
668 core_regsec (abfd)->filepos = (file_ptr) core->c_regs_pos;
669 core_reg2sec (abfd)->filepos = (file_ptr) core->fp_stuff_pos;
670
671 /* Align to word at least. */
672 core_stacksec (abfd)->alignment_power = 2;
673 core_datasec (abfd)->alignment_power = 2;
674 core_regsec (abfd)->alignment_power = 2;
675 core_reg2sec (abfd)->alignment_power = 2;
676
677 return abfd->xvec;
678 }
679
680 static char *
sunos4_core_file_failing_command(bfd * abfd)681 sunos4_core_file_failing_command (bfd *abfd)
682 {
683 return core_hdr (abfd)->hdr->c_cmdname;
684 }
685
686 static int
sunos4_core_file_failing_signal(bfd * abfd)687 sunos4_core_file_failing_signal (bfd *abfd)
688 {
689 return core_hdr (abfd)->hdr->c_signo;
690 }
691
692 static bfd_boolean
sunos4_core_file_matches_executable_p(bfd * core_bfd,bfd * exec_bfd)693 sunos4_core_file_matches_executable_p (bfd *core_bfd, bfd *exec_bfd)
694 {
695 if (core_bfd->xvec != exec_bfd->xvec)
696 {
697 bfd_set_error (bfd_error_system_call);
698 return FALSE;
699 }
700
701 /* Solaris core files do not include an aouthdr. */
702 if ((core_hdr (core_bfd)->hdr)->c_len == SOLARIS_BCP_CORE_LEN)
703 return TRUE;
704
705 return memcmp ((char *) &((core_hdr (core_bfd)->hdr)->c_aouthdr),
706 (char *) exec_hdr (exec_bfd),
707 sizeof (struct internal_exec)) == 0;
708 }
709
710 #define MY_set_sizes sunos4_set_sizes
711
712 static bfd_boolean
sunos4_set_sizes(bfd * abfd)713 sunos4_set_sizes (bfd *abfd)
714 {
715 switch (bfd_get_arch (abfd))
716 {
717 default:
718 return FALSE;
719 case bfd_arch_sparc:
720 adata (abfd).page_size = 0x2000;
721 adata (abfd).segment_size = 0x2000;
722 adata (abfd).exec_bytes_size = EXEC_BYTES_SIZE;
723 return TRUE;
724 case bfd_arch_m68k:
725 adata (abfd).page_size = 0x2000;
726 adata (abfd).segment_size = 0x20000;
727 adata (abfd).exec_bytes_size = EXEC_BYTES_SIZE;
728 return TRUE;
729 }
730 }
731
732 /* We default to setting the toolversion field to 1, as is required by
733 SunOS. */
734 #ifndef MY_exec_hdr_flags
735 #define MY_exec_hdr_flags 1
736 #endif
737
738 #ifndef MY_entry_is_text_address
739 #define MY_entry_is_text_address 0
740 #endif
741 #ifndef MY_add_dynamic_symbols
742 #define MY_add_dynamic_symbols 0
743 #endif
744 #ifndef MY_add_one_symbol
745 #define MY_add_one_symbol 0
746 #endif
747 #ifndef MY_link_dynamic_object
748 #define MY_link_dynamic_object 0
749 #endif
750 #ifndef MY_write_dynamic_symbol
751 #define MY_write_dynamic_symbol 0
752 #endif
753 #ifndef MY_check_dynamic_reloc
754 #define MY_check_dynamic_reloc 0
755 #endif
756 #ifndef MY_finish_dynamic_link
757 #define MY_finish_dynamic_link 0
758 #endif
759
760 static const struct aout_backend_data sunos4_aout_backend =
761 {
762 0, /* Zmagic files are not contiguous. */
763 1, /* Text includes header. */
764 MY_entry_is_text_address,
765 MY_exec_hdr_flags,
766 0, /* Default text vma. */
767 sunos4_set_sizes,
768 0, /* Header is counted in zmagic text. */
769 MY_add_dynamic_symbols,
770 MY_add_one_symbol,
771 MY_link_dynamic_object,
772 MY_write_dynamic_symbol,
773 MY_check_dynamic_reloc,
774 MY_finish_dynamic_link
775 };
776
777 #define MY_core_file_failing_command sunos4_core_file_failing_command
778 #define MY_core_file_failing_signal sunos4_core_file_failing_signal
779 #define MY_core_file_matches_executable_p sunos4_core_file_matches_executable_p
780
781 #define MY_bfd_debug_info_start bfd_void
782 #define MY_bfd_debug_info_end bfd_void
783 #define MY_bfd_debug_info_accumulate (void (*) (bfd *, struct bfd_section *)) bfd_void
784 #define MY_core_file_p sunos4_core_file_p
785 #define MY_write_object_contents NAME(aout, sunos4_write_object_contents)
786 #define MY_backend_data & sunos4_aout_backend
787
788 #ifndef TARGET_IS_LITTLE_ENDIAN_P
789 #define TARGET_IS_BIG_ENDIAN_P
790 #endif
791
792 #include "aout-target.h"
793