Coverage Report

Created: 2026-05-11 07:54

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/binutils-gdb/bfd/mach-o.c
Line
Count
Source
1
/* Mach-O support for BFD.
2
   Copyright (C) 1999-2026 Free Software Foundation, Inc.
3
4
   This file is part of BFD, the Binary File Descriptor library.
5
6
   This program is free software; you can redistribute it and/or modify
7
   it under the terms of the GNU General Public License as published by
8
   the Free Software Foundation; either version 3 of the License, or
9
   (at your option) any later version.
10
11
   This program is distributed in the hope that it will be useful,
12
   but WITHOUT ANY WARRANTY; without even the implied warranty of
13
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14
   GNU General Public License for more details.
15
16
   You should have received a copy of the GNU General Public License
17
   along with this program; if not, write to the Free Software
18
   Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
19
   MA 02110-1301, USA.  */
20
21
#include "sysdep.h"
22
#include <limits.h>
23
#include "bfd.h"
24
#include "libbfd.h"
25
#include "libiberty.h"
26
#include "mach-o.h"
27
#include "aout/stab_gnu.h"
28
#include "mach-o/reloc.h"
29
#include "mach-o/external.h"
30
#include <ctype.h>
31
#include <stdlib.h>
32
#include <string.h>
33
34
#define bfd_mach_o_object_p bfd_mach_o_gen_object_p
35
#define bfd_mach_o_core_p bfd_mach_o_gen_core_p
36
#define bfd_mach_o_mkobject bfd_mach_o_gen_mkobject
37
38
#define FILE_ALIGN(off, algn) \
39
167
  (((off) + ((ufile_ptr) 1 << (algn)) - 1) & ((ufile_ptr) -1 << (algn)))
40
41
static bool
42
bfd_mach_o_read_dyld_content (bfd *abfd, bfd_mach_o_dyld_info_command *cmd);
43
44
unsigned int
45
bfd_mach_o_version (bfd *abfd)
46
0
{
47
0
  bfd_mach_o_data_struct *mdata = NULL;
48
49
0
  BFD_ASSERT (bfd_mach_o_valid (abfd));
50
0
  mdata = bfd_mach_o_get_data (abfd);
51
52
0
  return mdata->header.version;
53
0
}
54
55
bool
56
bfd_mach_o_valid (bfd *abfd)
57
72
{
58
72
  if (abfd == NULL || abfd->xvec == NULL)
59
0
    return false;
60
61
72
  if (abfd->xvec->flavour != bfd_target_mach_o_flavour)
62
0
    return false;
63
64
72
  if (bfd_mach_o_get_data (abfd) == NULL)
65
0
    return false;
66
72
  return true;
67
72
}
68
69
static inline bool
70
mach_o_wide_p (bfd_mach_o_header *header)
71
85.5k
{
72
85.5k
  switch (header->version)
73
85.5k
    {
74
35.7k
    case 1:
75
35.7k
      return false;
76
49.7k
    case 2:
77
49.7k
      return true;
78
0
    default:
79
0
      BFD_FAIL ();
80
0
      return false;
81
85.5k
    }
82
85.5k
}
83
84
static inline bool
85
bfd_mach_o_wide_p (bfd *abfd)
86
1.72k
{
87
1.72k
  return mach_o_wide_p (&bfd_mach_o_get_data (abfd)->header);
88
1.72k
}
89
90
/* Tables to translate well known Mach-O segment/section names to bfd
91
   names.  Use of canonical names (such as .text or .debug_frame) is required
92
   by gdb.  */
93
94
/* __TEXT Segment.  */
95
static const mach_o_section_name_xlat text_section_names_xlat[] =
96
  {
97
    { ".text",        "__text",
98
  SEC_CODE | SEC_LOAD,      BFD_MACH_O_S_REGULAR,
99
  BFD_MACH_O_S_ATTR_PURE_INSTRUCTIONS,  0},
100
    { ".const",       "__const",
101
  SEC_READONLY | SEC_DATA | SEC_LOAD, BFD_MACH_O_S_REGULAR,
102
  BFD_MACH_O_S_ATTR_NONE,     0},
103
    { ".static_const",      "__static_const",
104
  SEC_READONLY | SEC_DATA | SEC_LOAD, BFD_MACH_O_S_REGULAR,
105
  BFD_MACH_O_S_ATTR_NONE,     0},
106
    { ".cstring",       "__cstring",
107
  SEC_READONLY | SEC_DATA | SEC_LOAD | SEC_MERGE | SEC_STRINGS,
108
            BFD_MACH_O_S_CSTRING_LITERALS,
109
  BFD_MACH_O_S_ATTR_NONE,     0},
110
    { ".literal4",        "__literal4",
111
  SEC_READONLY | SEC_DATA | SEC_LOAD, BFD_MACH_O_S_4BYTE_LITERALS,
112
  BFD_MACH_O_S_ATTR_NONE,     2},
113
    { ".literal8",        "__literal8",
114
  SEC_READONLY | SEC_DATA | SEC_LOAD, BFD_MACH_O_S_8BYTE_LITERALS,
115
  BFD_MACH_O_S_ATTR_NONE,     3},
116
    { ".literal16",       "__literal16",
117
  SEC_READONLY | SEC_DATA | SEC_LOAD, BFD_MACH_O_S_16BYTE_LITERALS,
118
  BFD_MACH_O_S_ATTR_NONE,     4},
119
    { ".constructor",       "__constructor",
120
  SEC_CODE | SEC_LOAD,      BFD_MACH_O_S_REGULAR,
121
  BFD_MACH_O_S_ATTR_NONE,     0},
122
    { ".destructor",        "__destructor",
123
  SEC_CODE | SEC_LOAD,      BFD_MACH_O_S_REGULAR,
124
  BFD_MACH_O_S_ATTR_NONE,     0},
125
    { ".eh_frame",        "__eh_frame",
126
  SEC_READONLY | SEC_DATA | SEC_LOAD, BFD_MACH_O_S_COALESCED,
127
  BFD_MACH_O_S_ATTR_LIVE_SUPPORT
128
  | BFD_MACH_O_S_ATTR_STRIP_STATIC_SYMS
129
  | BFD_MACH_O_S_ATTR_NO_TOC,   2},
130
    { NULL, NULL, 0, 0, 0, 0}
131
  };
132
133
/* __DATA Segment.  */
134
static const mach_o_section_name_xlat data_section_names_xlat[] =
135
  {
136
    { ".data",      "__data",
137
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
138
  BFD_MACH_O_S_ATTR_NONE,   0},
139
    { ".bss",       "__bss",
140
  SEC_NO_FLAGS,     BFD_MACH_O_S_ZEROFILL,
141
  BFD_MACH_O_S_ATTR_NONE,   0},
142
    { ".const_data",      "__const",
143
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
144
  BFD_MACH_O_S_ATTR_NONE,   0},
145
    { ".static_data",     "__static_data",
146
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
147
  BFD_MACH_O_S_ATTR_NONE,   0},
148
    { ".mod_init_func",   "__mod_init_func",
149
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_MOD_INIT_FUNC_POINTERS,
150
  BFD_MACH_O_S_ATTR_NONE,   2},
151
    { ".mod_term_func",   "__mod_term_func",
152
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_MOD_FINI_FUNC_POINTERS,
153
  BFD_MACH_O_S_ATTR_NONE,   2},
154
    { ".dyld",      "__dyld",
155
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
156
  BFD_MACH_O_S_ATTR_NONE,   0},
157
    { ".cfstring",      "__cfstring",
158
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
159
  BFD_MACH_O_S_ATTR_NONE,   2},
160
    { NULL, NULL, 0, 0, 0, 0}
161
  };
162
163
/* __DWARF Segment.  */
164
static const mach_o_section_name_xlat dwarf_section_names_xlat[] =
165
  {
166
    { ".debug_frame",     "__debug_frame",
167
  SEC_DEBUGGING,      BFD_MACH_O_S_REGULAR,
168
  BFD_MACH_O_S_ATTR_DEBUG,  0},
169
    { ".debug_info",      "__debug_info",
170
  SEC_DEBUGGING,      BFD_MACH_O_S_REGULAR,
171
  BFD_MACH_O_S_ATTR_DEBUG,  0},
172
    { ".debug_abbrev",    "__debug_abbrev",
173
  SEC_DEBUGGING,      BFD_MACH_O_S_REGULAR,
174
  BFD_MACH_O_S_ATTR_DEBUG,  0},
175
    { ".debug_aranges",   "__debug_aranges",
176
  SEC_DEBUGGING,      BFD_MACH_O_S_REGULAR,
177
  BFD_MACH_O_S_ATTR_DEBUG,  0},
178
    { ".debug_macinfo",   "__debug_macinfo",
179
  SEC_DEBUGGING,      BFD_MACH_O_S_REGULAR,
180
  BFD_MACH_O_S_ATTR_DEBUG,  0},
181
    { ".debug_line",      "__debug_line",
182
  SEC_DEBUGGING,      BFD_MACH_O_S_REGULAR,
183
  BFD_MACH_O_S_ATTR_DEBUG,  0},
184
    { ".debug_loc",     "__debug_loc",
185
  SEC_DEBUGGING,      BFD_MACH_O_S_REGULAR,
186
  BFD_MACH_O_S_ATTR_DEBUG,  0},
187
    { ".debug_pubnames",    "__debug_pubnames",
188
  SEC_DEBUGGING,      BFD_MACH_O_S_REGULAR,
189
  BFD_MACH_O_S_ATTR_DEBUG,  0},
190
    { ".debug_pubtypes",    "__debug_pubtypes",
191
  SEC_DEBUGGING,      BFD_MACH_O_S_REGULAR,
192
  BFD_MACH_O_S_ATTR_DEBUG,  0},
193
    { ".debug_str",     "__debug_str",
194
  SEC_DEBUGGING,      BFD_MACH_O_S_REGULAR,
195
  BFD_MACH_O_S_ATTR_DEBUG,  0},
196
    { ".debug_ranges",    "__debug_ranges",
197
  SEC_DEBUGGING,      BFD_MACH_O_S_REGULAR,
198
  BFD_MACH_O_S_ATTR_DEBUG,  0},
199
    { ".debug_macro",     "__debug_macro",
200
  SEC_DEBUGGING,      BFD_MACH_O_S_REGULAR,
201
  BFD_MACH_O_S_ATTR_DEBUG,  0},
202
    { ".debug_gdb_scripts",   "__debug_gdb_scri",
203
  SEC_DEBUGGING,      BFD_MACH_O_S_REGULAR,
204
  BFD_MACH_O_S_ATTR_DEBUG,  0},
205
    { NULL, NULL, 0, 0, 0, 0}
206
  };
207
208
/* __OBJC Segment.  */
209
static const mach_o_section_name_xlat objc_section_names_xlat[] =
210
  {
211
    { ".objc_class",      "__class",
212
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
213
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
214
    { ".objc_meta_class",   "__meta_class",
215
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
216
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
217
    { ".objc_cat_cls_meth",   "__cat_cls_meth",
218
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
219
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
220
    { ".objc_cat_inst_meth",    "__cat_inst_meth",
221
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
222
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
223
    { ".objc_protocol",   "__protocol",
224
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
225
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
226
    { ".objc_string_object",    "__string_object",
227
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
228
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
229
    { ".objc_cls_meth",   "__cls_meth",
230
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
231
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
232
    { ".objc_inst_meth",    "__inst_meth",
233
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
234
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
235
    { ".objc_cls_refs",   "__cls_refs",
236
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_LITERAL_POINTERS,
237
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
238
    { ".objc_message_refs",   "__message_refs",
239
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_LITERAL_POINTERS,
240
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
241
    { ".objc_symbols",    "__symbols",
242
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
243
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
244
    { ".objc_category",   "__category",
245
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
246
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
247
    { ".objc_class_vars",   "__class_vars",
248
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
249
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
250
    { ".objc_instance_vars",    "__instance_vars",
251
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
252
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
253
    { ".objc_module_info",    "__module_info",
254
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
255
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
256
    { ".objc_selector_strs",    "__selector_strs",
257
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_CSTRING_LITERALS,
258
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
259
    { ".objc_image_info",   "__image_info",
260
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
261
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
262
    { ".objc_selector_fixup",   "__sel_fixup",
263
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
264
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
265
    /* Objc V1 */
266
    { ".objc1_class_ext",   "__class_ext",
267
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
268
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
269
    { ".objc1_property_list",   "__property",
270
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
271
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
272
    { ".objc1_protocol_ext",    "__protocol_ext",
273
  SEC_DATA | SEC_LOAD,    BFD_MACH_O_S_REGULAR,
274
  BFD_MACH_O_S_ATTR_NO_DEAD_STRIP, 0},
275
    { NULL, NULL, 0, 0, 0, 0}
276
  };
277
278
static const mach_o_segment_name_xlat segsec_names_xlat[] =
279
  {
280
    { "__TEXT", text_section_names_xlat },
281
    { "__DATA", data_section_names_xlat },
282
    { "__DWARF", dwarf_section_names_xlat },
283
    { "__OBJC", objc_section_names_xlat },
284
    { NULL, NULL }
285
  };
286
287
static const char dsym_subdir[] = ".dSYM/Contents/Resources/DWARF";
288
289
/* For both cases bfd-name => mach-o name and vice versa, the specific target
290
   is checked before the generic.  This allows a target (e.g. ppc for cstring)
291
   to override the generic definition with a more specific one.  */
292
293
/* Fetch the translation from a Mach-O section designation (segment, section)
294
   as a bfd short name, if one exists.  Otherwise return NULL.
295
296
   Allow the segment and section names to be unterminated 16 byte arrays.  */
297
298
const mach_o_section_name_xlat *
299
bfd_mach_o_section_data_for_mach_sect (bfd *abfd, const char *segname,
300
               const char *sectname)
301
458k
{
302
458k
  const struct mach_o_segment_name_xlat *seg;
303
458k
  const mach_o_section_name_xlat *sec;
304
458k
  bfd_mach_o_backend_data *bed = bfd_mach_o_get_backend_data (abfd);
305
306
  /* First try any target-specific translations defined...  */
307
458k
  if (bed->segsec_names_xlat)
308
342k
    for (seg = bed->segsec_names_xlat; seg->segname; seg++)
309
239k
      if (strncmp (seg->segname, segname, BFD_MACH_O_SEGNAME_SIZE) == 0)
310
18.5k
  for (sec = seg->sections; sec->mach_o_name; sec++)
311
14.0k
    if (strncmp (sec->mach_o_name, sectname,
312
14.0k
           BFD_MACH_O_SECTNAME_SIZE) == 0)
313
555
      return sec;
314
315
  /* ... and then the Mach-O generic ones.  */
316
2.27M
  for (seg = segsec_names_xlat; seg->segname; seg++)
317
1.82M
    if (strncmp (seg->segname, segname, BFD_MACH_O_SEGNAME_SIZE) == 0)
318
98.7k
      for (sec = seg->sections; sec->mach_o_name; sec++)
319
90.4k
  if (strncmp (sec->mach_o_name, sectname,
320
90.4k
         BFD_MACH_O_SECTNAME_SIZE) == 0)
321
3.83k
    return sec;
322
323
454k
  return NULL;
324
458k
}
325
326
/* If the bfd_name for this section is a 'canonical' form for which we
327
   know the Mach-O data, return the segment name and the data for the
328
   Mach-O equivalent.  Otherwise return NULL.  */
329
330
const mach_o_section_name_xlat *
331
bfd_mach_o_section_data_for_bfd_name (bfd *abfd, const char *bfd_name,
332
              const char **segname)
333
465k
{
334
465k
  const struct mach_o_segment_name_xlat *seg;
335
465k
  const mach_o_section_name_xlat *sec;
336
465k
  bfd_mach_o_backend_data *bed = bfd_mach_o_get_backend_data (abfd);
337
465k
  *segname = NULL;
338
339
465k
  if (bfd_name[0] != '.')
340
460k
    return NULL;
341
342
  /* First try any target-specific translations defined...  */
343
4.39k
  if (bed->segsec_names_xlat)
344
8.42k
    for (seg = bed->segsec_names_xlat; seg->segname; seg++)
345
21.9k
      for (sec = seg->sections; sec->bfd_name; sec++)
346
16.0k
  if (strcmp (bfd_name, sec->bfd_name) == 0)
347
555
    {
348
555
      *segname = seg->segname;
349
555
      return sec;
350
555
    }
351
352
  /* ... and then the Mach-O generic ones.  */
353
6.71k
  for (seg = segsec_names_xlat; seg->segname; seg++)
354
47.6k
    for (sec = seg->sections; sec->bfd_name; sec++)
355
44.8k
      if (strcmp (bfd_name, sec->bfd_name) == 0)
356
3.84k
  {
357
3.84k
    *segname = seg->segname;
358
3.84k
    return sec;
359
3.84k
  }
360
361
0
  return NULL;
362
3.84k
}
363
364
/* Convert Mach-O section name to BFD.
365
366
   Try to use standard/canonical names, for which we have tables including
367
   default flag settings - which are returned.  Otherwise forge a new name
368
   in the form "<segmentname>.<sectionname>" this will be prefixed with
369
   LC_SEGMENT. if the segment name does not begin with an underscore.
370
371
   SEGNAME and SECTNAME are 16 byte arrays (they do not need to be NUL-
372
   terminated if the name length is exactly 16 bytes - but must be if the name
373
   length is less than 16 characters).  */
374
375
void
376
bfd_mach_o_convert_section_name_to_bfd (bfd *abfd, const char *segname,
377
          const char *secname, const char **name,
378
          flagword *flags)
379
458k
{
380
458k
  const mach_o_section_name_xlat *xlat;
381
458k
  char *res;
382
458k
  size_t len;
383
458k
  const char *pfx = "";
384
385
458k
  *name = NULL;
386
458k
  *flags = SEC_NO_FLAGS;
387
388
  /* First search for a canonical name...
389
     xlat will be non-null if there is an entry for segname, secname.  */
390
458k
  xlat = bfd_mach_o_section_data_for_mach_sect (abfd, segname, secname);
391
458k
  if (xlat)
392
4.38k
    {
393
4.38k
      len = strlen (xlat->bfd_name);
394
4.38k
      res = bfd_alloc (abfd, len + 1);
395
4.38k
      if (res == NULL)
396
0
  return;
397
4.38k
      memcpy (res, xlat->bfd_name, len + 1);
398
4.38k
      *name = res;
399
4.38k
      *flags = xlat->bfd_flags;
400
4.38k
      return;
401
4.38k
    }
402
403
  /* ... else we make up a bfd name from the segment concatenated with the
404
     section.  */
405
406
454k
  len = 16 + 1 + 16 + 1;
407
408
  /* Put "LC_SEGMENT." prefix if the segment name is weird (ie doesn't start
409
     with an underscore.  */
410
454k
  if (segname[0] != '_')
411
439k
    {
412
439k
      static const char seg_pfx[] = "LC_SEGMENT.";
413
414
439k
      pfx = seg_pfx;
415
439k
      len += sizeof (seg_pfx) - 1;
416
439k
    }
417
418
454k
  res = bfd_alloc (abfd, len);
419
454k
  if (res == NULL)
420
0
    return;
421
454k
  snprintf (res, len, "%s%.16s.%.16s", pfx, segname, secname);
422
454k
  *name = res;
423
454k
}
424
425
/* Convert a bfd section name to a Mach-O segment + section name.
426
427
   If the name is a canonical one for which we have a Darwin match
428
   return the translation table - which contains defaults for flags,
429
   type, attribute and default alignment data.
430
431
   Otherwise, expand the bfd_name (assumed to be in the form
432
   "[LC_SEGMENT.]<segmentname>.<sectionname>") and return NULL.  */
433
434
static const mach_o_section_name_xlat *
435
bfd_mach_o_convert_section_name_to_mach_o (bfd *abfd ATTRIBUTE_UNUSED,
436
             asection *sect,
437
             bfd_mach_o_section *section)
438
465k
{
439
465k
  const mach_o_section_name_xlat *xlat;
440
465k
  const char *name = bfd_section_name (sect);
441
465k
  const char *segname;
442
465k
  const char *dot;
443
465k
  size_t len;
444
465k
  size_t seglen;
445
465k
  size_t seclen;
446
447
465k
  memset (section->segname, 0, BFD_MACH_O_SEGNAME_SIZE + 1);
448
465k
  memset (section->sectname, 0, BFD_MACH_O_SECTNAME_SIZE + 1);
449
450
  /* See if is a canonical name ... */
451
465k
  xlat = bfd_mach_o_section_data_for_bfd_name (abfd, name, &segname);
452
465k
  if (xlat)
453
4.39k
    {
454
4.39k
      strcpy (section->segname, segname);
455
4.39k
      strcpy (section->sectname, xlat->mach_o_name);
456
4.39k
      return xlat;
457
4.39k
    }
458
459
  /* .. else we convert our constructed one back to Mach-O.
460
     Strip LC_SEGMENT. prefix, if present.  */
461
460k
  if (strncmp (name, "LC_SEGMENT.", 11) == 0)
462
439k
    name += 11;
463
464
  /* Find a dot.  */
465
460k
  dot = strchr (name, '.');
466
460k
  len = strlen (name);
467
468
  /* Try to split name into segment and section names.  */
469
460k
  if (dot && dot != name)
470
239k
    {
471
239k
      seglen = dot - name;
472
239k
      seclen = len - (dot + 1 - name);
473
474
239k
      if (seglen <= BFD_MACH_O_SEGNAME_SIZE
475
239k
    && seclen <= BFD_MACH_O_SECTNAME_SIZE)
476
234k
  {
477
234k
    memcpy (section->segname, name, seglen);
478
234k
    section->segname[seglen] = 0;
479
234k
    memcpy (section->sectname, dot + 1, seclen);
480
234k
    section->sectname[seclen] = 0;
481
234k
    return NULL;
482
234k
  }
483
239k
    }
484
485
  /* The segment and section names are both missing - don't make them
486
     into dots.  */
487
226k
  if (dot && dot == name)
488
220k
    return NULL;
489
490
  /* Just duplicate the name into both segment and section.  */
491
5.40k
  if (len > 16)
492
5.40k
    len = 16;
493
5.40k
  memcpy (section->segname, name, len);
494
5.40k
  section->segname[len] = 0;
495
5.40k
  memcpy (section->sectname, name, len);
496
5.40k
  section->sectname[len] = 0;
497
5.40k
  return NULL;
498
226k
}
499
500
/* Return the size of an entry for section SEC.
501
   Must be called only for symbol pointer section and symbol stubs
502
   sections.  */
503
504
unsigned int
505
bfd_mach_o_section_get_entry_size (bfd *abfd, bfd_mach_o_section *sec)
506
74
{
507
74
  switch (sec->flags & BFD_MACH_O_SECTION_TYPE_MASK)
508
74
    {
509
29
    case BFD_MACH_O_S_NON_LAZY_SYMBOL_POINTERS:
510
63
    case BFD_MACH_O_S_LAZY_SYMBOL_POINTERS:
511
63
      return bfd_mach_o_wide_p (abfd) ? 8 : 4;
512
11
    case BFD_MACH_O_S_SYMBOL_STUBS:
513
11
      return sec->reserved2;
514
0
    default:
515
0
      BFD_FAIL ();
516
0
      return 0;
517
74
    }
518
74
}
519
520
/* Return the number of indirect symbols for a section.
521
   Must be called only for symbol pointer section and symbol stubs
522
   sections.  */
523
524
unsigned int
525
bfd_mach_o_section_get_nbr_indirect (bfd *abfd, bfd_mach_o_section *sec)
526
87
{
527
87
  unsigned int elsz;
528
529
  /* FIXME: This array is set by the assembler but does not seem to be
530
     set anywhere for objcopy.  Since bfd_mach_o_build_dysymtab will
531
     not fill in output bfd_mach_o_dysymtab_command indirect_syms when
532
     this array is NULL we may as well return zero for the size.
533
     This is enough to stop objcopy allocating huge amounts of memory
534
     for indirect symbols in fuzzed object files.  */
535
87
  if (sec->indirect_syms == NULL)
536
87
    return 0;
537
538
0
  elsz = bfd_mach_o_section_get_entry_size (abfd, sec);
539
0
  if (elsz == 0)
540
0
    return 0;
541
0
  else
542
0
    return sec->size / elsz;
543
0
}
544
545
/* Append command CMD to ABFD.  Note that header.ncmds is not updated.  */
546
547
static void
548
bfd_mach_o_append_command (bfd *abfd, bfd_mach_o_load_command *cmd)
549
105k
{
550
105k
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
551
552
105k
  if (mdata->last_command != NULL)
553
96.0k
    mdata->last_command->next = cmd;
554
9.56k
  else
555
9.56k
    mdata->first_command = cmd;
556
105k
  mdata->last_command = cmd;
557
105k
  cmd->next = NULL;
558
105k
}
559
560
/* Copy any private info we understand from the input symbol
561
   to the output symbol.  */
562
563
bool
564
bfd_mach_o_bfd_copy_private_symbol_data (bfd *ibfd,
565
           asymbol **isymbol,
566
           bfd *obfd ATTRIBUTE_UNUSED,
567
           asymbol **osymbol)
568
191
{
569
191
  if (ibfd->xvec->flavour != bfd_target_mach_o_flavour)
570
0
    return true;
571
572
191
  bfd_mach_o_asymbol *os = (bfd_mach_o_asymbol *) *osymbol;
573
191
  bfd_mach_o_asymbol *is = (bfd_mach_o_asymbol *) *isymbol;
574
191
  os->n_type = is->n_type;
575
191
  os->n_sect = is->n_sect;
576
191
  os->n_desc = is->n_desc;
577
191
  os->symbol.udata.i = is->symbol.udata.i;
578
579
191
  return true;
580
191
}
581
582
/* Copy any private info we understand from the input section
583
   to the output section.  */
584
585
bool
586
bfd_mach_o_bfd_copy_private_section_data (bfd *ibfd,
587
            asection *isection,
588
            bfd *obfd ATTRIBUTE_UNUSED,
589
            asection *osection,
590
            struct bfd_link_info *link_info)
591
335
{
592
335
  if (link_info != NULL
593
335
      || ibfd->xvec->flavour != bfd_target_mach_o_flavour)
594
0
    return true;
595
596
335
  bfd_mach_o_section *os = bfd_mach_o_get_mach_o_section (osection);
597
335
  bfd_mach_o_section *is = bfd_mach_o_get_mach_o_section (isection);
598
599
335
  BFD_ASSERT (is != NULL && os != NULL);
600
601
335
  os->flags = is->flags;
602
335
  os->reserved1 = is->reserved1;
603
335
  os->reserved2 = is->reserved2;
604
335
  os->reserved3 = is->reserved3;
605
606
335
  return true;
607
335
}
608
609
static const char *
610
cputype (unsigned long value)
611
135
{
612
135
  switch (value)
613
135
    {
614
3
    case BFD_MACH_O_CPU_TYPE_VAX: return "VAX";
615
1
    case BFD_MACH_O_CPU_TYPE_MC680x0: return "MC68k";
616
5
    case BFD_MACH_O_CPU_TYPE_I386: return "I386";
617
0
    case BFD_MACH_O_CPU_TYPE_MIPS: return "MIPS";
618
0
    case BFD_MACH_O_CPU_TYPE_MC98000: return "MC98k";
619
0
    case BFD_MACH_O_CPU_TYPE_HPPA: return "HPPA";
620
94
    case BFD_MACH_O_CPU_TYPE_ARM: return "ARM";
621
0
    case BFD_MACH_O_CPU_TYPE_MC88000: return "MC88K";
622
0
    case BFD_MACH_O_CPU_TYPE_SPARC: return "SPARC";
623
0
    case BFD_MACH_O_CPU_TYPE_I860: return "I860";
624
0
    case BFD_MACH_O_CPU_TYPE_ALPHA: return "ALPHA";
625
0
    case BFD_MACH_O_CPU_TYPE_POWERPC: return "PPC";
626
0
    case BFD_MACH_O_CPU_TYPE_POWERPC_64: return "PPC64";
627
28
    case BFD_MACH_O_CPU_TYPE_X86_64: return "X86_64";
628
4
    case BFD_MACH_O_CPU_TYPE_ARM64: return "ARM64";
629
0
    default: return _("<unknown>");
630
135
    }
631
135
}
632
633
static const char *
634
cpusubtype (unsigned long cpu_type, unsigned long cpu_subtype, char *buffer)
635
135
{
636
135
  buffer[0] = 0;
637
135
  switch (cpu_subtype & BFD_MACH_O_CPU_SUBTYPE_MASK)
638
135
    {
639
61
    case 0:
640
61
      break;
641
63
    case BFD_MACH_O_CPU_SUBTYPE_LIB64:
642
63
      sprintf (buffer, " (LIB64)"); break;
643
11
    default:
644
11
      sprintf (buffer, _("<unknown mask flags>")); break;
645
135
    }
646
647
135
  cpu_subtype &= ~ BFD_MACH_O_CPU_SUBTYPE_MASK;
648
649
135
  switch (cpu_type)
650
135
    {
651
28
    case BFD_MACH_O_CPU_TYPE_X86_64:
652
33
    case BFD_MACH_O_CPU_TYPE_I386:
653
33
      switch (cpu_subtype)
654
33
  {
655
18
  case BFD_MACH_O_CPU_SUBTYPE_X86_ALL:
656
18
    return strcat (buffer, " (X86_ALL)");
657
15
  default:
658
15
    break;
659
33
  }
660
15
      break;
661
662
94
    case BFD_MACH_O_CPU_TYPE_ARM:
663
94
      switch (cpu_subtype)
664
94
  {
665
0
  case BFD_MACH_O_CPU_SUBTYPE_ARM_ALL:
666
0
    return strcat (buffer, " (ARM_ALL)");
667
0
  case BFD_MACH_O_CPU_SUBTYPE_ARM_V4T:
668
0
    return strcat (buffer, " (ARM_V4T)");
669
0
  case BFD_MACH_O_CPU_SUBTYPE_ARM_V6:
670
0
    return strcat (buffer, " (ARM_V6)");
671
0
  case BFD_MACH_O_CPU_SUBTYPE_ARM_V5TEJ:
672
0
    return strcat (buffer, " (ARM_V5TEJ)");
673
0
  case BFD_MACH_O_CPU_SUBTYPE_ARM_XSCALE:
674
0
    return strcat (buffer, " (ARM_XSCALE)");
675
0
  case BFD_MACH_O_CPU_SUBTYPE_ARM_V7:
676
0
    return strcat (buffer, " (ARM_V7)");
677
94
  default:
678
94
    break;
679
94
  }
680
94
      break;
681
682
94
    case BFD_MACH_O_CPU_TYPE_ARM64:
683
4
      switch (cpu_subtype)
684
4
  {
685
0
  case BFD_MACH_O_CPU_SUBTYPE_ARM64_ALL:
686
0
    return strcat (buffer, " (ARM64_ALL)");
687
0
  case BFD_MACH_O_CPU_SUBTYPE_ARM64_V8:
688
0
    return strcat (buffer, " (ARM64_V8)");
689
4
  default:
690
4
    break;
691
4
  }
692
4
      break;
693
694
4
    default:
695
4
      break;
696
135
    }
697
698
117
  if (cpu_subtype != 0)
699
116
    return strcat (buffer, _(" (<unknown>)"));
700
701
1
  return buffer;
702
117
}
703
704
bool
705
bfd_mach_o_bfd_print_private_bfd_data (bfd *abfd, void *ptr)
706
135
{
707
135
  FILE * file = (FILE *) ptr;
708
135
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
709
135
  char buff[128];
710
711
135
  fprintf (file, _(" MACH-O header:\n"));
712
135
  fprintf (file, _("   magic:      %#lx\n"), (long) mdata->header.magic);
713
135
  fprintf (file, _("   cputype:    %#lx (%s)\n"), (long) mdata->header.cputype,
714
135
     cputype (mdata->header.cputype));
715
135
  fprintf (file, _("   cpusubtype: %#lx%s\n"), (long) mdata->header.cpusubtype,
716
135
     cpusubtype (mdata->header.cputype, mdata->header.cpusubtype, buff));
717
135
  fprintf (file, _("   filetype:   %#lx\n"), (long) mdata->header.filetype);
718
135
  fprintf (file, _("   ncmds:      %#lx\n"), (long) mdata->header.ncmds);
719
135
  fprintf (file, _("   sizeocmds:  %#lx\n"), (long) mdata->header.sizeofcmds);
720
135
  fprintf (file, _("   flags:      %#lx\n"), (long) mdata->header.flags);
721
135
  fprintf (file, _("   version:    %x\n"), mdata->header.version);
722
723
135
  return true;
724
135
}
725
726
/* Copy any private info we understand from the input bfd
727
   to the output bfd.  */
728
729
bool
730
bfd_mach_o_bfd_copy_private_header_data (bfd *ibfd, bfd *obfd)
731
36
{
732
36
  bfd_mach_o_data_struct *imdata;
733
36
  bfd_mach_o_data_struct *omdata;
734
36
  bfd_mach_o_load_command *icmd;
735
736
36
  if (bfd_get_flavour (ibfd) != bfd_target_mach_o_flavour)
737
0
    return true;
738
739
36
  BFD_ASSERT (bfd_mach_o_valid (ibfd));
740
36
  BFD_ASSERT (bfd_mach_o_valid (obfd));
741
742
36
  imdata = bfd_mach_o_get_data (ibfd);
743
36
  omdata = bfd_mach_o_get_data (obfd);
744
745
  /* Copy header flags.  */
746
36
  omdata->header.flags = imdata->header.flags;
747
748
  /* PR 23299.  Copy the cputype.  */
749
36
  if (imdata->header.cputype != omdata->header.cputype)
750
1
    {
751
1
      if (omdata->header.cputype == 0)
752
1
  omdata->header.cputype = imdata->header.cputype;
753
0
      else if (imdata->header.cputype != 0)
754
  /* Urg - what has happened ?  */
755
0
  _bfd_error_handler (_("incompatible cputypes in mach-o files: %ld vs %ld"),
756
0
          (long) imdata->header.cputype,
757
0
          (long) omdata->header.cputype);
758
1
    }
759
760
  /* Copy the cpusubtype.  */
761
36
  omdata->header.cpusubtype = imdata->header.cpusubtype;
762
763
  /* Copy commands.  */
764
342
  for (icmd = imdata->first_command; icmd != NULL; icmd = icmd->next)
765
306
    {
766
306
      bfd_mach_o_load_command *ocmd;
767
768
306
      switch (icmd->type)
769
306
  {
770
16
  case BFD_MACH_O_LC_LOAD_DYLIB:
771
32
  case BFD_MACH_O_LC_LOAD_DYLINKER:
772
48
  case BFD_MACH_O_LC_DYLD_INFO:
773
    /* Command is copied.  */
774
48
    ocmd = bfd_alloc (obfd, sizeof (bfd_mach_o_load_command));
775
48
    if (ocmd == NULL)
776
0
      return false;
777
778
    /* Copy common fields.  */
779
48
    ocmd->type = icmd->type;
780
48
    ocmd->type_required = icmd->type_required;
781
48
    ocmd->offset = 0;
782
48
    ocmd->len = icmd->len;
783
48
    break;
784
785
258
  default:
786
    /* Command is not copied.  */
787
258
    continue;
788
258
    break;
789
306
  }
790
791
48
      switch (icmd->type)
792
48
  {
793
16
  case BFD_MACH_O_LC_LOAD_DYLIB:
794
16
    {
795
16
      bfd_mach_o_dylib_command *idy = &icmd->command.dylib;
796
16
      bfd_mach_o_dylib_command *ody = &ocmd->command.dylib;
797
798
16
      ody->name_offset = idy->name_offset;
799
16
      ody->timestamp = idy->timestamp;
800
16
      ody->current_version = idy->current_version;
801
16
      ody->compatibility_version = idy->compatibility_version;
802
16
      ody->name_str = idy->name_str;
803
16
    }
804
16
    break;
805
806
16
  case BFD_MACH_O_LC_LOAD_DYLINKER:
807
16
    {
808
16
      bfd_mach_o_dylinker_command *idy = &icmd->command.dylinker;
809
16
      bfd_mach_o_dylinker_command *ody = &ocmd->command.dylinker;
810
811
16
      ody->name_offset = idy->name_offset;
812
16
      ody->name_str = idy->name_str;
813
16
    }
814
16
    break;
815
816
16
  case BFD_MACH_O_LC_DYLD_INFO:
817
16
    {
818
16
      bfd_mach_o_dyld_info_command *idy = &icmd->command.dyld_info;
819
16
      bfd_mach_o_dyld_info_command *ody = &ocmd->command.dyld_info;
820
821
16
      if (bfd_mach_o_read_dyld_content (ibfd, idy))
822
15
        {
823
15
    ody->rebase_size = idy->rebase_size;
824
15
    ody->rebase_content = idy->rebase_content;
825
826
15
    ody->bind_size = idy->bind_size;
827
15
    ody->bind_content = idy->bind_content;
828
829
15
    ody->weak_bind_size = idy->weak_bind_size;
830
15
    ody->weak_bind_content = idy->weak_bind_content;
831
832
15
    ody->lazy_bind_size = idy->lazy_bind_size;
833
15
    ody->lazy_bind_content = idy->lazy_bind_content;
834
835
15
    ody->export_size = idy->export_size;
836
15
    ody->export_content = idy->export_content;
837
15
        }
838
      /* PR 17512L: file: 730e492d.  */
839
1
      else
840
1
        {
841
1
    ody->rebase_size =
842
1
      ody->bind_size =
843
1
      ody->weak_bind_size =
844
1
      ody->lazy_bind_size =
845
1
      ody->export_size = 0;
846
1
    ody->rebase_content =
847
1
      ody->bind_content =
848
1
      ody->weak_bind_content =
849
1
      ody->lazy_bind_content =
850
1
      ody->export_content = NULL;
851
1
        }
852
16
    }
853
16
    break;
854
855
0
  default:
856
    /* That command should be handled.  */
857
0
    abort ();
858
48
  }
859
860
      /* Insert command.  */
861
48
      bfd_mach_o_append_command (obfd, ocmd);
862
48
    }
863
864
36
  return true;
865
36
}
866
867
/* This allows us to set up to 32 bits of flags (unless we invent some
868
   fiendish scheme to subdivide).  For now, we'll just set the file flags
869
   without error checking - just overwrite.  */
870
871
bool
872
bfd_mach_o_bfd_set_private_flags (bfd *abfd, flagword flags)
873
0
{
874
0
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
875
876
0
  if (!mdata)
877
0
    return false;
878
879
0
  mdata->header.flags = flags;
880
0
  return true;
881
0
}
882
883
/* Count the total number of symbols.  */
884
885
static long
886
bfd_mach_o_count_symbols (bfd *abfd)
887
6.74k
{
888
6.74k
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
889
890
6.74k
  if (mdata->symtab == NULL)
891
302
    return 0;
892
6.44k
  return mdata->symtab->nsyms;
893
6.74k
}
894
895
long
896
bfd_mach_o_get_symtab_upper_bound (bfd *abfd)
897
1.33k
{
898
1.33k
  long nsyms = bfd_mach_o_count_symbols (abfd);
899
900
1.33k
  return ((nsyms + 1) * sizeof (asymbol *));
901
1.33k
}
902
903
long
904
bfd_mach_o_canonicalize_symtab (bfd *abfd, asymbol **alocation)
905
1.25k
{
906
1.25k
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
907
1.25k
  long nsyms = bfd_mach_o_count_symbols (abfd);
908
1.25k
  bfd_mach_o_symtab_command *sym = mdata->symtab;
909
1.25k
  unsigned long j;
910
911
1.25k
  if (nsyms < 0)
912
0
    return nsyms;
913
914
1.25k
  if (nsyms == 0)
915
91
    {
916
      /* Do not try to read symbols if there are none.  */
917
91
      alocation[0] = NULL;
918
91
      return 0;
919
91
    }
920
921
1.16k
  if (!bfd_mach_o_read_symtab_symbols (abfd))
922
159
    {
923
159
      _bfd_error_handler
924
159
  (_("bfd_mach_o_canonicalize_symtab: unable to load symbols"));
925
159
      return -1;
926
159
    }
927
928
1.00k
  BFD_ASSERT (sym->symbols != NULL);
929
930
5.76k
  for (j = 0; j < sym->nsyms; j++)
931
4.76k
    alocation[j] = &sym->symbols[j].symbol;
932
933
1.00k
  alocation[j] = NULL;
934
935
1.00k
  return nsyms;
936
1.16k
}
937
938
/* Create synthetic symbols for indirect symbols.  */
939
940
long
941
bfd_mach_o_get_synthetic_symtab (bfd *abfd,
942
         long symcount ATTRIBUTE_UNUSED,
943
         asymbol **syms ATTRIBUTE_UNUSED,
944
         long dynsymcount ATTRIBUTE_UNUSED,
945
         asymbol **dynsyms ATTRIBUTE_UNUSED,
946
         asymbol **ret)
947
81
{
948
81
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
949
81
  bfd_mach_o_dysymtab_command *dysymtab = mdata->dysymtab;
950
81
  bfd_mach_o_symtab_command *symtab = mdata->symtab;
951
81
  asymbol *s;
952
81
  char * s_start;
953
81
  unsigned long count, i, j, n;
954
81
  size_t size;
955
81
  char *names;
956
81
  const char stub [] = "$stub";
957
958
81
  *ret = NULL;
959
960
  /* Stop now if no symbols or no indirect symbols.  */
961
81
  if (dysymtab == NULL || dysymtab->nindirectsyms == 0
962
69
      || symtab == NULL || symtab->symbols == NULL)
963
59
    return 0;
964
965
  /* We need to allocate a bfd symbol for every indirect symbol and to
966
     allocate the memory for its name.  */
967
22
  count = dysymtab->nindirectsyms;
968
22
  size = 0;
969
110
  for (j = 0; j < count; j++)
970
88
    {
971
88
      unsigned int isym = dysymtab->indirect_syms[j];
972
88
      const char *str;
973
974
      /* Some indirect symbols are anonymous.  */
975
88
      if (isym < symtab->nsyms
976
40
    && (str = symtab->symbols[isym].symbol.name) != NULL)
977
40
  {
978
    /* PR 17512: file: f5b8eeba.  */
979
40
    size += strnlen (str, symtab->strsize - (str - symtab->strtab));
980
40
    size += sizeof (stub);
981
40
  }
982
88
    }
983
984
22
  s_start = bfd_malloc (size + count * sizeof (asymbol));
985
22
  s = *ret = (asymbol *) s_start;
986
22
  if (s == NULL)
987
0
    return -1;
988
22
  names = (char *) (s + count);
989
990
22
  n = 0;
991
1.81k
  for (i = 0; i < mdata->nsects; i++)
992
1.80k
    {
993
1.80k
      bfd_mach_o_section *sec = mdata->sections[i];
994
1.80k
      unsigned int first, last;
995
1.80k
      bfd_vma addr;
996
1.80k
      unsigned int entry_size;
997
998
1.80k
      switch (sec->flags & BFD_MACH_O_SECTION_TYPE_MASK)
999
1.80k
  {
1000
29
  case BFD_MACH_O_S_NON_LAZY_SYMBOL_POINTERS:
1001
63
  case BFD_MACH_O_S_LAZY_SYMBOL_POINTERS:
1002
74
  case BFD_MACH_O_S_SYMBOL_STUBS:
1003
    /* Only these sections have indirect symbols.  */
1004
74
    first = sec->reserved1;
1005
74
    last = first + bfd_mach_o_section_get_nbr_indirect (abfd, sec);
1006
74
    addr = sec->addr;
1007
74
    entry_size = bfd_mach_o_section_get_entry_size (abfd, sec);
1008
1009
    /* PR 17512: file: 08e15eec.  */
1010
74
    if (first >= count || last > count || first > last)
1011
6
      goto fail;
1012
1013
68
    for (j = first; j < last; j++)
1014
0
      {
1015
0
        unsigned int isym = dysymtab->indirect_syms[j];
1016
0
        const char *str;
1017
0
        size_t len;
1018
1019
0
        if (isym < symtab->nsyms
1020
0
      && (str = symtab->symbols[isym].symbol.name) != NULL)
1021
0
    {
1022
      /* PR 17512: file: 04d64d9b.  */
1023
0
      if (n >= count)
1024
0
        goto fail;
1025
0
      len = strnlen (str, symtab->strsize - (str - symtab->strtab));
1026
      /* PR 17512: file: 47dfd4d2, 18f340a4.  */
1027
0
      if (size < len + sizeof (stub))
1028
0
        goto fail;
1029
0
      memcpy (names, str, len);
1030
0
      memcpy (names + len, stub, sizeof (stub));
1031
0
      s->name = names;
1032
0
      names += len + sizeof (stub);
1033
0
      size -= len + sizeof (stub);
1034
0
      s->the_bfd = symtab->symbols[isym].symbol.the_bfd;
1035
0
      s->flags = BSF_GLOBAL | BSF_SYNTHETIC;
1036
0
      s->section = sec->bfdsection;
1037
0
      s->value = addr - sec->addr;
1038
0
      s->udata.p = NULL;
1039
0
      s++;
1040
0
      n++;
1041
0
    }
1042
0
        addr += entry_size;
1043
0
      }
1044
68
    break;
1045
1.72k
  default:
1046
1.72k
    break;
1047
1.80k
  }
1048
1.80k
    }
1049
1050
16
  return n;
1051
1052
6
 fail:
1053
6
  free (s_start);
1054
6
  * ret = NULL;
1055
6
  return -1;
1056
22
}
1057
1058
void
1059
bfd_mach_o_get_symbol_info (bfd *abfd ATTRIBUTE_UNUSED,
1060
          asymbol *symbol,
1061
          symbol_info *ret)
1062
1.74k
{
1063
1.74k
  bfd_symbol_info (symbol, ret);
1064
1.74k
}
1065
1066
void
1067
bfd_mach_o_print_symbol (bfd *abfd,
1068
       void * afile,
1069
       asymbol *symbol,
1070
       bfd_print_symbol_type how)
1071
0
{
1072
0
  FILE *file = (FILE *) afile;
1073
0
  const char *name;
1074
0
  bfd_mach_o_asymbol *asym = (bfd_mach_o_asymbol *)symbol;
1075
1076
0
  switch (how)
1077
0
    {
1078
0
    case bfd_print_symbol_name:
1079
0
      fprintf (file, "%s", symbol->name);
1080
0
      break;
1081
0
    default:
1082
0
      bfd_print_symbol_vandf (abfd, (void *) file, symbol);
1083
0
      if (asym->n_type & BFD_MACH_O_N_STAB)
1084
0
  name = bfd_get_stab_name (asym->n_type);
1085
0
      else
1086
0
  switch (asym->n_type & BFD_MACH_O_N_TYPE)
1087
0
    {
1088
0
    case BFD_MACH_O_N_UNDF:
1089
0
      if (symbol->value == 0)
1090
0
        name = "UND";
1091
0
      else
1092
0
        name = "COM";
1093
0
      break;
1094
0
    case BFD_MACH_O_N_ABS:
1095
0
      name = "ABS";
1096
0
      break;
1097
0
    case BFD_MACH_O_N_INDR:
1098
0
      name = "INDR";
1099
0
      break;
1100
0
    case BFD_MACH_O_N_PBUD:
1101
0
      name = "PBUD";
1102
0
      break;
1103
0
    case BFD_MACH_O_N_SECT:
1104
0
      name = "SECT";
1105
0
      break;
1106
0
    default:
1107
0
      name = "???";
1108
0
      break;
1109
0
    }
1110
0
      if (name == NULL)
1111
0
  name = "";
1112
0
      fprintf (file, " %02x %-6s %02x %04x",
1113
0
         asym->n_type, name, asym->n_sect, asym->n_desc);
1114
0
      if ((asym->n_type & BFD_MACH_O_N_STAB) == 0
1115
0
    && (asym->n_type & BFD_MACH_O_N_TYPE) == BFD_MACH_O_N_SECT)
1116
0
  fprintf (file, " [%s]", symbol->section->name);
1117
0
      fprintf (file, " %s", symbol->name);
1118
0
    }
1119
0
}
1120
1121
static void
1122
bfd_mach_o_convert_architecture (bfd_mach_o_cpu_type mtype,
1123
         bfd_mach_o_cpu_subtype msubtype,
1124
         enum bfd_architecture *type,
1125
         unsigned long *subtype)
1126
10.1k
{
1127
10.1k
  *subtype = bfd_arch_unknown;
1128
1129
10.1k
  switch (mtype)
1130
10.1k
    {
1131
257
    case BFD_MACH_O_CPU_TYPE_VAX:
1132
257
      *type = bfd_arch_vax;
1133
257
      break;
1134
183
    case BFD_MACH_O_CPU_TYPE_MC680x0:
1135
183
      *type = bfd_arch_m68k;
1136
183
      break;
1137
3.35k
    case BFD_MACH_O_CPU_TYPE_I386:
1138
3.35k
      *type = bfd_arch_i386;
1139
3.35k
      *subtype = bfd_mach_i386_i386;
1140
3.35k
      break;
1141
2.20k
    case BFD_MACH_O_CPU_TYPE_X86_64:
1142
2.20k
      *type = bfd_arch_i386;
1143
2.20k
      *subtype = bfd_mach_x86_64;
1144
2.20k
      break;
1145
196
    case BFD_MACH_O_CPU_TYPE_MIPS:
1146
196
      *type = bfd_arch_mips;
1147
196
      break;
1148
58
    case BFD_MACH_O_CPU_TYPE_MC98000:
1149
58
      *type = bfd_arch_m98k;
1150
58
      break;
1151
146
    case BFD_MACH_O_CPU_TYPE_HPPA:
1152
146
      *type = bfd_arch_hppa;
1153
146
      break;
1154
2.20k
    case BFD_MACH_O_CPU_TYPE_ARM:
1155
2.20k
      *type = bfd_arch_arm;
1156
2.20k
      switch (msubtype)
1157
2.20k
  {
1158
14
  case BFD_MACH_O_CPU_SUBTYPE_ARM_V4T:
1159
14
    *subtype = bfd_mach_arm_4T;
1160
14
    break;
1161
14
  case BFD_MACH_O_CPU_SUBTYPE_ARM_V6:
1162
14
    *subtype = bfd_mach_arm_4T; /* Best fit ?  */
1163
14
    break;
1164
12
  case BFD_MACH_O_CPU_SUBTYPE_ARM_V5TEJ:
1165
12
    *subtype = bfd_mach_arm_5TE;
1166
12
    break;
1167
26
  case BFD_MACH_O_CPU_SUBTYPE_ARM_XSCALE:
1168
26
    *subtype = bfd_mach_arm_XScale;
1169
26
    break;
1170
17
  case BFD_MACH_O_CPU_SUBTYPE_ARM_V7:
1171
17
    *subtype = bfd_mach_arm_5TE; /* Best fit ?  */
1172
17
    break;
1173
45
  case BFD_MACH_O_CPU_SUBTYPE_ARM_ALL:
1174
2.12k
  default:
1175
2.12k
    break;
1176
2.20k
  }
1177
2.20k
      break;
1178
2.20k
    case BFD_MACH_O_CPU_TYPE_SPARC:
1179
313
      *type = bfd_arch_sparc;
1180
313
      *subtype = bfd_mach_sparc;
1181
313
      break;
1182
161
    case BFD_MACH_O_CPU_TYPE_ALPHA:
1183
161
      *type = bfd_arch_alpha;
1184
161
      break;
1185
230
    case BFD_MACH_O_CPU_TYPE_POWERPC:
1186
230
      *type = bfd_arch_powerpc;
1187
230
      *subtype = bfd_mach_ppc;
1188
230
      break;
1189
133
    case BFD_MACH_O_CPU_TYPE_POWERPC_64:
1190
133
      *type = bfd_arch_powerpc;
1191
133
      *subtype = bfd_mach_ppc64;
1192
133
      break;
1193
535
    case BFD_MACH_O_CPU_TYPE_ARM64:
1194
535
      *type = bfd_arch_aarch64;
1195
535
      *subtype = bfd_mach_aarch64;
1196
535
      break;
1197
226
    default:
1198
226
      *type = bfd_arch_unknown;
1199
226
      break;
1200
10.1k
    }
1201
10.1k
}
1202
1203
/* Write n NUL bytes to ABFD so that LEN + n is a multiple of 4.  Return the
1204
   number of bytes written or -1 in case of error.  */
1205
1206
static int
1207
bfd_mach_o_pad4 (bfd *abfd, size_t len)
1208
15
{
1209
15
  if (len % 4 != 0)
1210
13
    {
1211
13
      char pad[4] = {0,0,0,0};
1212
13
      unsigned int padlen = 4 - (len % 4);
1213
1214
13
      if (bfd_write (pad, padlen, abfd) != padlen)
1215
0
  return -1;
1216
1217
13
      return padlen;
1218
13
    }
1219
2
  else
1220
2
    return 0;
1221
15
}
1222
1223
/* Likewise, but for a command.  */
1224
1225
static int
1226
bfd_mach_o_pad_command (bfd *abfd, size_t len)
1227
30
{
1228
30
  size_t align = bfd_mach_o_wide_p (abfd) ? 8 : 4;
1229
1230
30
  if (len % align != 0)
1231
30
    {
1232
30
      char pad[8] = {0};
1233
30
      size_t padlen = align - (len % align);
1234
1235
30
      if (bfd_write (pad, padlen, abfd) != padlen)
1236
0
  return -1;
1237
1238
30
      return padlen;
1239
30
    }
1240
0
  else
1241
0
    return 0;
1242
30
}
1243
1244
static bool
1245
bfd_mach_o_write_header (bfd *abfd, bfd_mach_o_header *header)
1246
37
{
1247
37
  struct mach_o_header_external raw;
1248
37
  size_t size;
1249
1250
37
  size = mach_o_wide_p (header) ?
1251
28
    BFD_MACH_O_HEADER_64_SIZE : BFD_MACH_O_HEADER_SIZE;
1252
1253
37
  bfd_h_put_32 (abfd, header->magic, raw.magic);
1254
37
  bfd_h_put_32 (abfd, header->cputype, raw.cputype);
1255
37
  bfd_h_put_32 (abfd, header->cpusubtype, raw.cpusubtype);
1256
37
  bfd_h_put_32 (abfd, header->filetype, raw.filetype);
1257
37
  bfd_h_put_32 (abfd, header->ncmds, raw.ncmds);
1258
37
  bfd_h_put_32 (abfd, header->sizeofcmds, raw.sizeofcmds);
1259
37
  bfd_h_put_32 (abfd, header->flags, raw.flags);
1260
1261
37
  if (mach_o_wide_p (header))
1262
37
    bfd_h_put_32 (abfd, header->reserved, raw.reserved);
1263
1264
37
  if (bfd_seek (abfd, 0, SEEK_SET) != 0
1265
37
      || bfd_write (&raw, size, abfd) != size)
1266
0
    return false;
1267
1268
37
  return true;
1269
37
}
1270
1271
static bool
1272
bfd_mach_o_write_thread (bfd *abfd, bfd_mach_o_load_command *command)
1273
0
{
1274
0
  bfd_mach_o_thread_command *cmd = &command->command.thread;
1275
0
  unsigned int i;
1276
0
  struct mach_o_thread_command_external raw;
1277
0
  size_t offset;
1278
1279
0
  BFD_ASSERT ((command->type == BFD_MACH_O_LC_THREAD)
1280
0
        || (command->type == BFD_MACH_O_LC_UNIXTHREAD));
1281
1282
0
  offset = BFD_MACH_O_LC_SIZE;
1283
0
  for (i = 0; i < cmd->nflavours; i++)
1284
0
    {
1285
0
      BFD_ASSERT ((cmd->flavours[i].size % 4) == 0);
1286
0
      BFD_ASSERT (cmd->flavours[i].offset
1287
0
      == command->offset + offset + BFD_MACH_O_LC_SIZE);
1288
1289
0
      bfd_h_put_32 (abfd, cmd->flavours[i].flavour, raw.flavour);
1290
0
      bfd_h_put_32 (abfd, (cmd->flavours[i].size / 4), raw.count);
1291
1292
0
      if (bfd_seek (abfd, command->offset + offset, SEEK_SET) != 0
1293
0
    || bfd_write (&raw, sizeof (raw), abfd) != sizeof (raw))
1294
0
  return false;
1295
1296
0
      offset += cmd->flavours[i].size + sizeof (raw);
1297
0
    }
1298
1299
0
  return true;
1300
0
}
1301
1302
static bool
1303
bfd_mach_o_write_dylinker (bfd *abfd, bfd_mach_o_load_command *command)
1304
15
{
1305
15
  bfd_mach_o_dylinker_command *cmd = &command->command.dylinker;
1306
15
  struct mach_o_str_command_external raw;
1307
15
  size_t namelen;
1308
1309
15
  bfd_h_put_32 (abfd, cmd->name_offset, raw.str);
1310
1311
15
  if (bfd_seek (abfd, command->offset + BFD_MACH_O_LC_SIZE, SEEK_SET) != 0
1312
15
      || bfd_write (&raw, sizeof (raw), abfd) != sizeof (raw))
1313
0
    return false;
1314
1315
15
  namelen = strlen (cmd->name_str) + 1;
1316
15
  if (bfd_write (cmd->name_str, namelen, abfd) != namelen)
1317
0
    return false;
1318
1319
15
  if (bfd_mach_o_pad_command (abfd, namelen) < 0)
1320
0
    return false;
1321
1322
15
  return true;
1323
15
}
1324
1325
static bool
1326
bfd_mach_o_write_dylib (bfd *abfd, bfd_mach_o_load_command *command)
1327
15
{
1328
15
  bfd_mach_o_dylib_command *cmd = &command->command.dylib;
1329
15
  struct mach_o_dylib_command_external raw;
1330
15
  size_t namelen;
1331
1332
15
  bfd_h_put_32 (abfd, cmd->name_offset, raw.name);
1333
15
  bfd_h_put_32 (abfd, cmd->timestamp, raw.timestamp);
1334
15
  bfd_h_put_32 (abfd, cmd->current_version, raw.current_version);
1335
15
  bfd_h_put_32 (abfd, cmd->compatibility_version, raw.compatibility_version);
1336
1337
15
  if (bfd_seek (abfd, command->offset + BFD_MACH_O_LC_SIZE, SEEK_SET) != 0
1338
15
      || bfd_write (&raw, sizeof (raw), abfd) != sizeof (raw))
1339
0
    return false;
1340
1341
15
  namelen = strlen (cmd->name_str) + 1;
1342
15
  if (bfd_write (cmd->name_str, namelen, abfd) != namelen)
1343
0
    return false;
1344
1345
15
  if (bfd_mach_o_pad_command (abfd, namelen) < 0)
1346
0
    return false;
1347
1348
15
  return true;
1349
15
}
1350
1351
static bool
1352
bfd_mach_o_write_main (bfd *abfd, bfd_mach_o_load_command *command)
1353
5
{
1354
5
  bfd_mach_o_main_command *cmd = &command->command.main;
1355
5
  struct mach_o_entry_point_command_external raw;
1356
1357
5
  bfd_h_put_64 (abfd, cmd->entryoff, raw.entryoff);
1358
5
  bfd_h_put_64 (abfd, cmd->stacksize, raw.stacksize);
1359
1360
5
  if (bfd_seek (abfd, command->offset + BFD_MACH_O_LC_SIZE, SEEK_SET) != 0
1361
5
      || bfd_write (&raw, sizeof (raw), abfd) != sizeof (raw))
1362
0
    return false;
1363
1364
5
  return true;
1365
5
}
1366
1367
static bool
1368
bfd_mach_o_write_dyld_info (bfd *abfd, bfd_mach_o_load_command *command)
1369
13
{
1370
13
  bfd_mach_o_dyld_info_command *cmd = &command->command.dyld_info;
1371
13
  struct mach_o_dyld_info_command_external raw;
1372
1373
13
  bfd_h_put_32 (abfd, cmd->rebase_off, raw.rebase_off);
1374
13
  bfd_h_put_32 (abfd, cmd->rebase_size, raw.rebase_size);
1375
13
  bfd_h_put_32 (abfd, cmd->bind_off, raw.bind_off);
1376
13
  bfd_h_put_32 (abfd, cmd->bind_size, raw.bind_size);
1377
13
  bfd_h_put_32 (abfd, cmd->weak_bind_off, raw.weak_bind_off);
1378
13
  bfd_h_put_32 (abfd, cmd->weak_bind_size, raw.weak_bind_size);
1379
13
  bfd_h_put_32 (abfd, cmd->lazy_bind_off, raw.lazy_bind_off);
1380
13
  bfd_h_put_32 (abfd, cmd->lazy_bind_size, raw.lazy_bind_size);
1381
13
  bfd_h_put_32 (abfd, cmd->export_off, raw.export_off);
1382
13
  bfd_h_put_32 (abfd, cmd->export_size, raw.export_size);
1383
1384
13
  if (bfd_seek (abfd, command->offset + BFD_MACH_O_LC_SIZE, SEEK_SET) != 0
1385
13
      || bfd_write (&raw, sizeof (raw), abfd) != sizeof (raw))
1386
0
    return false;
1387
1388
13
  if (cmd->rebase_size != 0)
1389
5
    if (bfd_seek (abfd, cmd->rebase_off, SEEK_SET) != 0
1390
5
  || (bfd_write (cmd->rebase_content, cmd->rebase_size, abfd) !=
1391
5
      cmd->rebase_size))
1392
0
      return false;
1393
1394
13
  if (cmd->bind_size != 0)
1395
4
    if (bfd_seek (abfd, cmd->bind_off, SEEK_SET) != 0
1396
4
  || (bfd_write (cmd->bind_content, cmd->bind_size, abfd) !=
1397
4
      cmd->bind_size))
1398
0
      return false;
1399
1400
13
  if (cmd->weak_bind_size != 0)
1401
0
    if (bfd_seek (abfd, cmd->weak_bind_off, SEEK_SET) != 0
1402
0
  || (bfd_write (cmd->weak_bind_content, cmd->weak_bind_size, abfd) !=
1403
0
      cmd->weak_bind_size))
1404
0
      return false;
1405
1406
13
  if (cmd->lazy_bind_size != 0)
1407
4
    if (bfd_seek (abfd, cmd->lazy_bind_off, SEEK_SET) != 0
1408
4
  || (bfd_write (cmd->lazy_bind_content, cmd->lazy_bind_size, abfd) !=
1409
4
      cmd->lazy_bind_size))
1410
0
      return false;
1411
1412
13
  if (cmd->export_size != 0)
1413
5
    if (bfd_seek (abfd, cmd->export_off, SEEK_SET) != 0
1414
5
  || (bfd_write (cmd->export_content, cmd->export_size, abfd) !=
1415
5
      cmd->export_size))
1416
0
      return false;
1417
1418
13
  return true;
1419
13
}
1420
1421
long
1422
bfd_mach_o_get_reloc_upper_bound (bfd *abfd, asection *asect)
1423
77.8k
{
1424
77.8k
  size_t count, raw;
1425
1426
77.8k
  count = asect->reloc_count;
1427
77.8k
  if (count >= LONG_MAX / sizeof (arelent *)
1428
77.8k
      || _bfd_mul_overflow (count, BFD_MACH_O_RELENT_SIZE, &raw))
1429
0
    {
1430
0
      bfd_set_error (bfd_error_file_too_big);
1431
0
      return -1;
1432
0
    }
1433
77.8k
  if (!bfd_write_p (abfd))
1434
77.8k
    {
1435
77.8k
      ufile_ptr filesize = bfd_get_file_size (abfd);
1436
77.8k
      if (filesize != 0 && raw > filesize)
1437
63.2k
  {
1438
63.2k
    bfd_set_error (bfd_error_file_truncated);
1439
63.2k
    return -1;
1440
63.2k
  }
1441
77.8k
    }
1442
14.5k
  return (count + 1) * sizeof (arelent *);
1443
77.8k
}
1444
1445
/* In addition to the need to byte-swap the symbol number, the bit positions
1446
   of the fields in the relocation information vary per target endian-ness.  */
1447
1448
void
1449
bfd_mach_o_swap_in_non_scattered_reloc (bfd *abfd, bfd_mach_o_reloc_info *rel,
1450
          unsigned char *fields)
1451
11.6k
{
1452
11.6k
  unsigned char info = fields[3];
1453
1454
11.6k
  if (bfd_big_endian (abfd))
1455
0
    {
1456
0
      rel->r_value = (fields[0] << 16) | (fields[1] << 8) | fields[2];
1457
0
      rel->r_type = (info >> BFD_MACH_O_BE_TYPE_SHIFT) & BFD_MACH_O_TYPE_MASK;
1458
0
      rel->r_pcrel = (info & BFD_MACH_O_BE_PCREL) ? 1 : 0;
1459
0
      rel->r_length = (info >> BFD_MACH_O_BE_LENGTH_SHIFT)
1460
0
          & BFD_MACH_O_LENGTH_MASK;
1461
0
      rel->r_extern = (info & BFD_MACH_O_BE_EXTERN) ? 1 : 0;
1462
0
    }
1463
11.6k
  else
1464
11.6k
    {
1465
11.6k
      rel->r_value = (fields[2] << 16) | (fields[1] << 8) | fields[0];
1466
11.6k
      rel->r_type = (info >> BFD_MACH_O_LE_TYPE_SHIFT) & BFD_MACH_O_TYPE_MASK;
1467
11.6k
      rel->r_pcrel = (info & BFD_MACH_O_LE_PCREL) ? 1 : 0;
1468
11.6k
      rel->r_length = (info >> BFD_MACH_O_LE_LENGTH_SHIFT)
1469
11.6k
          & BFD_MACH_O_LENGTH_MASK;
1470
11.6k
      rel->r_extern = (info & BFD_MACH_O_LE_EXTERN) ? 1 : 0;
1471
11.6k
    }
1472
11.6k
}
1473
1474
/* Set syms_ptr_ptr and addend of RES.  */
1475
1476
bool
1477
bfd_mach_o_canonicalize_non_scattered_reloc (bfd *abfd,
1478
               bfd_mach_o_reloc_info *reloc,
1479
               arelent *res, asymbol **syms)
1480
11.5k
{
1481
11.5k
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
1482
11.5k
  unsigned int num;
1483
11.5k
  asymbol **sym;
1484
1485
  /* Non-scattered relocation.  */
1486
11.5k
  reloc->r_scattered = 0;
1487
11.5k
  res->addend = 0;
1488
1489
11.5k
  num = reloc->r_value;
1490
1491
11.5k
  if (reloc->r_extern)
1492
4.16k
    {
1493
      /* PR 17512: file: 8396-1185-0.004.  */
1494
4.16k
      if (num >= (unsigned) bfd_mach_o_count_symbols (abfd))
1495
3.68k
  sym = &bfd_und_section_ptr->symbol;
1496
479
      else if (syms == NULL)
1497
0
  sym = &bfd_und_section_ptr->symbol;
1498
479
      else
1499
  /* An external symbol number.  */
1500
479
  sym = syms + num;
1501
4.16k
    }
1502
7.43k
  else if (num == 0x00ffffff || num == 0)
1503
3.70k
    {
1504
      /* The 'symnum' in a non-scattered PAIR is 0x00ffffff.  But as this
1505
   is generic code, we don't know wether this is really a PAIR.
1506
   This value is almost certainly not a valid section number, hence
1507
   this specific case to avoid an assertion failure.
1508
   Target specific swap_reloc_in routine should adjust that.  */
1509
3.70k
      sym = &bfd_abs_section_ptr->symbol;
1510
3.70k
    }
1511
3.73k
  else
1512
3.73k
    {
1513
      /* PR 17512: file: 006-2964-0.004.  */
1514
3.73k
      if (num > mdata->nsects)
1515
2.56k
  {
1516
2.56k
    _bfd_error_handler (_("\
1517
2.56k
malformed mach-o reloc: section index is greater than the number of sections"));
1518
2.56k
    return false;
1519
2.56k
  }
1520
1521
      /* A section number.  */
1522
1.17k
      sym = &mdata->sections[num - 1]->bfdsection->symbol;
1523
      /* For a symbol defined in section S, the addend (stored in the
1524
   binary) contains the address of the section.  To comply with
1525
   bfd convention, subtract the section address.
1526
   Use the address from the header, so that the user can modify
1527
       the vma of the section.  */
1528
1.17k
      res->addend = -mdata->sections[num - 1]->addr;
1529
1.17k
    }
1530
1531
  /* Note: Pairs for PPC LO/HI/HA are not scattered, but contain the offset
1532
     in the lower 16bits of the address value.  So we have to find the
1533
     'symbol' from the preceding reloc.  We do this even though the
1534
     section symbol is probably not needed here, because NULL symbol
1535
     values cause an assert in generic BFD code.  This must be done in
1536
     the PPC swap_reloc_in routine.  */
1537
9.03k
  res->sym_ptr_ptr = sym;
1538
1539
9.03k
  return true;
1540
11.5k
}
1541
1542
/* Do most of the work for canonicalize_relocs on RAW: create internal
1543
   representation RELOC and set most fields of RES using symbol table SYMS.
1544
   Each target still has to set the howto of RES and possibly adjust other
1545
   fields.
1546
   Previously the Mach-O hook point was simply swap_in, but some targets
1547
   (like arm64) don't follow the generic rules (symnum is a value for the
1548
   non-scattered relocation ADDEND).  */
1549
1550
bool
1551
bfd_mach_o_pre_canonicalize_one_reloc (bfd *abfd,
1552
               struct mach_o_reloc_info_external *raw,
1553
               bfd_mach_o_reloc_info *reloc,
1554
               arelent *res, asymbol **syms)
1555
13.3k
{
1556
13.3k
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
1557
13.3k
  bfd_vma addr;
1558
1559
13.3k
  addr = bfd_get_32 (abfd, raw->r_address);
1560
13.3k
  res->sym_ptr_ptr = &bfd_und_section_ptr->symbol;
1561
13.3k
  res->addend = 0;
1562
1563
13.3k
  if (addr & BFD_MACH_O_SR_SCATTERED)
1564
5.41k
    {
1565
5.41k
      unsigned int j;
1566
5.41k
      bfd_vma symnum = bfd_get_32 (abfd, raw->r_symbolnum);
1567
1568
      /* Scattered relocation, can't be extern. */
1569
5.41k
      reloc->r_scattered = 1;
1570
5.41k
      reloc->r_extern = 0;
1571
1572
      /*   Extract section and offset from r_value (symnum).  */
1573
5.41k
      reloc->r_value = symnum;
1574
      /* FIXME: This breaks when a symbol in a reloc exactly follows the
1575
   end of the data for the section (e.g. in a calculation of section
1576
   data length).  At present, the symbol will end up associated with
1577
   the following section or, if it falls within alignment padding, as
1578
   the undefined section symbol.  */
1579
33.5k
      for (j = 0; j < mdata->nsects; j++)
1580
33.3k
  {
1581
33.3k
    bfd_mach_o_section *sect = mdata->sections[j];
1582
33.3k
    if (symnum >= sect->addr && symnum < sect->addr + sect->size)
1583
5.22k
      {
1584
5.22k
        res->sym_ptr_ptr = &sect->bfdsection->symbol;
1585
5.22k
        res->addend = symnum - sect->addr;
1586
5.22k
        break;
1587
5.22k
      }
1588
33.3k
  }
1589
1590
      /* Extract the info and address fields from r_address.  */
1591
5.41k
      reloc->r_type = BFD_MACH_O_GET_SR_TYPE (addr);
1592
5.41k
      reloc->r_length = BFD_MACH_O_GET_SR_LENGTH (addr);
1593
5.41k
      reloc->r_pcrel = addr & BFD_MACH_O_SR_PCREL;
1594
5.41k
      reloc->r_address = BFD_MACH_O_GET_SR_TYPE (addr);
1595
5.41k
      res->address = BFD_MACH_O_GET_SR_ADDRESS (addr);
1596
5.41k
    }
1597
7.93k
  else
1598
7.93k
    {
1599
      /* Non-scattered relocation.  */
1600
7.93k
      reloc->r_scattered = 0;
1601
7.93k
      reloc->r_address = addr;
1602
7.93k
      res->address = addr;
1603
1604
      /* The value and info fields have to be extracted dependent on target
1605
   endian-ness.  */
1606
7.93k
      bfd_mach_o_swap_in_non_scattered_reloc (abfd, reloc, raw->r_symbolnum);
1607
1608
7.93k
      if (!bfd_mach_o_canonicalize_non_scattered_reloc (abfd, reloc,
1609
7.93k
              res, syms))
1610
1.82k
  return false;
1611
7.93k
    }
1612
1613
  /* We have set up a reloc with all the information present, so the swapper
1614
     can modify address, value and addend fields, if necessary, to convey
1615
     information in the generic BFD reloc that is mach-o specific.  */
1616
1617
11.5k
  return true;
1618
13.3k
}
1619
1620
static int
1621
bfd_mach_o_canonicalize_relocs (bfd *abfd, unsigned long filepos,
1622
        unsigned long count,
1623
        arelent *res, asymbol **syms)
1624
14.4k
{
1625
14.4k
  bfd_mach_o_backend_data *bed = bfd_mach_o_get_backend_data (abfd);
1626
14.4k
  unsigned long i;
1627
14.4k
  struct mach_o_reloc_info_external *native_relocs = NULL;
1628
14.4k
  size_t native_size;
1629
1630
  /* Allocate and read relocs.  */
1631
14.4k
  if (_bfd_mul_overflow (count, BFD_MACH_O_RELENT_SIZE, &native_size))
1632
    /* PR 17512: file: 09477b57.  */
1633
0
    goto err;
1634
1635
14.4k
  if (bfd_seek (abfd, filepos, SEEK_SET) != 0)
1636
0
    return -1;
1637
14.4k
  native_relocs = (struct mach_o_reloc_info_external *)
1638
14.4k
    _bfd_malloc_and_read (abfd, native_size, native_size);
1639
14.4k
  if (native_relocs == NULL)
1640
4.86k
    return -1;
1641
1642
18.1k
  for (i = 0; i < count; i++)
1643
17.4k
    {
1644
17.4k
      if (!(*bed->_bfd_mach_o_canonicalize_one_reloc)(abfd, &native_relocs[i],
1645
17.4k
                  &res[i], syms, res))
1646
8.88k
  goto err;
1647
17.4k
    }
1648
684
  free (native_relocs);
1649
684
  return i;
1650
1651
8.88k
 err:
1652
8.88k
  free (native_relocs);
1653
8.88k
  if (bfd_get_error () == bfd_error_no_error)
1654
407
    bfd_set_error (bfd_error_invalid_operation);
1655
8.88k
  return -1;
1656
9.56k
}
1657
1658
long
1659
bfd_mach_o_canonicalize_reloc (bfd *abfd, asection *asect,
1660
             arelent **rels, asymbol **syms)
1661
14.5k
{
1662
14.5k
  bfd_mach_o_backend_data *bed = bfd_mach_o_get_backend_data (abfd);
1663
14.5k
  unsigned long i;
1664
14.5k
  arelent *res;
1665
1666
14.5k
  if (asect->reloc_count == 0)
1667
71
    return 0;
1668
1669
  /* No need to go further if we don't know how to read relocs.  */
1670
14.5k
  if (bed->_bfd_mach_o_canonicalize_one_reloc == NULL)
1671
84
    return 0;
1672
1673
14.4k
  if (asect->relocation == NULL)
1674
14.4k
    {
1675
14.4k
      size_t amt;
1676
1677
14.4k
      if (_bfd_mul_overflow (asect->reloc_count, sizeof (arelent), &amt))
1678
0
  {
1679
0
    bfd_set_error (bfd_error_file_too_big);
1680
0
    return -1;
1681
0
  }
1682
14.4k
      res = bfd_malloc (amt);
1683
14.4k
      if (res == NULL)
1684
0
  return -1;
1685
1686
14.4k
      if (bfd_mach_o_canonicalize_relocs (abfd, asect->rel_filepos,
1687
14.4k
            asect->reloc_count, res, syms) < 0)
1688
13.7k
  {
1689
13.7k
    free (res);
1690
13.7k
    return -1;
1691
13.7k
  }
1692
684
      asect->relocation = res;
1693
684
    }
1694
1695
684
  res = asect->relocation;
1696
3.77k
  for (i = 0; i < asect->reloc_count; i++)
1697
3.09k
    rels[i] = &res[i];
1698
684
  rels[i] = NULL;
1699
1700
684
  return i;
1701
14.4k
}
1702
1703
long
1704
bfd_mach_o_get_dynamic_reloc_upper_bound (bfd *abfd)
1705
81
{
1706
81
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
1707
81
  bfd_mach_o_dysymtab_command *dysymtab = mdata->dysymtab;
1708
1709
81
  if (dysymtab == NULL)
1710
12
    return 1;
1711
1712
69
  ufile_ptr filesize = bfd_get_file_size (abfd);
1713
69
  size_t amt;
1714
1715
69
  if (filesize != 0)
1716
69
    {
1717
69
      if (dysymtab->extreloff > filesize
1718
69
    || dysymtab->nextrel > ((filesize - dysymtab->extreloff)
1719
69
          / BFD_MACH_O_RELENT_SIZE)
1720
69
    || dysymtab->locreloff > filesize
1721
69
    || dysymtab->nlocrel > ((filesize - dysymtab->locreloff)
1722
69
          / BFD_MACH_O_RELENT_SIZE))
1723
27
  {
1724
27
    bfd_set_error (bfd_error_file_truncated);
1725
27
    return -1;
1726
27
  }
1727
69
    }
1728
42
  if (dysymtab->nextrel + dysymtab->nlocrel < dysymtab->nextrel
1729
42
      || _bfd_mul_overflow (dysymtab->nextrel + dysymtab->nlocrel,
1730
42
          sizeof (arelent), &amt))
1731
0
    {
1732
0
      bfd_set_error (bfd_error_file_too_big);
1733
0
      return -1;
1734
0
    }
1735
1736
42
  return (dysymtab->nextrel + dysymtab->nlocrel + 1) * sizeof (arelent *);
1737
42
}
1738
1739
long
1740
bfd_mach_o_canonicalize_dynamic_reloc (bfd *abfd, arelent **rels,
1741
               struct bfd_symbol **syms)
1742
54
{
1743
54
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
1744
54
  bfd_mach_o_dysymtab_command *dysymtab = mdata->dysymtab;
1745
54
  bfd_mach_o_backend_data *bed = bfd_mach_o_get_backend_data (abfd);
1746
54
  unsigned long i;
1747
54
  arelent *res;
1748
1749
54
  if (dysymtab == NULL)
1750
12
    return 0;
1751
42
  if (dysymtab->nextrel == 0 && dysymtab->nlocrel == 0)
1752
42
    return 0;
1753
1754
  /* No need to go further if we don't know how to read relocs.  */
1755
0
  if (bed->_bfd_mach_o_canonicalize_one_reloc == NULL)
1756
0
    return 0;
1757
1758
0
  if (mdata->dyn_reloc_cache == NULL)
1759
0
    {
1760
0
      size_t amt = (dysymtab->nextrel + dysymtab->nlocrel) * sizeof (arelent);
1761
0
      res = bfd_malloc (amt);
1762
0
      if (res == NULL)
1763
0
  return -1;
1764
1765
0
      if (bfd_mach_o_canonicalize_relocs (abfd, dysymtab->extreloff,
1766
0
            dysymtab->nextrel, res, syms) < 0)
1767
0
  {
1768
0
    free (res);
1769
0
    return -1;
1770
0
  }
1771
1772
0
      if (bfd_mach_o_canonicalize_relocs (abfd, dysymtab->locreloff,
1773
0
            dysymtab->nlocrel,
1774
0
            res + dysymtab->nextrel, syms) < 0)
1775
0
  {
1776
0
    free (res);
1777
0
    return -1;
1778
0
  }
1779
1780
0
      mdata->dyn_reloc_cache = res;
1781
0
    }
1782
1783
0
  res = mdata->dyn_reloc_cache;
1784
0
  for (i = 0; i < dysymtab->nextrel + dysymtab->nlocrel; i++)
1785
0
    rels[i] = &res[i];
1786
0
  rels[i] = NULL;
1787
0
  return i;
1788
0
}
1789
1790
/* In addition to the need to byte-swap the symbol number, the bit positions
1791
   of the fields in the relocation information vary per target endian-ness.  */
1792
1793
static void
1794
bfd_mach_o_swap_out_non_scattered_reloc (bfd *abfd, unsigned char *fields,
1795
           bfd_mach_o_reloc_info *rel)
1796
0
{
1797
0
  unsigned char info = 0;
1798
1799
0
  BFD_ASSERT (rel->r_type <= 15);
1800
0
  BFD_ASSERT (rel->r_length <= 3);
1801
1802
0
  if (bfd_big_endian (abfd))
1803
0
    {
1804
0
      fields[0] = (rel->r_value >> 16) & 0xff;
1805
0
      fields[1] = (rel->r_value >> 8) & 0xff;
1806
0
      fields[2] = rel->r_value & 0xff;
1807
0
      info |= rel->r_type << BFD_MACH_O_BE_TYPE_SHIFT;
1808
0
      info |= rel->r_pcrel ? BFD_MACH_O_BE_PCREL : 0;
1809
0
      info |= rel->r_length << BFD_MACH_O_BE_LENGTH_SHIFT;
1810
0
      info |= rel->r_extern ? BFD_MACH_O_BE_EXTERN : 0;
1811
0
    }
1812
0
  else
1813
0
    {
1814
0
      fields[2] = (rel->r_value >> 16) & 0xff;
1815
0
      fields[1] = (rel->r_value >> 8) & 0xff;
1816
0
      fields[0] = rel->r_value & 0xff;
1817
0
      info |= rel->r_type << BFD_MACH_O_LE_TYPE_SHIFT;
1818
0
      info |= rel->r_pcrel ? BFD_MACH_O_LE_PCREL : 0;
1819
0
      info |= rel->r_length << BFD_MACH_O_LE_LENGTH_SHIFT;
1820
0
      info |= rel->r_extern ? BFD_MACH_O_LE_EXTERN : 0;
1821
0
    }
1822
0
  fields[3] = info;
1823
0
}
1824
1825
static bool
1826
bfd_mach_o_write_relocs (bfd *abfd, bfd_mach_o_section *section)
1827
52
{
1828
52
  unsigned int i;
1829
52
  arelent **entries;
1830
52
  asection *sec;
1831
52
  bfd_mach_o_backend_data *bed = bfd_mach_o_get_backend_data (abfd);
1832
1833
52
  sec = section->bfdsection;
1834
52
  if (sec->reloc_count == 0)
1835
52
    return true;
1836
1837
0
  if (bed->_bfd_mach_o_swap_reloc_out == NULL)
1838
0
    return true;
1839
1840
0
  if (bfd_seek (abfd, section->reloff, SEEK_SET) != 0)
1841
0
    return false;
1842
1843
  /* Convert and write.  */
1844
0
  entries = section->bfdsection->orelocation;
1845
0
  for (i = 0; i < section->nreloc; i++)
1846
0
    {
1847
0
      arelent *rel = entries[i];
1848
0
      struct mach_o_reloc_info_external raw;
1849
0
      bfd_mach_o_reloc_info info, *pinfo = &info;
1850
1851
      /* Convert relocation to an intermediate representation.  */
1852
0
      if (!(*bed->_bfd_mach_o_swap_reloc_out) (rel, pinfo))
1853
0
  return false;
1854
1855
      /* Lower the relocation info.  */
1856
0
      if (pinfo->r_scattered)
1857
0
  {
1858
0
    unsigned long v;
1859
1860
0
    v = BFD_MACH_O_SR_SCATTERED
1861
0
      | (pinfo->r_pcrel ? BFD_MACH_O_SR_PCREL : 0)
1862
0
      | BFD_MACH_O_SET_SR_LENGTH (pinfo->r_length)
1863
0
      | BFD_MACH_O_SET_SR_TYPE (pinfo->r_type)
1864
0
      | BFD_MACH_O_SET_SR_ADDRESS (pinfo->r_address);
1865
    /* Note: scattered relocs have field in reverse order...  */
1866
0
    bfd_put_32 (abfd, v, raw.r_address);
1867
0
    bfd_put_32 (abfd, pinfo->r_value, raw.r_symbolnum);
1868
0
  }
1869
0
      else
1870
0
  {
1871
0
    bfd_put_32 (abfd, pinfo->r_address, raw.r_address);
1872
0
    bfd_mach_o_swap_out_non_scattered_reloc (abfd, raw.r_symbolnum,
1873
0
               pinfo);
1874
0
  }
1875
1876
0
      if (bfd_write (&raw, BFD_MACH_O_RELENT_SIZE, abfd)
1877
0
    != BFD_MACH_O_RELENT_SIZE)
1878
0
  return false;
1879
0
    }
1880
0
  return true;
1881
0
}
1882
1883
static bool
1884
bfd_mach_o_write_section_32 (bfd *abfd, bfd_mach_o_section *section)
1885
5
{
1886
5
  struct mach_o_section_32_external raw;
1887
1888
5
  memcpy (raw.sectname, section->sectname, 16);
1889
5
  memcpy (raw.segname, section->segname, 16);
1890
5
  bfd_h_put_32 (abfd, section->addr, raw.addr);
1891
5
  bfd_h_put_32 (abfd, section->size, raw.size);
1892
5
  bfd_h_put_32 (abfd, section->offset, raw.offset);
1893
5
  bfd_h_put_32 (abfd, section->align, raw.align);
1894
5
  bfd_h_put_32 (abfd, section->reloff, raw.reloff);
1895
5
  bfd_h_put_32 (abfd, section->nreloc, raw.nreloc);
1896
5
  bfd_h_put_32 (abfd, section->flags, raw.flags);
1897
5
  bfd_h_put_32 (abfd, section->reserved1, raw.reserved1);
1898
5
  bfd_h_put_32 (abfd, section->reserved2, raw.reserved2);
1899
1900
5
  if (bfd_write (&raw, BFD_MACH_O_SECTION_SIZE, abfd)
1901
5
      != BFD_MACH_O_SECTION_SIZE)
1902
0
    return false;
1903
1904
5
  return true;
1905
5
}
1906
1907
static bool
1908
bfd_mach_o_write_section_64 (bfd *abfd, bfd_mach_o_section *section)
1909
47
{
1910
47
  struct mach_o_section_64_external raw;
1911
1912
47
  memcpy (raw.sectname, section->sectname, 16);
1913
47
  memcpy (raw.segname, section->segname, 16);
1914
47
  bfd_h_put_64 (abfd, section->addr, raw.addr);
1915
47
  bfd_h_put_64 (abfd, section->size, raw.size);
1916
47
  bfd_h_put_32 (abfd, section->offset, raw.offset);
1917
47
  bfd_h_put_32 (abfd, section->align, raw.align);
1918
47
  bfd_h_put_32 (abfd, section->reloff, raw.reloff);
1919
47
  bfd_h_put_32 (abfd, section->nreloc, raw.nreloc);
1920
47
  bfd_h_put_32 (abfd, section->flags, raw.flags);
1921
47
  bfd_h_put_32 (abfd, section->reserved1, raw.reserved1);
1922
47
  bfd_h_put_32 (abfd, section->reserved2, raw.reserved2);
1923
47
  bfd_h_put_32 (abfd, section->reserved3, raw.reserved3);
1924
1925
47
  if (bfd_write (&raw, BFD_MACH_O_SECTION_64_SIZE, abfd)
1926
47
      != BFD_MACH_O_SECTION_64_SIZE)
1927
0
    return false;
1928
1929
47
  return true;
1930
47
}
1931
1932
static bool
1933
bfd_mach_o_write_segment_32 (bfd *abfd, bfd_mach_o_load_command *command)
1934
13
{
1935
13
  struct mach_o_segment_command_32_external raw;
1936
13
  bfd_mach_o_segment_command *seg = &command->command.segment;
1937
13
  bfd_mach_o_section *sec;
1938
1939
13
  BFD_ASSERT (command->type == BFD_MACH_O_LC_SEGMENT);
1940
1941
18
  for (sec = seg->sect_head; sec != NULL; sec = sec->next)
1942
5
    if (!bfd_mach_o_write_relocs (abfd, sec))
1943
0
      return false;
1944
1945
13
  memcpy (raw.segname, seg->segname, 16);
1946
13
  bfd_h_put_32 (abfd, seg->vmaddr, raw.vmaddr);
1947
13
  bfd_h_put_32 (abfd, seg->vmsize, raw.vmsize);
1948
13
  bfd_h_put_32 (abfd, seg->fileoff, raw.fileoff);
1949
13
  bfd_h_put_32 (abfd, seg->filesize, raw.filesize);
1950
13
  bfd_h_put_32 (abfd, seg->maxprot, raw.maxprot);
1951
13
  bfd_h_put_32 (abfd, seg->initprot, raw.initprot);
1952
13
  bfd_h_put_32 (abfd, seg->nsects, raw.nsects);
1953
13
  bfd_h_put_32 (abfd, seg->flags, raw.flags);
1954
1955
13
  if (bfd_seek (abfd, command->offset + BFD_MACH_O_LC_SIZE, SEEK_SET) != 0
1956
13
      || bfd_write (&raw, sizeof (raw), abfd) != sizeof (raw))
1957
0
    return false;
1958
1959
18
  for (sec = seg->sect_head; sec != NULL; sec = sec->next)
1960
5
    if (!bfd_mach_o_write_section_32 (abfd, sec))
1961
0
      return false;
1962
1963
13
  return true;
1964
13
}
1965
1966
static bool
1967
bfd_mach_o_write_segment_64 (bfd *abfd, bfd_mach_o_load_command *command)
1968
79
{
1969
79
  struct mach_o_segment_command_64_external raw;
1970
79
  bfd_mach_o_segment_command *seg = &command->command.segment;
1971
79
  bfd_mach_o_section *sec;
1972
1973
79
  BFD_ASSERT (command->type == BFD_MACH_O_LC_SEGMENT_64);
1974
1975
126
  for (sec = seg->sect_head; sec != NULL; sec = sec->next)
1976
47
    if (!bfd_mach_o_write_relocs (abfd, sec))
1977
0
      return false;
1978
1979
79
  memcpy (raw.segname, seg->segname, 16);
1980
79
  bfd_h_put_64 (abfd, seg->vmaddr, raw.vmaddr);
1981
79
  bfd_h_put_64 (abfd, seg->vmsize, raw.vmsize);
1982
79
  bfd_h_put_64 (abfd, seg->fileoff, raw.fileoff);
1983
79
  bfd_h_put_64 (abfd, seg->filesize, raw.filesize);
1984
79
  bfd_h_put_32 (abfd, seg->maxprot, raw.maxprot);
1985
79
  bfd_h_put_32 (abfd, seg->initprot, raw.initprot);
1986
79
  bfd_h_put_32 (abfd, seg->nsects, raw.nsects);
1987
79
  bfd_h_put_32 (abfd, seg->flags, raw.flags);
1988
1989
79
  if (bfd_seek (abfd, command->offset + BFD_MACH_O_LC_SIZE, SEEK_SET) != 0
1990
79
      || bfd_write (&raw, sizeof (raw), abfd) != sizeof (raw))
1991
0
    return false;
1992
1993
126
  for (sec = seg->sect_head; sec != NULL; sec = sec->next)
1994
47
    if (!bfd_mach_o_write_section_64 (abfd, sec))
1995
0
      return false;
1996
1997
79
  return true;
1998
79
}
1999
2000
static bool
2001
bfd_mach_o_write_symtab_content (bfd *abfd, bfd_mach_o_symtab_command *sym)
2002
15
{
2003
15
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
2004
15
  unsigned long i;
2005
15
  unsigned int wide = bfd_mach_o_wide_p (abfd);
2006
15
  struct bfd_strtab_hash *strtab;
2007
15
  asymbol **symbols = bfd_get_outsymbols (abfd);
2008
15
  int padlen;
2009
2010
  /* Write the symbols first.  */
2011
15
  if (bfd_seek (abfd, sym->symoff, SEEK_SET) != 0)
2012
0
    return false;
2013
2014
15
  strtab = _bfd_stringtab_init ();
2015
15
  if (strtab == NULL)
2016
0
    return false;
2017
2018
15
  if (sym->nsyms > 0)
2019
    /* Although we don't strictly need to do this, for compatibility with
2020
       Darwin system tools, actually output an empty string for the index
2021
       0 entry.  */
2022
15
    _bfd_stringtab_add (strtab, "", true, false);
2023
2024
194
  for (i = 0; i < sym->nsyms; i++)
2025
179
    {
2026
179
      bfd_size_type str_index;
2027
179
      bfd_mach_o_asymbol *s = (bfd_mach_o_asymbol *)symbols[i];
2028
2029
179
      if (s->symbol.name == 0 || s->symbol.name[0] == '\0')
2030
  /* An index of 0 always means the empty string.  */
2031
163
  str_index = 0;
2032
16
      else
2033
16
  {
2034
16
    str_index = _bfd_stringtab_add (strtab, s->symbol.name, true, false);
2035
2036
16
    if (str_index == (bfd_size_type) -1)
2037
0
      goto err;
2038
16
  }
2039
2040
179
      if (wide)
2041
131
  {
2042
131
    struct mach_o_nlist_64_external raw;
2043
2044
131
    bfd_h_put_32 (abfd, str_index, raw.n_strx);
2045
131
    bfd_h_put_8 (abfd, s->n_type, raw.n_type);
2046
131
    bfd_h_put_8 (abfd, s->n_sect, raw.n_sect);
2047
131
    bfd_h_put_16 (abfd, s->n_desc, raw.n_desc);
2048
131
    bfd_h_put_64 (abfd, s->symbol.section->vma + s->symbol.value,
2049
131
      raw.n_value);
2050
2051
131
    if (bfd_write (&raw, sizeof (raw), abfd) != sizeof (raw))
2052
0
      goto err;
2053
131
  }
2054
48
      else
2055
48
  {
2056
48
    struct mach_o_nlist_external raw;
2057
2058
48
    bfd_h_put_32 (abfd, str_index, raw.n_strx);
2059
48
    bfd_h_put_8 (abfd, s->n_type, raw.n_type);
2060
48
    bfd_h_put_8 (abfd, s->n_sect, raw.n_sect);
2061
48
    bfd_h_put_16 (abfd, s->n_desc, raw.n_desc);
2062
48
    bfd_h_put_32 (abfd, s->symbol.section->vma + s->symbol.value,
2063
48
      raw.n_value);
2064
2065
48
    if (bfd_write (&raw, sizeof (raw), abfd) != sizeof (raw))
2066
0
      goto err;
2067
48
  }
2068
179
    }
2069
15
  sym->strsize = _bfd_stringtab_size (strtab);
2070
15
  sym->stroff = mdata->filelen;
2071
15
  mdata->filelen += sym->strsize;
2072
2073
15
  if (bfd_seek (abfd, sym->stroff, SEEK_SET) != 0)
2074
0
    goto err;
2075
2076
15
  if (!_bfd_stringtab_emit (abfd, strtab))
2077
0
    goto err;
2078
2079
15
  _bfd_stringtab_free (strtab);
2080
2081
  /* Pad string table.  */
2082
15
  padlen = bfd_mach_o_pad4 (abfd, sym->strsize);
2083
15
  if (padlen < 0)
2084
0
    return false;
2085
15
  mdata->filelen += padlen;
2086
15
  sym->strsize += padlen;
2087
2088
15
  return true;
2089
2090
0
 err:
2091
0
  _bfd_stringtab_free (strtab);
2092
0
  sym->strsize = 0;
2093
0
  return false;
2094
15
}
2095
2096
static bool
2097
bfd_mach_o_write_symtab (bfd *abfd, bfd_mach_o_load_command *command)
2098
15
{
2099
15
  bfd_mach_o_symtab_command *sym = &command->command.symtab;
2100
15
  struct mach_o_symtab_command_external raw;
2101
2102
15
  BFD_ASSERT (command->type == BFD_MACH_O_LC_SYMTAB);
2103
2104
  /* The command.  */
2105
15
  bfd_h_put_32 (abfd, sym->symoff, raw.symoff);
2106
15
  bfd_h_put_32 (abfd, sym->nsyms, raw.nsyms);
2107
15
  bfd_h_put_32 (abfd, sym->stroff, raw.stroff);
2108
15
  bfd_h_put_32 (abfd, sym->strsize, raw.strsize);
2109
2110
15
  if (bfd_seek (abfd, command->offset + BFD_MACH_O_LC_SIZE, SEEK_SET) != 0
2111
15
      || bfd_write (&raw, sizeof (raw), abfd) != sizeof (raw))
2112
0
    return false;
2113
2114
15
  return true;
2115
15
}
2116
2117
/* Count the number of indirect symbols in the image.
2118
   Requires that the sections are in their final order.  */
2119
2120
static unsigned int
2121
bfd_mach_o_count_indirect_symbols (bfd *abfd, bfd_mach_o_data_struct *mdata)
2122
15
{
2123
15
  unsigned int i;
2124
15
  unsigned int nisyms = 0;
2125
2126
55
  for (i = 0; i < mdata->nsects; ++i)
2127
40
    {
2128
40
      bfd_mach_o_section *sec = mdata->sections[i];
2129
2130
40
      switch (sec->flags & BFD_MACH_O_SECTION_TYPE_MASK)
2131
40
  {
2132
4
    case BFD_MACH_O_S_NON_LAZY_SYMBOL_POINTERS:
2133
9
    case BFD_MACH_O_S_LAZY_SYMBOL_POINTERS:
2134
13
    case BFD_MACH_O_S_SYMBOL_STUBS:
2135
13
      nisyms += bfd_mach_o_section_get_nbr_indirect (abfd, sec);
2136
13
      break;
2137
27
    default:
2138
27
      break;
2139
40
  }
2140
40
    }
2141
15
  return nisyms;
2142
15
}
2143
2144
/* Create the dysymtab.  */
2145
2146
static bool
2147
bfd_mach_o_build_dysymtab (bfd *abfd, bfd_mach_o_dysymtab_command *cmd)
2148
15
{
2149
15
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
2150
2151
  /* TODO:
2152
     We are not going to try and fill these in yet and, moreover, we are
2153
     going to bail if they are already set.  */
2154
15
  if (cmd->nmodtab != 0
2155
15
      || cmd->ntoc != 0
2156
15
      || cmd->nextrefsyms != 0)
2157
0
    {
2158
0
      _bfd_error_handler (_("sorry: modtab, toc and extrefsyms are not yet"
2159
0
          " implemented for dysymtab commands."));
2160
0
      return false;
2161
0
    }
2162
2163
15
  cmd->ilocalsym = 0;
2164
2165
15
  if (bfd_get_symcount (abfd) > 0)
2166
15
    {
2167
15
      asymbol **symbols = bfd_get_outsymbols (abfd);
2168
15
      unsigned long i;
2169
2170
       /* Count the number of each kind of symbol.  */
2171
88
      for (i = 0; i < bfd_get_symcount (abfd); ++i)
2172
85
  {
2173
85
    bfd_mach_o_asymbol *s = (bfd_mach_o_asymbol *)symbols[i];
2174
85
    if (s->n_type & (BFD_MACH_O_N_EXT | BFD_MACH_O_N_PEXT))
2175
12
      break;
2176
85
  }
2177
15
      cmd->nlocalsym = i;
2178
15
      cmd->iextdefsym = i;
2179
77
      for (; i < bfd_get_symcount (abfd); ++i)
2180
70
  {
2181
70
    bfd_mach_o_asymbol *s = (bfd_mach_o_asymbol *)symbols[i];
2182
70
    if ((s->n_type & BFD_MACH_O_N_TYPE) == BFD_MACH_O_N_UNDF)
2183
8
      break;
2184
70
  }
2185
15
      cmd->nextdefsym = i - cmd->nlocalsym;
2186
15
      cmd->iundefsym = cmd->nextdefsym + cmd->iextdefsym;
2187
15
      cmd->nundefsym = bfd_get_symcount (abfd)
2188
15
      - cmd->nlocalsym
2189
15
      - cmd->nextdefsym;
2190
15
    }
2191
0
  else
2192
0
    {
2193
0
      cmd->nlocalsym = 0;
2194
0
      cmd->iextdefsym = 0;
2195
0
      cmd->nextdefsym = 0;
2196
0
      cmd->iundefsym = 0;
2197
0
      cmd->nundefsym = 0;
2198
0
    }
2199
2200
15
  cmd->nindirectsyms = bfd_mach_o_count_indirect_symbols (abfd, mdata);
2201
15
  if (cmd->nindirectsyms > 0)
2202
0
    {
2203
0
      unsigned i;
2204
0
      unsigned n;
2205
0
      size_t amt;
2206
2207
0
      mdata->filelen = FILE_ALIGN (mdata->filelen, 2);
2208
0
      cmd->indirectsymoff = mdata->filelen;
2209
0
      if (_bfd_mul_overflow (cmd->nindirectsyms, 4, &amt))
2210
0
  return false;
2211
0
      mdata->filelen += amt;
2212
2213
0
      cmd->indirect_syms = bfd_zalloc (abfd, amt);
2214
0
      if (cmd->indirect_syms == NULL)
2215
0
  return false;
2216
2217
0
      n = 0;
2218
0
      for (i = 0; i < mdata->nsects; ++i)
2219
0
  {
2220
0
    bfd_mach_o_section *sec = mdata->sections[i];
2221
2222
0
    switch (sec->flags & BFD_MACH_O_SECTION_TYPE_MASK)
2223
0
      {
2224
0
        case BFD_MACH_O_S_NON_LAZY_SYMBOL_POINTERS:
2225
0
        case BFD_MACH_O_S_LAZY_SYMBOL_POINTERS:
2226
0
        case BFD_MACH_O_S_SYMBOL_STUBS:
2227
0
    {
2228
0
      unsigned j, num;
2229
0
      bfd_mach_o_asymbol **isyms = sec->indirect_syms;
2230
2231
0
      num = bfd_mach_o_section_get_nbr_indirect (abfd, sec);
2232
0
      if (isyms == NULL || num == 0)
2233
0
        break;
2234
      /* Record the starting index in the reserved1 field.  */
2235
0
      sec->reserved1 = n;
2236
0
      for (j = 0; j < num; j++, n++)
2237
0
        {
2238
0
          if (isyms[j] == NULL)
2239
0
      cmd->indirect_syms[n] = BFD_MACH_O_INDIRECT_SYM_LOCAL;
2240
0
          else if (isyms[j]->symbol.section == bfd_abs_section_ptr
2241
0
             && ! (isyms[j]->n_type & BFD_MACH_O_N_EXT))
2242
0
      cmd->indirect_syms[n] = BFD_MACH_O_INDIRECT_SYM_LOCAL
2243
0
             | BFD_MACH_O_INDIRECT_SYM_ABS;
2244
0
          else
2245
0
      cmd->indirect_syms[n] = isyms[j]->symbol.udata.i;
2246
0
        }
2247
0
    }
2248
0
    break;
2249
0
        default:
2250
0
    break;
2251
0
      }
2252
0
  }
2253
0
    }
2254
2255
15
  return true;
2256
15
}
2257
2258
/* Write a dysymtab command.
2259
   TODO: Possibly coalesce writes of smaller objects.  */
2260
2261
static bool
2262
bfd_mach_o_write_dysymtab (bfd *abfd, bfd_mach_o_load_command *command)
2263
15
{
2264
15
  bfd_mach_o_dysymtab_command *cmd = &command->command.dysymtab;
2265
2266
15
  BFD_ASSERT (command->type == BFD_MACH_O_LC_DYSYMTAB);
2267
2268
15
  if (cmd->nmodtab != 0)
2269
0
    {
2270
0
      unsigned int i;
2271
2272
0
      if (bfd_seek (abfd, cmd->modtaboff, SEEK_SET) != 0)
2273
0
  return false;
2274
2275
0
      for (i = 0; i < cmd->nmodtab; i++)
2276
0
  {
2277
0
    bfd_mach_o_dylib_module *module = &cmd->dylib_module[i];
2278
0
    unsigned int iinit;
2279
0
    unsigned int ninit;
2280
2281
0
    iinit = module->iinit & 0xffff;
2282
0
    iinit |= ((module->iterm & 0xffff) << 16);
2283
2284
0
    ninit = module->ninit & 0xffff;
2285
0
    ninit |= ((module->nterm & 0xffff) << 16);
2286
2287
0
    if (bfd_mach_o_wide_p (abfd))
2288
0
      {
2289
0
        struct mach_o_dylib_module_64_external w;
2290
2291
0
        bfd_h_put_32 (abfd, module->module_name_idx, &w.module_name);
2292
0
        bfd_h_put_32 (abfd, module->iextdefsym, &w.iextdefsym);
2293
0
        bfd_h_put_32 (abfd, module->nextdefsym, &w.nextdefsym);
2294
0
        bfd_h_put_32 (abfd, module->irefsym, &w.irefsym);
2295
0
        bfd_h_put_32 (abfd, module->nrefsym, &w.nrefsym);
2296
0
        bfd_h_put_32 (abfd, module->ilocalsym, &w.ilocalsym);
2297
0
        bfd_h_put_32 (abfd, module->nlocalsym, &w.nlocalsym);
2298
0
        bfd_h_put_32 (abfd, module->iextrel, &w.iextrel);
2299
0
        bfd_h_put_32 (abfd, module->nextrel, &w.nextrel);
2300
0
        bfd_h_put_32 (abfd, iinit, &w.iinit_iterm);
2301
0
        bfd_h_put_32 (abfd, ninit, &w.ninit_nterm);
2302
0
        bfd_h_put_64 (abfd, module->objc_module_info_addr,
2303
0
          &w.objc_module_info_addr);
2304
0
        bfd_h_put_32 (abfd, module->objc_module_info_size,
2305
0
          &w.objc_module_info_size);
2306
2307
0
        if (bfd_write (&w, sizeof (w), abfd) != sizeof (w))
2308
0
    return false;
2309
0
      }
2310
0
    else
2311
0
      {
2312
0
        struct mach_o_dylib_module_external n;
2313
2314
0
        bfd_h_put_32 (abfd, module->module_name_idx, &n.module_name);
2315
0
        bfd_h_put_32 (abfd, module->iextdefsym, &n.iextdefsym);
2316
0
        bfd_h_put_32 (abfd, module->nextdefsym, &n.nextdefsym);
2317
0
        bfd_h_put_32 (abfd, module->irefsym, &n.irefsym);
2318
0
        bfd_h_put_32 (abfd, module->nrefsym, &n.nrefsym);
2319
0
        bfd_h_put_32 (abfd, module->ilocalsym, &n.ilocalsym);
2320
0
        bfd_h_put_32 (abfd, module->nlocalsym, &n.nlocalsym);
2321
0
        bfd_h_put_32 (abfd, module->iextrel, &n.iextrel);
2322
0
        bfd_h_put_32 (abfd, module->nextrel, &n.nextrel);
2323
0
        bfd_h_put_32 (abfd, iinit, &n.iinit_iterm);
2324
0
        bfd_h_put_32 (abfd, ninit, &n.ninit_nterm);
2325
0
        bfd_h_put_32 (abfd, module->objc_module_info_addr,
2326
0
          &n.objc_module_info_addr);
2327
0
        bfd_h_put_32 (abfd, module->objc_module_info_size,
2328
0
          &n.objc_module_info_size);
2329
2330
0
        if (bfd_write (&n, sizeof (n), abfd) != sizeof (n))
2331
0
    return false;
2332
0
      }
2333
0
  }
2334
0
    }
2335
2336
15
  if (cmd->ntoc != 0)
2337
0
    {
2338
0
      unsigned int i;
2339
2340
0
      if (bfd_seek (abfd, cmd->tocoff, SEEK_SET) != 0)
2341
0
  return false;
2342
2343
0
      for (i = 0; i < cmd->ntoc; i++)
2344
0
  {
2345
0
    struct mach_o_dylib_table_of_contents_external raw;
2346
0
    bfd_mach_o_dylib_table_of_content *toc = &cmd->dylib_toc[i];
2347
2348
0
    bfd_h_put_32 (abfd, toc->symbol_index, &raw.symbol_index);
2349
0
    bfd_h_put_32 (abfd, toc->module_index, &raw.module_index);
2350
2351
0
    if (bfd_write (&raw, sizeof (raw), abfd) != sizeof (raw))
2352
0
      return false;
2353
0
  }
2354
0
    }
2355
2356
15
  if (cmd->nindirectsyms > 0)
2357
0
    {
2358
0
      unsigned int i;
2359
2360
0
      if (bfd_seek (abfd, cmd->indirectsymoff, SEEK_SET) != 0)
2361
0
  return false;
2362
2363
0
      for (i = 0; i < cmd->nindirectsyms; ++i)
2364
0
  {
2365
0
    unsigned char raw[4];
2366
2367
0
    bfd_h_put_32 (abfd, cmd->indirect_syms[i], &raw);
2368
0
    if (bfd_write (raw, sizeof (raw), abfd) != sizeof (raw))
2369
0
      return false;
2370
0
  }
2371
0
    }
2372
2373
15
  if (cmd->nextrefsyms != 0)
2374
0
    {
2375
0
      unsigned int i;
2376
2377
0
      if (bfd_seek (abfd, cmd->extrefsymoff, SEEK_SET) != 0)
2378
0
  return false;
2379
2380
0
      for (i = 0; i < cmd->nextrefsyms; i++)
2381
0
  {
2382
0
    unsigned long v;
2383
0
    unsigned char raw[4];
2384
0
    bfd_mach_o_dylib_reference *ref = &cmd->ext_refs[i];
2385
2386
    /* Fields isym and flags are written as bit-fields, thus we need
2387
       a specific processing for endianness.  */
2388
2389
0
    if (bfd_big_endian (abfd))
2390
0
      {
2391
0
        v = ((ref->isym & 0xffffff) << 8);
2392
0
        v |= ref->flags & 0xff;
2393
0
      }
2394
0
    else
2395
0
      {
2396
0
        v = ref->isym  & 0xffffff;
2397
0
        v |= ((ref->flags & 0xff) << 24);
2398
0
      }
2399
2400
0
    bfd_h_put_32 (abfd, v, raw);
2401
0
    if (bfd_write (raw, sizeof (raw), abfd) != sizeof (raw))
2402
0
      return false;
2403
0
  }
2404
0
    }
2405
2406
  /* The command.  */
2407
15
  if (bfd_seek (abfd, command->offset + BFD_MACH_O_LC_SIZE, SEEK_SET) != 0)
2408
0
    return false;
2409
15
  else
2410
15
    {
2411
15
      struct mach_o_dysymtab_command_external raw;
2412
2413
15
      bfd_h_put_32 (abfd, cmd->ilocalsym, &raw.ilocalsym);
2414
15
      bfd_h_put_32 (abfd, cmd->nlocalsym, &raw.nlocalsym);
2415
15
      bfd_h_put_32 (abfd, cmd->iextdefsym, &raw.iextdefsym);
2416
15
      bfd_h_put_32 (abfd, cmd->nextdefsym, &raw.nextdefsym);
2417
15
      bfd_h_put_32 (abfd, cmd->iundefsym, &raw.iundefsym);
2418
15
      bfd_h_put_32 (abfd, cmd->nundefsym, &raw.nundefsym);
2419
15
      bfd_h_put_32 (abfd, cmd->tocoff, &raw.tocoff);
2420
15
      bfd_h_put_32 (abfd, cmd->ntoc, &raw.ntoc);
2421
15
      bfd_h_put_32 (abfd, cmd->modtaboff, &raw.modtaboff);
2422
15
      bfd_h_put_32 (abfd, cmd->nmodtab, &raw.nmodtab);
2423
15
      bfd_h_put_32 (abfd, cmd->extrefsymoff, &raw.extrefsymoff);
2424
15
      bfd_h_put_32 (abfd, cmd->nextrefsyms, &raw.nextrefsyms);
2425
15
      bfd_h_put_32 (abfd, cmd->indirectsymoff, &raw.indirectsymoff);
2426
15
      bfd_h_put_32 (abfd, cmd->nindirectsyms, &raw.nindirectsyms);
2427
15
      bfd_h_put_32 (abfd, cmd->extreloff, &raw.extreloff);
2428
15
      bfd_h_put_32 (abfd, cmd->nextrel, &raw.nextrel);
2429
15
      bfd_h_put_32 (abfd, cmd->locreloff, &raw.locreloff);
2430
15
      bfd_h_put_32 (abfd, cmd->nlocrel, &raw.nlocrel);
2431
2432
15
      if (bfd_write (&raw, sizeof (raw), abfd) != sizeof (raw))
2433
0
  return false;
2434
15
    }
2435
2436
15
  return true;
2437
15
}
2438
2439
static unsigned
2440
bfd_mach_o_primary_symbol_sort_key (bfd_mach_o_asymbol *s)
2441
746
{
2442
746
  unsigned mtyp = s->n_type & BFD_MACH_O_N_TYPE;
2443
2444
  /* Just leave debug symbols where they are (pretend they are local, and
2445
     then they will just be sorted on position).  */
2446
746
  if (s->n_type & BFD_MACH_O_N_STAB)
2447
137
    return 0;
2448
2449
  /* Local (we should never see an undefined local AFAICT).  */
2450
609
  if (! (s->n_type & (BFD_MACH_O_N_EXT | BFD_MACH_O_N_PEXT)))
2451
385
    return 0;
2452
2453
  /* Common symbols look like undefined externs.  */
2454
224
  if (mtyp == BFD_MACH_O_N_UNDF)
2455
9
    return 2;
2456
2457
  /* A defined non-local, non-debug symbol.  */
2458
215
  return 1;
2459
224
}
2460
2461
static int
2462
bfd_mach_o_cf_symbols (const void *a, const void *b)
2463
373
{
2464
373
  bfd_mach_o_asymbol *sa = *(bfd_mach_o_asymbol **) a;
2465
373
  bfd_mach_o_asymbol *sb = *(bfd_mach_o_asymbol **) b;
2466
373
  unsigned int soa, sob;
2467
2468
373
  soa = bfd_mach_o_primary_symbol_sort_key (sa);
2469
373
  sob = bfd_mach_o_primary_symbol_sort_key (sb);
2470
373
  if (soa < sob)
2471
28
    return -1;
2472
2473
345
  if (soa > sob)
2474
44
    return 1;
2475
2476
  /* If it's local or stab, just preserve the input order.  */
2477
301
  if (soa == 0)
2478
227
    {
2479
227
      if (sa->symbol.udata.i < sb->symbol.udata.i)
2480
227
  return -1;
2481
0
      if (sa->symbol.udata.i > sb->symbol.udata.i)
2482
0
  return  1;
2483
2484
      /* This is probably an error.  */
2485
0
      return 0;
2486
0
    }
2487
2488
  /* The second sort key is name.  */
2489
74
  return strcmp (sa->symbol.name, sb->symbol.name);
2490
301
}
2491
2492
/* Process the symbols.
2493
2494
   This should be OK for single-module files - but it is not likely to work
2495
   for multi-module shared libraries.
2496
2497
   (a) If the application has not filled in the relevant mach-o fields, make
2498
       an estimate.
2499
2500
   (b) Order them, like this:
2501
  (  i) local.
2502
    (unsorted)
2503
  ( ii) external defined
2504
    (by name)
2505
  (iii) external undefined/common
2506
    (by name)
2507
  ( iv) common
2508
    (by name)
2509
*/
2510
2511
static bool
2512
bfd_mach_o_mangle_symbols (bfd *abfd)
2513
38
{
2514
38
  unsigned long i;
2515
38
  asymbol **symbols = bfd_get_outsymbols (abfd);
2516
2517
38
  if (symbols == NULL || bfd_get_symcount (abfd) == 0)
2518
22
    return true;
2519
2520
199
  for (i = 0; i < bfd_get_symcount (abfd); i++)
2521
183
    {
2522
183
      bfd_mach_o_asymbol *s = (bfd_mach_o_asymbol *)symbols[i];
2523
2524
      /* We use this value, which is out-of-range as a symbol index, to signal
2525
   that the mach-o-specific data are not filled in and need to be created
2526
   from the bfd values.  It is much preferable for the application to do
2527
   this, since more meaningful diagnostics can be made that way.  */
2528
2529
183
      if (s->symbol.udata.i == SYM_MACHO_FIELDS_UNSET)
2530
0
  {
2531
    /* No symbol information has been set - therefore determine
2532
       it from the bfd symbol flags/info.  */
2533
0
    if (s->symbol.section == bfd_abs_section_ptr)
2534
0
      s->n_type = BFD_MACH_O_N_ABS;
2535
0
    else if (s->symbol.section == bfd_und_section_ptr)
2536
0
      {
2537
0
        s->n_type = BFD_MACH_O_N_UNDF;
2538
0
        if (s->symbol.flags & BSF_WEAK)
2539
0
    s->n_desc |= BFD_MACH_O_N_WEAK_REF;
2540
        /* mach-o automatically makes undefined symbols extern.  */
2541
0
        s->n_type |= BFD_MACH_O_N_EXT;
2542
0
        s->symbol.flags |= BSF_GLOBAL;
2543
0
      }
2544
0
    else if (s->symbol.section == bfd_com_section_ptr)
2545
0
      {
2546
0
        s->n_type = BFD_MACH_O_N_UNDF | BFD_MACH_O_N_EXT;
2547
0
        s->symbol.flags |= BSF_GLOBAL;
2548
0
      }
2549
0
    else
2550
0
      s->n_type = BFD_MACH_O_N_SECT;
2551
0
  }
2552
2553
      /* Update external symbol bit in case objcopy changed it.  */
2554
183
      if (s->symbol.flags & BSF_GLOBAL)
2555
52
  s->n_type |= BFD_MACH_O_N_EXT;
2556
131
      else
2557
131
  s->n_type &= ~BFD_MACH_O_N_EXT;
2558
2559
      /* Put the section index in, where required.  */
2560
183
      if ((s->symbol.section != bfd_abs_section_ptr
2561
173
    && s->symbol.section != bfd_und_section_ptr
2562
27
    && s->symbol.section != bfd_com_section_ptr)
2563
165
    || ((s->n_type & BFD_MACH_O_N_STAB) != 0
2564
32
         && s->symbol.name == NULL))
2565
18
  s->n_sect = s->symbol.section->output_section->target_index;
2566
2567
      /* Number to preserve order for local and debug syms.  */
2568
183
      s->symbol.udata.i = i;
2569
183
    }
2570
2571
  /* Sort the symbols.  */
2572
16
  qsort ((void *) symbols, (size_t) bfd_get_symcount (abfd),
2573
16
   sizeof (asymbol *), bfd_mach_o_cf_symbols);
2574
2575
199
  for (i = 0; i < bfd_get_symcount (abfd); ++i)
2576
183
    {
2577
183
      bfd_mach_o_asymbol *s = (bfd_mach_o_asymbol *)symbols[i];
2578
183
      s->symbol.udata.i = i;  /* renumber.  */
2579
183
    }
2580
2581
16
  return true;
2582
38
}
2583
2584
/* We build a flat table of sections, which can be re-ordered if necessary.
2585
   Fill in the section number and other mach-o-specific data.  */
2586
2587
static bool
2588
bfd_mach_o_mangle_sections (bfd *abfd, bfd_mach_o_data_struct *mdata)
2589
38
{
2590
38
  asection *sec;
2591
38
  unsigned target_index;
2592
38
  unsigned nsect;
2593
38
  size_t amt;
2594
2595
38
  nsect = bfd_count_sections (abfd);
2596
2597
  /* Don't do it if it's already set - assume the application knows what it's
2598
     doing.  */
2599
38
  if (mdata->nsects == nsect
2600
18
      && (mdata->nsects == 0 || mdata->sections != NULL))
2601
18
    return true;
2602
2603
  /* We need to check that this can be done...  */
2604
20
  if (nsect > 255)
2605
0
    {
2606
0
      _bfd_error_handler (_("mach-o: there are too many sections (%u)"
2607
0
          " maximum is 255,\n"), nsect);
2608
0
      return false;
2609
0
    }
2610
2611
20
  mdata->nsects = nsect;
2612
20
  amt = mdata->nsects * sizeof (bfd_mach_o_section *);
2613
20
  mdata->sections = bfd_alloc (abfd, amt);
2614
20
  if (mdata->sections == NULL)
2615
0
    return false;
2616
2617
  /* Create Mach-O sections.
2618
     Section type, attribute and align should have been set when the
2619
     section was created - either read in or specified.  */
2620
20
  target_index = 0;
2621
71
  for (sec = abfd->sections; sec; sec = sec->next)
2622
51
    {
2623
51
      unsigned bfd_align = bfd_section_alignment (sec);
2624
51
      bfd_mach_o_section *msect = bfd_mach_o_get_mach_o_section (sec);
2625
2626
51
      mdata->sections[target_index] = msect;
2627
2628
51
      msect->addr = bfd_section_vma (sec);
2629
51
      msect->size = bfd_section_size (sec);
2630
2631
      /* Use the largest alignment set, in case it was bumped after the
2632
   section was created.  */
2633
51
      msect->align = msect->align > bfd_align ? msect->align : bfd_align;
2634
2635
51
      msect->offset = 0;
2636
51
      sec->target_index = ++target_index;
2637
51
    }
2638
2639
20
  return true;
2640
20
}
2641
2642
bool
2643
bfd_mach_o_write_contents (bfd *abfd)
2644
37
{
2645
37
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
2646
37
  bfd_mach_o_load_command *cmd;
2647
37
  bfd_mach_o_symtab_command *symtab = NULL;
2648
37
  bfd_mach_o_dysymtab_command *dysymtab = NULL;
2649
37
  bfd_mach_o_segment_command *linkedit = NULL;
2650
2651
  /* Make the commands, if not already present.  */
2652
37
  if (!abfd->output_has_begun && !bfd_mach_o_build_commands (abfd))
2653
0
    return false;
2654
37
  abfd->output_has_begun = true;
2655
2656
  /* Write the header.  */
2657
37
  if (!bfd_mach_o_write_header (abfd, &mdata->header))
2658
0
    return false;
2659
2660
  /* First pass: allocate the linkedit segment.  */
2661
207
  for (cmd = mdata->first_command; cmd != NULL; cmd = cmd->next)
2662
170
    switch (cmd->type)
2663
170
      {
2664
79
      case BFD_MACH_O_LC_SEGMENT_64:
2665
92
      case BFD_MACH_O_LC_SEGMENT:
2666
92
  if (strcmp (cmd->command.segment.segname, "__LINKEDIT") == 0)
2667
32
    linkedit = &cmd->command.segment;
2668
92
  break;
2669
15
      case BFD_MACH_O_LC_SYMTAB:
2670
15
  symtab = &cmd->command.symtab;
2671
15
  break;
2672
15
      case BFD_MACH_O_LC_DYSYMTAB:
2673
15
  dysymtab = &cmd->command.dysymtab;
2674
15
  break;
2675
13
      case BFD_MACH_O_LC_DYLD_INFO:
2676
13
  {
2677
13
    bfd_mach_o_dyld_info_command *di = &cmd->command.dyld_info;
2678
2679
13
    di->rebase_off = di->rebase_size != 0 ? mdata->filelen : 0;
2680
13
    mdata->filelen += di->rebase_size;
2681
13
    di->bind_off = di->bind_size != 0 ? mdata->filelen : 0;
2682
13
    mdata->filelen += di->bind_size;
2683
13
    di->weak_bind_off = di->weak_bind_size != 0 ? mdata->filelen : 0;
2684
13
    mdata->filelen += di->weak_bind_size;
2685
13
    di->lazy_bind_off = di->lazy_bind_size != 0 ? mdata->filelen : 0;
2686
13
    mdata->filelen += di->lazy_bind_size;
2687
13
    di->export_off = di->export_size != 0 ? mdata->filelen : 0;
2688
13
    mdata->filelen += di->export_size;
2689
13
  }
2690
13
  break;
2691
15
      case BFD_MACH_O_LC_LOAD_DYLIB:
2692
30
      case BFD_MACH_O_LC_LOAD_DYLINKER:
2693
35
      case BFD_MACH_O_LC_MAIN:
2694
  /* Nothing to do.  */
2695
35
  break;
2696
0
      default:
2697
0
  _bfd_error_handler
2698
0
    (_("unable to allocate data for load command %#x"),
2699
0
     cmd->type);
2700
0
  break;
2701
170
      }
2702
2703
  /* Specially handle symtab and dysymtab.  */
2704
2705
  /* Pre-allocate the symbol table (but not the string table).  The reason
2706
     is that the dysymtab is after the symbol table but before the string
2707
     table (required by the native strip tool).  */
2708
37
  if (symtab != NULL)
2709
15
    {
2710
15
      unsigned int symlen;
2711
15
      unsigned int wide = bfd_mach_o_wide_p (abfd);
2712
2713
15
      symlen = wide ? BFD_MACH_O_NLIST_64_SIZE : BFD_MACH_O_NLIST_SIZE;
2714
2715
      /* Align for symbols.  */
2716
15
      mdata->filelen = FILE_ALIGN (mdata->filelen, wide ? 3 : 2);
2717
15
      symtab->symoff = mdata->filelen;
2718
2719
15
      symtab->nsyms = bfd_get_symcount (abfd);
2720
15
      mdata->filelen += symtab->nsyms * symlen;
2721
15
    }
2722
2723
  /* Build the dysymtab.  */
2724
37
  if (dysymtab != NULL)
2725
15
    if (!bfd_mach_o_build_dysymtab (abfd, dysymtab))
2726
0
      return false;
2727
2728
  /* Write symtab and strtab.  */
2729
37
  if (symtab != NULL)
2730
15
    if (!bfd_mach_o_write_symtab_content (abfd, symtab))
2731
0
      return false;
2732
2733
  /* Adjust linkedit size.  */
2734
37
  if (linkedit != NULL)
2735
32
    {
2736
      /* bfd_vma pagemask = bfd_mach_o_get_backend_data (abfd)->page_size - 1; */
2737
2738
32
      linkedit->vmsize = mdata->filelen - linkedit->fileoff;
2739
      /* linkedit->vmsize = (linkedit->vmsize + pagemask) & ~pagemask; */
2740
32
      linkedit->filesize = mdata->filelen - linkedit->fileoff;
2741
2742
32
      linkedit->initprot = BFD_MACH_O_PROT_READ;
2743
32
      linkedit->maxprot = BFD_MACH_O_PROT_READ | BFD_MACH_O_PROT_WRITE
2744
32
  | BFD_MACH_O_PROT_EXECUTE;
2745
32
    }
2746
2747
  /* Second pass: write commands.  */
2748
207
  for (cmd = mdata->first_command; cmd != NULL; cmd = cmd->next)
2749
170
    {
2750
170
      struct mach_o_load_command_external raw;
2751
170
      unsigned long typeflag;
2752
2753
170
      typeflag = cmd->type | (cmd->type_required ? BFD_MACH_O_LC_REQ_DYLD : 0);
2754
2755
170
      bfd_h_put_32 (abfd, typeflag, raw.cmd);
2756
170
      bfd_h_put_32 (abfd, cmd->len, raw.cmdsize);
2757
2758
170
      if (bfd_seek (abfd, cmd->offset, SEEK_SET) != 0
2759
170
    || bfd_write (&raw, BFD_MACH_O_LC_SIZE, abfd) != 8)
2760
0
  return false;
2761
2762
170
      switch (cmd->type)
2763
170
  {
2764
13
  case BFD_MACH_O_LC_SEGMENT:
2765
13
    if (!bfd_mach_o_write_segment_32 (abfd, cmd))
2766
0
      return false;
2767
13
    break;
2768
79
  case BFD_MACH_O_LC_SEGMENT_64:
2769
79
    if (!bfd_mach_o_write_segment_64 (abfd, cmd))
2770
0
      return false;
2771
79
    break;
2772
79
  case BFD_MACH_O_LC_SYMTAB:
2773
15
    if (!bfd_mach_o_write_symtab (abfd, cmd))
2774
0
      return false;
2775
15
    break;
2776
15
  case BFD_MACH_O_LC_DYSYMTAB:
2777
15
    if (!bfd_mach_o_write_dysymtab (abfd, cmd))
2778
0
      return false;
2779
15
    break;
2780
15
  case BFD_MACH_O_LC_THREAD:
2781
0
  case BFD_MACH_O_LC_UNIXTHREAD:
2782
0
    if (!bfd_mach_o_write_thread (abfd, cmd))
2783
0
      return false;
2784
0
    break;
2785
15
  case BFD_MACH_O_LC_LOAD_DYLIB:
2786
15
    if (!bfd_mach_o_write_dylib (abfd, cmd))
2787
0
      return false;
2788
15
    break;
2789
15
  case BFD_MACH_O_LC_LOAD_DYLINKER:
2790
15
    if (!bfd_mach_o_write_dylinker (abfd, cmd))
2791
0
      return false;
2792
15
    break;
2793
15
  case BFD_MACH_O_LC_MAIN:
2794
5
    if (!bfd_mach_o_write_main (abfd, cmd))
2795
0
      return false;
2796
5
    break;
2797
13
  case BFD_MACH_O_LC_DYLD_INFO:
2798
13
    if (!bfd_mach_o_write_dyld_info (abfd, cmd))
2799
0
      return false;
2800
13
    break;
2801
13
  default:
2802
0
    _bfd_error_handler
2803
0
      (_("unable to write unknown load command %#x"),
2804
0
       cmd->type);
2805
0
    return false;
2806
170
  }
2807
170
    }
2808
2809
37
  return true;
2810
37
}
2811
2812
static void
2813
bfd_mach_o_append_section_to_segment (bfd_mach_o_segment_command *seg,
2814
              bfd_mach_o_section *s)
2815
458k
{
2816
458k
  if (seg->sect_head == NULL)
2817
19.6k
    seg->sect_head = s;
2818
439k
  else
2819
439k
    seg->sect_tail->next = s;
2820
458k
  seg->sect_tail = s;
2821
458k
}
2822
2823
/* Create section Mach-O flags from BFD flags.  */
2824
2825
static void
2826
bfd_mach_o_set_section_flags_from_bfd (bfd *abfd ATTRIBUTE_UNUSED,
2827
               asection *sec)
2828
460k
{
2829
460k
  flagword bfd_flags;
2830
460k
  bfd_mach_o_section *s = bfd_mach_o_get_mach_o_section (sec);
2831
2832
  /* Create default flags.  */
2833
460k
  bfd_flags = bfd_section_flags (sec);
2834
460k
  if ((bfd_flags & SEC_CODE) == SEC_CODE)
2835
265
    s->flags = BFD_MACH_O_S_ATTR_PURE_INSTRUCTIONS
2836
265
      | BFD_MACH_O_S_ATTR_SOME_INSTRUCTIONS
2837
265
      | BFD_MACH_O_S_REGULAR;
2838
460k
  else if ((bfd_flags & (SEC_ALLOC | SEC_LOAD)) == SEC_ALLOC)
2839
9
    s->flags = BFD_MACH_O_S_ZEROFILL;
2840
460k
  else if (bfd_flags & SEC_DEBUGGING)
2841
27
    s->flags = BFD_MACH_O_S_REGULAR |  BFD_MACH_O_S_ATTR_DEBUG;
2842
460k
  else
2843
460k
    s->flags = BFD_MACH_O_S_REGULAR;
2844
460k
}
2845
2846
static bool
2847
bfd_mach_o_build_obj_seg_command (bfd *abfd, bfd_mach_o_segment_command *seg)
2848
2
{
2849
2
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
2850
2
  unsigned int i, j;
2851
2852
2
  seg->vmaddr = 0;
2853
2
  seg->fileoff = mdata->filelen;
2854
2
  seg->initprot = BFD_MACH_O_PROT_READ | BFD_MACH_O_PROT_WRITE
2855
2
    | BFD_MACH_O_PROT_EXECUTE;
2856
2
  seg->maxprot = seg->initprot;
2857
2858
  /*  Append sections to the segment.
2859
2860
      This is a little tedious, we have to honor the need to account zerofill
2861
      sections after all the rest.  This forces us to do the calculation of
2862
      total vmsize in three passes so that any alignment increments are
2863
      properly accounted.  */
2864
4
  for (i = 0; i < mdata->nsects; ++i)
2865
2
    {
2866
2
      bfd_mach_o_section *s = mdata->sections[i];
2867
2
      asection *sec = s->bfdsection;
2868
2869
      /* Although we account for zerofill section sizes in vm order, they are
2870
   placed in the file in source sequence.  */
2871
2
      bfd_mach_o_append_section_to_segment (seg, s);
2872
2
      s->offset = 0;
2873
2874
      /* Zerofill sections have zero file size & offset, the only content
2875
   written to the file is the symbols.  */
2876
2
      if ((s->flags & BFD_MACH_O_SECTION_TYPE_MASK) == BFD_MACH_O_S_ZEROFILL
2877
2
    || ((s->flags & BFD_MACH_O_SECTION_TYPE_MASK)
2878
2
        == BFD_MACH_O_S_GB_ZEROFILL))
2879
0
  continue;
2880
2881
      /* The Darwin system tools (in MH_OBJECT files, at least) always account
2882
   sections, even those with zero size.  */
2883
2
      if (s->size > 0)
2884
0
  {
2885
0
    seg->vmsize = FILE_ALIGN (seg->vmsize, s->align);
2886
0
    seg->vmsize += s->size;
2887
2888
    /* MH_OBJECT files have unaligned content.  */
2889
0
    if (1)
2890
0
      {
2891
0
        seg->filesize = FILE_ALIGN (seg->filesize, s->align);
2892
0
        mdata->filelen = FILE_ALIGN (mdata->filelen, s->align);
2893
0
      }
2894
0
    seg->filesize += s->size;
2895
2896
    /* The system tools write even zero-sized sections with an offset
2897
       field set to the current file position.  */
2898
0
    s->offset = mdata->filelen;
2899
0
  }
2900
2901
2
      sec->filepos = s->offset;
2902
2
      mdata->filelen += s->size;
2903
2
    }
2904
2905
  /* Now pass through again, for zerofill, only now we just update the
2906
     vmsize, and then for zerofill_GB.  */
2907
6
  for (j = 0; j < 2; j++)
2908
4
    {
2909
4
      unsigned int stype;
2910
2911
4
      if (j == 0)
2912
2
  stype = BFD_MACH_O_S_ZEROFILL;
2913
2
      else
2914
2
  stype = BFD_MACH_O_S_GB_ZEROFILL;
2915
2916
8
      for (i = 0; i < mdata->nsects; ++i)
2917
4
  {
2918
4
    bfd_mach_o_section *s = mdata->sections[i];
2919
2920
4
    if ((s->flags & BFD_MACH_O_SECTION_TYPE_MASK) != stype)
2921
4
      continue;
2922
2923
0
    if (s->size > 0)
2924
0
      {
2925
0
        seg->vmsize = FILE_ALIGN (seg->vmsize, s->align);
2926
0
        seg->vmsize += s->size;
2927
0
      }
2928
0
  }
2929
4
    }
2930
2931
  /* Allocate space for the relocations.  */
2932
2
  mdata->filelen = FILE_ALIGN (mdata->filelen, 2);
2933
2934
4
  for (i = 0; i < mdata->nsects; ++i)
2935
2
    {
2936
2
      bfd_mach_o_section *ms = mdata->sections[i];
2937
2
      asection *sec = ms->bfdsection;
2938
2939
2
      ms->nreloc = sec->reloc_count;
2940
2
      if (ms->nreloc == 0)
2941
2
  {
2942
    /* Clear nreloc and reloff if there is no relocs.  */
2943
2
    ms->reloff = 0;
2944
2
    continue;
2945
2
  }
2946
0
      sec->rel_filepos = mdata->filelen;
2947
0
      ms->reloff = sec->rel_filepos;
2948
0
      mdata->filelen += sec->reloc_count * BFD_MACH_O_RELENT_SIZE;
2949
0
    }
2950
2951
2
  return true;
2952
2
}
2953
2954
static bool
2955
bfd_mach_o_build_exec_seg_command (bfd *abfd, bfd_mach_o_segment_command *seg)
2956
27
{
2957
27
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
2958
27
  unsigned int i;
2959
27
  bfd_vma pagemask = bfd_mach_o_get_backend_data (abfd)->page_size - 1;
2960
27
  bfd_vma vma;
2961
27
  bfd_mach_o_section *s;
2962
2963
27
  seg->vmsize = 0;
2964
2965
27
  seg->fileoff = mdata->filelen;
2966
27
  seg->maxprot = 0;
2967
27
  seg->initprot = 0;
2968
27
  seg->flags = 0;
2969
2970
  /*  Append sections to the segment.  We assume they are properly ordered
2971
      by vma (but we check that).  */
2972
27
  vma = 0;
2973
129
  for (i = 0; i < mdata->nsects; ++i)
2974
103
    {
2975
103
      s = mdata->sections[i];
2976
2977
      /* Consider only sections for this segment.  */
2978
103
      if (strcmp (seg->segname, s->segname) != 0)
2979
51
  continue;
2980
2981
52
      bfd_mach_o_append_section_to_segment (seg, s);
2982
2983
52
      if (s->addr < vma)
2984
1
  {
2985
1
    _bfd_error_handler
2986
      /* xgettext:c-format */
2987
1
      (_("section address (%#" PRIx64 ") "
2988
1
         "below start of segment (%#" PRIx64 ")"),
2989
1
         (uint64_t) s->addr, (uint64_t) vma);
2990
1
    return false;
2991
1
  }
2992
2993
51
      vma = s->addr + s->size;
2994
51
    }
2995
2996
  /* Set segment file offset: make it page aligned.  */
2997
26
  vma = seg->sect_head->addr;
2998
26
  seg->vmaddr = vma & ~pagemask;
2999
26
  if ((mdata->filelen & pagemask) > (vma & pagemask))
3000
12
    mdata->filelen += pagemask + 1;
3001
26
  seg->fileoff = mdata->filelen & ~pagemask;
3002
26
  mdata->filelen = seg->fileoff + (vma & pagemask);
3003
3004
  /* Set section file offset.  */
3005
76
  for (s = seg->sect_head; s != NULL; s = s->next)
3006
50
    {
3007
50
      asection *sec = s->bfdsection;
3008
50
      flagword flags = bfd_section_flags (sec);
3009
3010
      /* Adjust segment size.  */
3011
50
      seg->vmsize = FILE_ALIGN (seg->vmsize, s->align);
3012
50
      seg->vmsize += s->size;
3013
3014
      /* File offset and length.  */
3015
50
      seg->filesize = FILE_ALIGN (seg->filesize, s->align);
3016
3017
50
      if ((s->flags & BFD_MACH_O_SECTION_TYPE_MASK) != BFD_MACH_O_S_ZEROFILL
3018
50
    && ((s->flags & BFD_MACH_O_SECTION_TYPE_MASK)
3019
50
        != BFD_MACH_O_S_GB_ZEROFILL))
3020
50
  {
3021
50
    mdata->filelen = FILE_ALIGN (mdata->filelen, s->align);
3022
3023
50
    s->offset = mdata->filelen;
3024
50
    s->bfdsection->filepos = s->offset;
3025
3026
50
    seg->filesize += s->size;
3027
50
    mdata->filelen += s->size;
3028
50
  }
3029
0
      else
3030
0
  {
3031
0
    s->offset = 0;
3032
0
    s->bfdsection->filepos = 0;
3033
0
  }
3034
3035
      /* Set protection.  */
3036
50
      if (flags & SEC_LOAD)
3037
49
  {
3038
49
    if (flags & SEC_CODE)
3039
22
      seg->initprot |= BFD_MACH_O_PROT_READ | BFD_MACH_O_PROT_EXECUTE;
3040
49
    if ((flags & (SEC_DATA | SEC_READONLY)) == SEC_DATA)
3041
21
      seg->initprot |= BFD_MACH_O_PROT_WRITE | BFD_MACH_O_PROT_READ;
3042
49
  }
3043
3044
      /* Relocs shouldn't appear in non-object files.  */
3045
50
      if (s->bfdsection->reloc_count != 0)
3046
0
  return false;
3047
50
    }
3048
3049
  /* Set maxprot.  */
3050
26
  if (seg->initprot != 0)
3051
25
    seg->maxprot = BFD_MACH_O_PROT_READ | BFD_MACH_O_PROT_WRITE
3052
25
     | BFD_MACH_O_PROT_EXECUTE;
3053
1
  else
3054
1
    seg->maxprot = 0;
3055
3056
  /* Round segment size (and file size).  */
3057
26
  seg->vmsize = (seg->vmsize + pagemask) & ~pagemask;
3058
26
  seg->filesize = (seg->filesize + pagemask) & ~pagemask;
3059
26
  mdata->filelen = (mdata->filelen + pagemask) & ~pagemask;
3060
3061
26
  return true;
3062
26
}
3063
3064
/* Layout the commands: set commands size and offset, set ncmds and sizeofcmds
3065
   fields in header.  */
3066
3067
static bool
3068
bfd_mach_o_layout_commands (bfd_mach_o_data_struct *mdata)
3069
38
{
3070
38
  unsigned wide = mach_o_wide_p (&mdata->header);
3071
38
  unsigned int hdrlen;
3072
38
  ufile_ptr offset;
3073
38
  bfd_mach_o_load_command *cmd;
3074
38
  unsigned int align;
3075
38
  bool ret = true;
3076
3077
38
  hdrlen = wide ? BFD_MACH_O_HEADER_64_SIZE : BFD_MACH_O_HEADER_SIZE;
3078
38
  align = wide ? 8 - 1 : 4 - 1;
3079
38
  offset = hdrlen;
3080
38
  mdata->header.ncmds = 0;
3081
3082
220
  for (cmd = mdata->first_command; cmd; cmd = cmd->next)
3083
182
    {
3084
182
      mdata->header.ncmds++;
3085
182
      cmd->offset = offset;
3086
3087
182
      switch (cmd->type)
3088
182
  {
3089
85
  case BFD_MACH_O_LC_SEGMENT_64:
3090
85
    cmd->len = BFD_MACH_O_LC_SEGMENT_64_SIZE
3091
85
      + BFD_MACH_O_SECTION_64_SIZE * cmd->command.segment.nsects;
3092
85
    break;
3093
13
  case BFD_MACH_O_LC_SEGMENT:
3094
13
    cmd->len = BFD_MACH_O_LC_SEGMENT_SIZE
3095
13
      + BFD_MACH_O_SECTION_SIZE * cmd->command.segment.nsects;
3096
13
    break;
3097
16
  case BFD_MACH_O_LC_SYMTAB:
3098
16
    cmd->len = sizeof (struct mach_o_symtab_command_external)
3099
16
      + BFD_MACH_O_LC_SIZE;
3100
16
    break;
3101
16
  case BFD_MACH_O_LC_DYSYMTAB:
3102
16
    cmd->len = sizeof (struct mach_o_dysymtab_command_external)
3103
16
     + BFD_MACH_O_LC_SIZE;
3104
16
    break;
3105
16
  case BFD_MACH_O_LC_LOAD_DYLIB:
3106
16
    cmd->len = sizeof (struct mach_o_dylib_command_external)
3107
16
     + BFD_MACH_O_LC_SIZE;
3108
16
    cmd->command.dylib.name_offset = cmd->len;
3109
16
    cmd->len += strlen (cmd->command.dylib.name_str);
3110
16
    cmd->len = (cmd->len + align) & ~align;
3111
16
    break;
3112
16
  case BFD_MACH_O_LC_LOAD_DYLINKER:
3113
16
    cmd->len = sizeof (struct mach_o_str_command_external)
3114
16
     + BFD_MACH_O_LC_SIZE;
3115
16
    cmd->command.dylinker.name_offset = cmd->len;
3116
16
    cmd->len += strlen (cmd->command.dylinker.name_str);
3117
16
    cmd->len = (cmd->len + align) & ~align;
3118
16
    break;
3119
6
  case BFD_MACH_O_LC_MAIN:
3120
6
    cmd->len = sizeof (struct mach_o_entry_point_command_external)
3121
6
     + BFD_MACH_O_LC_SIZE;
3122
6
    break;
3123
14
  case BFD_MACH_O_LC_DYLD_INFO:
3124
14
    cmd->len = sizeof (struct mach_o_dyld_info_command_external)
3125
14
     + BFD_MACH_O_LC_SIZE;
3126
14
    break;
3127
0
  default:
3128
0
    _bfd_error_handler
3129
0
      (_("unable to layout unknown load command %#x"),
3130
0
       cmd->type);
3131
0
    ret = false;
3132
0
    break;
3133
182
  }
3134
3135
182
      BFD_ASSERT (cmd->len % (align + 1) == 0);
3136
182
      offset += cmd->len;
3137
182
    }
3138
38
  mdata->header.sizeofcmds = offset - hdrlen;
3139
38
  mdata->filelen = offset;
3140
3141
38
  return ret;
3142
38
}
3143
3144
/* Subroutine of bfd_mach_o_build_commands: set type, name and nsects of a
3145
   segment.  */
3146
3147
static void
3148
bfd_mach_o_init_segment (bfd_mach_o_data_struct *mdata,
3149
       bfd_mach_o_load_command *cmd,
3150
       const char *segname, unsigned int nbr_sect)
3151
98
{
3152
98
  bfd_mach_o_segment_command *seg = &cmd->command.segment;
3153
98
  unsigned wide = mach_o_wide_p (&mdata->header);
3154
3155
  /* Init segment command.  */
3156
98
  cmd->type = wide ? BFD_MACH_O_LC_SEGMENT_64 : BFD_MACH_O_LC_SEGMENT;
3157
98
  cmd->type_required = false;
3158
3159
98
  strcpy (seg->segname, segname);
3160
98
  seg->nsects = nbr_sect;
3161
3162
98
  seg->vmaddr = 0;
3163
98
  seg->vmsize = 0;
3164
3165
98
  seg->fileoff = 0;
3166
98
  seg->filesize = 0;
3167
98
  seg->maxprot = 0;
3168
98
  seg->initprot = 0;
3169
98
  seg->flags = 0;
3170
98
  seg->sect_head = NULL;
3171
98
  seg->sect_tail = NULL;
3172
98
}
3173
3174
/* Build Mach-O load commands (currently assuming an MH_OBJECT file).
3175
   TODO: Other file formats, rebuilding symtab/dysymtab commands for strip
3176
   and copy functionality.  */
3177
3178
bool
3179
bfd_mach_o_build_commands (bfd *abfd)
3180
38
{
3181
38
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
3182
38
  unsigned wide = mach_o_wide_p (&mdata->header);
3183
38
  unsigned int nbr_segcmd = 0;
3184
38
  bfd_mach_o_load_command *commands;
3185
38
  unsigned int nbr_commands;
3186
38
  int symtab_idx = -1;
3187
38
  int dysymtab_idx = -1;
3188
38
  int main_idx = -1;
3189
38
  unsigned int i;
3190
3191
  /* Return now if already built.  */
3192
38
  if (mdata->header.ncmds != 0)
3193
0
    return true;
3194
3195
  /* Fill in the file type, if not already set.  */
3196
38
  if (mdata->header.filetype == 0)
3197
38
    {
3198
38
      if (abfd->flags & EXEC_P)
3199
33
  mdata->header.filetype = BFD_MACH_O_MH_EXECUTE;
3200
5
      else if (abfd->flags & DYNAMIC)
3201
0
  mdata->header.filetype = BFD_MACH_O_MH_DYLIB;
3202
5
      else
3203
5
  mdata->header.filetype = BFD_MACH_O_MH_OBJECT;
3204
38
    }
3205
3206
  /* If hasn't already been done, flatten sections list, and sort
3207
     if/when required.  Must be done before the symbol table is adjusted,
3208
     since that depends on properly numbered sections.  */
3209
38
  if (mdata->nsects == 0 || mdata->sections == NULL)
3210
38
    if (! bfd_mach_o_mangle_sections (abfd, mdata))
3211
0
      return false;
3212
3213
  /* Order the symbol table, fill-in/check mach-o specific fields and
3214
     partition out any indirect symbols.  */
3215
38
  if (!bfd_mach_o_mangle_symbols (abfd))
3216
0
    return false;
3217
3218
  /* Segment commands.  */
3219
38
  if (mdata->header.filetype == BFD_MACH_O_MH_OBJECT)
3220
5
    {
3221
      /* Only one segment for all the sections.  But the segment is
3222
   optional if there is no sections.  */
3223
5
      nbr_segcmd = (mdata->nsects > 0) ? 1 : 0;
3224
5
    }
3225
33
  else
3226
33
    {
3227
33
      bfd_mach_o_section *prev_sect = NULL;
3228
3229
      /* One pagezero segment and one linkedit segment.  */
3230
33
      nbr_segcmd = 2;
3231
3232
      /* Create one segment for associated segment name in sections.
3233
   Assume that sections with the same segment name are consecutive.  */
3234
82
      for (i = 0; i < mdata->nsects; i++)
3235
49
  {
3236
49
    bfd_mach_o_section *this_sect = mdata->sections[i];
3237
3238
49
    if (prev_sect == NULL
3239
31
        || strcmp (prev_sect->segname, this_sect->segname) != 0)
3240
30
      {
3241
30
        nbr_segcmd++;
3242
30
        prev_sect = this_sect;
3243
30
      }
3244
49
  }
3245
33
    }
3246
3247
38
  nbr_commands = nbr_segcmd;
3248
3249
  /* One command for the symbol table (only if there are symbols.  */
3250
38
  if (bfd_get_symcount (abfd) > 0)
3251
16
    symtab_idx = nbr_commands++;
3252
3253
  /* FIXME:
3254
     This is a rather crude test for whether we should build a dysymtab.  */
3255
38
  if (bfd_mach_o_should_emit_dysymtab ()
3256
38
      && bfd_get_symcount (abfd))
3257
16
    {
3258
      /* If there should be a case where a dysymtab could be emitted without
3259
   a symtab (seems improbable), this would need amending.  */
3260
16
      dysymtab_idx = nbr_commands++;
3261
16
    }
3262
3263
  /* Add an entry point command.  */
3264
38
  if (mdata->header.filetype == BFD_MACH_O_MH_EXECUTE
3265
33
      && bfd_get_start_address (abfd) != 0)
3266
6
    main_idx = nbr_commands++;
3267
3268
  /* Well, we must have a header, at least.  */
3269
38
  mdata->filelen = wide ? BFD_MACH_O_HEADER_64_SIZE : BFD_MACH_O_HEADER_SIZE;
3270
3271
  /* A bit unusual, but no content is valid;
3272
     as -n empty.s -o empty.o  */
3273
38
  if (nbr_commands == 0)
3274
3
    {
3275
      /* Layout commands (well none...) and set headers command fields.  */
3276
3
      return bfd_mach_o_layout_commands (mdata);
3277
3
    }
3278
3279
  /* Create commands for segments (and symtabs), prepend them.  */
3280
35
  commands = bfd_zalloc (abfd, nbr_commands * sizeof (bfd_mach_o_load_command));
3281
35
  if (commands == NULL)
3282
0
    return false;
3283
136
  for (i = 0; i < nbr_commands - 1; i++)
3284
101
    commands[i].next = &commands[i + 1];
3285
35
  commands[nbr_commands - 1].next = mdata->first_command;
3286
35
  if (mdata->first_command == NULL)
3287
19
    mdata->last_command = &commands[nbr_commands - 1];
3288
35
  mdata->first_command = &commands[0];
3289
3290
35
  if (mdata->header.filetype == BFD_MACH_O_MH_OBJECT && nbr_segcmd != 0)
3291
2
    {
3292
      /* For object file, there is only one segment.  */
3293
2
      bfd_mach_o_init_segment (mdata, &commands[0], "", mdata->nsects);
3294
2
    }
3295
33
  else if (nbr_segcmd != 0)
3296
33
    {
3297
33
      bfd_mach_o_load_command *cmd;
3298
3299
33
      BFD_ASSERT (nbr_segcmd >= 2);
3300
3301
      /* The pagezero.  */
3302
33
      cmd = &commands[0];
3303
33
      bfd_mach_o_init_segment (mdata, cmd, "__PAGEZERO", 0);
3304
3305
      /* Segments from sections.  */
3306
33
      cmd++;
3307
63
      for (i = 0; i < mdata->nsects;)
3308
30
  {
3309
30
    const char *segname = mdata->sections[i]->segname;
3310
30
    unsigned int nbr_sect = 1;
3311
3312
    /* Count number of sections for this segment.  */
3313
49
    for (i++; i < mdata->nsects; i++)
3314
31
      if (strcmp (mdata->sections[i]->segname, segname) == 0)
3315
19
        nbr_sect++;
3316
12
      else
3317
12
        break;
3318
3319
30
    bfd_mach_o_init_segment (mdata, cmd, segname, nbr_sect);
3320
30
    cmd++;
3321
30
  }
3322
3323
      /* The linkedit.  */
3324
33
      bfd_mach_o_init_segment (mdata, cmd, "__LINKEDIT", 0);
3325
33
    }
3326
3327
35
  if (symtab_idx >= 0)
3328
16
    {
3329
      /* Init symtab command.  */
3330
16
      bfd_mach_o_load_command *cmd = &commands[symtab_idx];
3331
3332
16
      cmd->type = BFD_MACH_O_LC_SYMTAB;
3333
16
      cmd->type_required = false;
3334
16
    }
3335
3336
  /* If required, setup symtab command, see comment above about the quality
3337
     of this test.  */
3338
35
  if (dysymtab_idx >= 0)
3339
16
    {
3340
16
      bfd_mach_o_load_command *cmd = &commands[dysymtab_idx];
3341
3342
16
      cmd->type = BFD_MACH_O_LC_DYSYMTAB;
3343
16
      cmd->type_required = false;
3344
16
    }
3345
3346
  /* Create the main command.  */
3347
35
  if (main_idx >= 0)
3348
6
    {
3349
6
      bfd_mach_o_load_command *cmd = &commands[main_idx];
3350
3351
6
      cmd->type = BFD_MACH_O_LC_MAIN;
3352
6
      cmd->type_required = true;
3353
3354
6
      cmd->command.main.entryoff = 0;
3355
6
      cmd->command.main.stacksize = 0;
3356
6
    }
3357
3358
  /* Layout commands.  */
3359
35
  if (! bfd_mach_o_layout_commands (mdata))
3360
0
    return false;
3361
3362
  /* So, now we have sized the commands and the filelen set to that.
3363
     Now we can build the segment command and set the section file offsets.  */
3364
35
  if (mdata->header.filetype == BFD_MACH_O_MH_OBJECT)
3365
2
    {
3366
4
      for (i = 0; i < nbr_segcmd; i++)
3367
2
  if (!bfd_mach_o_build_obj_seg_command
3368
2
      (abfd, &commands[i].command.segment))
3369
0
    return false;
3370
2
    }
3371
33
  else
3372
33
    {
3373
33
      bfd_vma maxvma = 0;
3374
3375
      /* Skip pagezero and linkedit segments.  */
3376
59
      for (i = 1; i < nbr_segcmd - 1; i++)
3377
27
  {
3378
27
    bfd_mach_o_segment_command *seg = &commands[i].command.segment;
3379
3380
27
    if (!bfd_mach_o_build_exec_seg_command (abfd, seg))
3381
1
      return false;
3382
3383
26
    if (seg->vmaddr + seg->vmsize > maxvma)
3384
22
      maxvma = seg->vmaddr + seg->vmsize;
3385
26
  }
3386
3387
      /* Set the size of __PAGEZERO.  */
3388
32
      commands[0].command.segment.vmsize =
3389
32
  commands[1].command.segment.vmaddr;
3390
3391
      /* Set the vma and fileoff of __LINKEDIT.  */
3392
32
      commands[nbr_segcmd - 1].command.segment.vmaddr = maxvma;
3393
32
      commands[nbr_segcmd - 1].command.segment.fileoff = mdata->filelen;
3394
3395
      /* Set entry point (once segments have been laid out).  */
3396
32
      if (main_idx >= 0)
3397
5
  commands[main_idx].command.main.entryoff =
3398
5
    bfd_get_start_address (abfd) - commands[1].command.segment.vmaddr;
3399
32
    }
3400
3401
34
  return true;
3402
35
}
3403
3404
/* Set the contents of a section.  */
3405
3406
bool
3407
bfd_mach_o_set_section_contents (bfd *abfd,
3408
         asection *section,
3409
         const void * location,
3410
         file_ptr offset,
3411
         bfd_size_type count)
3412
29
{
3413
29
  file_ptr pos;
3414
3415
  /* Trying to write the first section contents will trigger the creation of
3416
     the load commands if they are not already present.  */
3417
29
  if (!abfd->output_has_begun && !bfd_mach_o_build_commands (abfd))
3418
1
    return false;
3419
3420
28
  if (count == 0)
3421
0
    return true;
3422
3423
28
  pos = section->filepos + offset;
3424
28
  if (bfd_seek (abfd, pos, SEEK_SET) != 0
3425
28
      || bfd_write (location, count, abfd) != count)
3426
0
    return false;
3427
3428
28
  return true;
3429
28
}
3430
3431
int
3432
bfd_mach_o_sizeof_headers (bfd *a ATTRIBUTE_UNUSED,
3433
         struct bfd_link_info *info ATTRIBUTE_UNUSED)
3434
0
{
3435
0
  return 0;
3436
0
}
3437
3438
/* Make an empty symbol.  This is required only because
3439
   bfd_make_section_anyway wants to create a symbol for the section.  */
3440
3441
asymbol *
3442
bfd_mach_o_make_empty_symbol (bfd *abfd)
3443
467k
{
3444
467k
  asymbol *new_symbol;
3445
3446
467k
  new_symbol = bfd_zalloc (abfd, sizeof (bfd_mach_o_asymbol));
3447
467k
  if (new_symbol == NULL)
3448
0
    return new_symbol;
3449
467k
  new_symbol->the_bfd = abfd;
3450
467k
  new_symbol->udata.i = SYM_MACHO_FIELDS_UNSET;
3451
467k
  return new_symbol;
3452
467k
}
3453
3454
static bool
3455
bfd_mach_o_read_header (bfd *abfd, file_ptr hdr_off, bfd_mach_o_header *header)
3456
886k
{
3457
886k
  struct mach_o_header_external raw;
3458
886k
  unsigned int size;
3459
886k
  bfd_vma (*get32) (const void *) = NULL;
3460
3461
  /* Just read the magic number.  */
3462
886k
  if (bfd_seek (abfd, hdr_off, SEEK_SET) != 0
3463
886k
      || bfd_read (raw.magic, sizeof (raw.magic), abfd) != 4)
3464
3.46k
    return false;
3465
3466
883k
  if (bfd_getb32 (raw.magic) == BFD_MACH_O_MH_MAGIC)
3467
1.81k
    {
3468
1.81k
      header->byteorder = BFD_ENDIAN_BIG;
3469
1.81k
      header->magic = BFD_MACH_O_MH_MAGIC;
3470
1.81k
      header->version = 1;
3471
1.81k
      get32 = bfd_getb32;
3472
1.81k
    }
3473
881k
  else if (bfd_getl32 (raw.magic) == BFD_MACH_O_MH_MAGIC)
3474
13.1k
    {
3475
13.1k
      header->byteorder = BFD_ENDIAN_LITTLE;
3476
13.1k
      header->magic = BFD_MACH_O_MH_MAGIC;
3477
13.1k
      header->version = 1;
3478
13.1k
      get32 = bfd_getl32;
3479
13.1k
    }
3480
868k
  else if (bfd_getb32 (raw.magic) == BFD_MACH_O_MH_MAGIC_64)
3481
102
    {
3482
102
      header->byteorder = BFD_ENDIAN_BIG;
3483
102
      header->magic = BFD_MACH_O_MH_MAGIC_64;
3484
102
      header->version = 2;
3485
102
      get32 = bfd_getb32;
3486
102
    }
3487
868k
  else if (bfd_getl32 (raw.magic) == BFD_MACH_O_MH_MAGIC_64)
3488
19.1k
    {
3489
19.1k
      header->byteorder = BFD_ENDIAN_LITTLE;
3490
19.1k
      header->magic = BFD_MACH_O_MH_MAGIC_64;
3491
19.1k
      header->version = 2;
3492
19.1k
      get32 = bfd_getl32;
3493
19.1k
    }
3494
849k
  else
3495
849k
    {
3496
849k
      header->byteorder = BFD_ENDIAN_UNKNOWN;
3497
849k
      return false;
3498
849k
    }
3499
3500
  /* Once the size of the header is known, read the full header.  */
3501
34.2k
  size = mach_o_wide_p (header) ?
3502
19.2k
    BFD_MACH_O_HEADER_64_SIZE : BFD_MACH_O_HEADER_SIZE;
3503
3504
34.2k
  if (bfd_seek (abfd, hdr_off, SEEK_SET) != 0
3505
34.2k
      || bfd_read (&raw, size, abfd) != size)
3506
186
    return false;
3507
3508
34.0k
  header->cputype = (*get32) (raw.cputype);
3509
34.0k
  header->cpusubtype = (*get32) (raw.cpusubtype);
3510
34.0k
  header->filetype = (*get32) (raw.filetype);
3511
34.0k
  header->ncmds = (*get32) (raw.ncmds);
3512
34.0k
  header->sizeofcmds = (*get32) (raw.sizeofcmds);
3513
34.0k
  header->flags = (*get32) (raw.flags);
3514
3515
34.0k
  if (mach_o_wide_p (header))
3516
19.1k
    header->reserved = (*get32) (raw.reserved);
3517
14.9k
  else
3518
14.9k
    header->reserved = 0;
3519
3520
34.0k
  return true;
3521
34.2k
}
3522
3523
bool
3524
bfd_mach_o_new_section_hook (bfd *abfd, asection *sec)
3525
465k
{
3526
465k
  bfd_mach_o_section *s = bfd_zalloc (abfd, sizeof (*s));
3527
465k
  if (s == NULL)
3528
0
    return false;
3529
465k
  sec->used_by_bfd = s;
3530
465k
  s->bfdsection = sec;
3531
3532
  /* Create the Darwin seg/sect name pair from the bfd name.
3533
     If this is a canonical name for which a specific paiting exists
3534
     there will also be defined flags, type, attribute and alignment
3535
     values.  */
3536
465k
  const mach_o_section_name_xlat *xlat
3537
465k
    = bfd_mach_o_convert_section_name_to_mach_o (abfd, sec, s);
3538
465k
  if (xlat != NULL)
3539
4.39k
    {
3540
4.39k
      s->flags = xlat->macho_sectype | xlat->macho_secattr;
3541
4.39k
      unsigned bfdalign = bfd_section_alignment (sec);
3542
4.39k
      s->align = xlat->sectalign > bfdalign ? xlat->sectalign : bfdalign;
3543
4.39k
      bfd_set_section_alignment (sec, s->align);
3544
4.39k
      flagword bfd_flags = bfd_section_flags (sec);
3545
4.39k
      if (bfd_flags == SEC_NO_FLAGS)
3546
118
  bfd_set_section_flags (sec, xlat->bfd_flags);
3547
4.39k
    }
3548
460k
  else
3549
    /* Create default flags.  */
3550
460k
    bfd_mach_o_set_section_flags_from_bfd (abfd, sec);
3551
3552
465k
  return _bfd_generic_new_section_hook (abfd, sec);
3553
465k
}
3554
3555
static void
3556
bfd_mach_o_init_section_from_mach_o (asection *sec, unsigned long prot)
3557
458k
{
3558
458k
  flagword flags;
3559
458k
  bfd_mach_o_section *section;
3560
3561
458k
  flags = bfd_section_flags (sec);
3562
458k
  section = bfd_mach_o_get_mach_o_section (sec);
3563
3564
  /* TODO: see if we should use the xlat system for doing this by
3565
     preference and fall back to this for unknown sections.  */
3566
3567
458k
  if (flags == SEC_NO_FLAGS)
3568
454k
    {
3569
      /* Try to guess flags.  */
3570
454k
      if (section->flags & BFD_MACH_O_S_ATTR_DEBUG)
3571
114k
  flags = SEC_DEBUGGING;
3572
340k
      else
3573
340k
  {
3574
340k
    flags = SEC_ALLOC;
3575
340k
    if ((section->flags & BFD_MACH_O_SECTION_TYPE_MASK)
3576
340k
        != BFD_MACH_O_S_ZEROFILL)
3577
328k
      {
3578
328k
        flags |= SEC_LOAD;
3579
328k
        if (prot & BFD_MACH_O_PROT_EXECUTE)
3580
51.3k
    flags |= SEC_CODE;
3581
328k
        if (prot & BFD_MACH_O_PROT_WRITE)
3582
112k
    flags |= SEC_DATA;
3583
216k
        else if (prot & BFD_MACH_O_PROT_READ)
3584
34.8k
    flags |= SEC_READONLY;
3585
328k
      }
3586
340k
  }
3587
454k
    }
3588
4.27k
  else
3589
4.27k
    {
3590
4.27k
      if ((flags & SEC_DEBUGGING) == 0)
3591
4.19k
  flags |= SEC_ALLOC;
3592
4.27k
    }
3593
3594
458k
  if (section->offset != 0)
3595
339k
    flags |= SEC_HAS_CONTENTS;
3596
458k
  if (section->nreloc != 0)
3597
323k
    flags |= SEC_RELOC;
3598
3599
458k
  bfd_set_section_flags (sec, flags);
3600
3601
458k
  sec->vma = section->addr;
3602
458k
  sec->lma = section->addr;
3603
458k
  sec->size = section->size;
3604
458k
  sec->filepos = section->offset;
3605
458k
  sec->alignment_power = section->align;
3606
458k
  sec->segment_mark = 0;
3607
458k
  sec->reloc_count = section->nreloc;
3608
458k
  sec->rel_filepos = section->reloff;
3609
458k
}
3610
3611
static asection *
3612
bfd_mach_o_make_bfd_section (bfd *abfd,
3613
           const unsigned char *segname,
3614
           const unsigned char *sectname)
3615
458k
{
3616
458k
  const char *sname;
3617
458k
  flagword flags;
3618
3619
458k
  bfd_mach_o_convert_section_name_to_bfd
3620
458k
    (abfd, (const char *)segname, (const char *)sectname, &sname, &flags);
3621
458k
  if (sname == NULL)
3622
0
    return NULL;
3623
3624
458k
  return bfd_make_section_anyway_with_flags (abfd, sname, flags);
3625
458k
}
3626
3627
static asection *
3628
bfd_mach_o_read_section_32 (bfd *abfd, unsigned long prot)
3629
296k
{
3630
296k
  struct mach_o_section_32_external raw;
3631
296k
  asection *sec;
3632
296k
  bfd_mach_o_section *section;
3633
3634
296k
  if (bfd_read (&raw, BFD_MACH_O_SECTION_SIZE, abfd)
3635
296k
      != BFD_MACH_O_SECTION_SIZE)
3636
693
    return NULL;
3637
3638
295k
  sec = bfd_mach_o_make_bfd_section (abfd, raw.segname, raw.sectname);
3639
295k
  if (sec == NULL)
3640
0
    return NULL;
3641
3642
295k
  section = bfd_mach_o_get_mach_o_section (sec);
3643
295k
  memcpy (section->segname, raw.segname, sizeof (raw.segname));
3644
295k
  section->segname[BFD_MACH_O_SEGNAME_SIZE] = 0;
3645
295k
  memcpy (section->sectname, raw.sectname, sizeof (raw.sectname));
3646
295k
  section->sectname[BFD_MACH_O_SECTNAME_SIZE] = 0;
3647
295k
  section->addr = bfd_h_get_32 (abfd, raw.addr);
3648
295k
  section->size = bfd_h_get_32 (abfd, raw.size);
3649
295k
  section->offset = bfd_h_get_32 (abfd, raw.offset);
3650
295k
  section->align = bfd_h_get_32 (abfd, raw.align);
3651
  /* PR 17512: file: 0017eb76.  */
3652
295k
  if (section->align >= 31)
3653
213k
    {
3654
213k
      _bfd_error_handler
3655
213k
  (_("bfd_mach_o_read_section_32: overlarge alignment value: %#lx"),
3656
213k
   section->align);
3657
213k
      section->align = 30;
3658
213k
    }
3659
295k
  section->reloff = bfd_h_get_32 (abfd, raw.reloff);
3660
295k
  section->nreloc = bfd_h_get_32 (abfd, raw.nreloc);
3661
295k
  section->flags = bfd_h_get_32 (abfd, raw.flags);
3662
295k
  section->reserved1 = bfd_h_get_32 (abfd, raw.reserved1);
3663
295k
  section->reserved2 = bfd_h_get_32 (abfd, raw.reserved2);
3664
295k
  section->reserved3 = 0;
3665
3666
295k
  bfd_mach_o_init_section_from_mach_o (sec, prot);
3667
3668
295k
  return sec;
3669
295k
}
3670
3671
static asection *
3672
bfd_mach_o_read_section_64 (bfd *abfd, unsigned long prot)
3673
163k
{
3674
163k
  struct mach_o_section_64_external raw;
3675
163k
  asection *sec;
3676
163k
  bfd_mach_o_section *section;
3677
3678
163k
  if (bfd_read (&raw, BFD_MACH_O_SECTION_64_SIZE, abfd)
3679
163k
      != BFD_MACH_O_SECTION_64_SIZE)
3680
398
    return NULL;
3681
3682
162k
  sec = bfd_mach_o_make_bfd_section (abfd, raw.segname, raw.sectname);
3683
162k
  if (sec == NULL)
3684
0
    return NULL;
3685
3686
162k
  section = bfd_mach_o_get_mach_o_section (sec);
3687
162k
  memcpy (section->segname, raw.segname, sizeof (raw.segname));
3688
162k
  section->segname[BFD_MACH_O_SEGNAME_SIZE] = 0;
3689
162k
  memcpy (section->sectname, raw.sectname, sizeof (raw.sectname));
3690
162k
  section->sectname[BFD_MACH_O_SECTNAME_SIZE] = 0;
3691
162k
  section->addr = bfd_h_get_64 (abfd, raw.addr);
3692
162k
  section->size = bfd_h_get_64 (abfd, raw.size);
3693
162k
  section->offset = bfd_h_get_32 (abfd, raw.offset);
3694
162k
  section->align = bfd_h_get_32 (abfd, raw.align);
3695
162k
  if (section->align >= 63)
3696
89.1k
    {
3697
89.1k
      _bfd_error_handler
3698
89.1k
  (_("bfd_mach_o_read_section_64: overlarge alignment value: %#lx"),
3699
89.1k
   section->align);
3700
89.1k
      section->align = 62;
3701
89.1k
    }
3702
162k
  section->reloff = bfd_h_get_32 (abfd, raw.reloff);
3703
162k
  section->nreloc = bfd_h_get_32 (abfd, raw.nreloc);
3704
162k
  section->flags = bfd_h_get_32 (abfd, raw.flags);
3705
162k
  section->reserved1 = bfd_h_get_32 (abfd, raw.reserved1);
3706
162k
  section->reserved2 = bfd_h_get_32 (abfd, raw.reserved2);
3707
162k
  section->reserved3 = bfd_h_get_32 (abfd, raw.reserved3);
3708
3709
162k
  bfd_mach_o_init_section_from_mach_o (sec, prot);
3710
3711
162k
  return sec;
3712
162k
}
3713
3714
static asection *
3715
bfd_mach_o_read_section (bfd *abfd, unsigned long prot, unsigned int wide)
3716
460k
{
3717
460k
  if (wide)
3718
163k
    return bfd_mach_o_read_section_64 (abfd, prot);
3719
296k
  else
3720
296k
    return bfd_mach_o_read_section_32 (abfd, prot);
3721
460k
}
3722
3723
static bool
3724
bfd_mach_o_read_symtab_symbol (bfd *abfd,
3725
             bfd_mach_o_symtab_command *sym,
3726
             bfd_mach_o_asymbol *s,
3727
             unsigned long i)
3728
4.48k
{
3729
4.48k
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
3730
4.48k
  unsigned int wide = mach_o_wide_p (&mdata->header);
3731
4.48k
  unsigned int symwidth =
3732
4.48k
    wide ? BFD_MACH_O_NLIST_64_SIZE : BFD_MACH_O_NLIST_SIZE;
3733
4.48k
  unsigned int symoff = sym->symoff + (i * symwidth);
3734
4.48k
  struct mach_o_nlist_64_external raw;
3735
4.48k
  unsigned char type = -1;
3736
4.48k
  unsigned char section = -1;
3737
4.48k
  short desc = -1;
3738
4.48k
  symvalue value = -1;
3739
4.48k
  unsigned long stroff = -1;
3740
4.48k
  unsigned int symtype = -1;
3741
3742
4.48k
  BFD_ASSERT (sym->strtab != NULL);
3743
3744
4.48k
  if (bfd_seek (abfd, symoff, SEEK_SET) != 0
3745
4.48k
      || bfd_read (&raw, symwidth, abfd) != symwidth)
3746
0
    {
3747
0
      _bfd_error_handler
3748
  /* xgettext:c-format */
3749
0
  (_("bfd_mach_o_read_symtab_symbol: unable to read %d bytes at %u"),
3750
0
   symwidth, symoff);
3751
0
      return false;
3752
0
    }
3753
3754
4.48k
  stroff = bfd_h_get_32 (abfd, raw.n_strx);
3755
4.48k
  type = bfd_h_get_8 (abfd, raw.n_type);
3756
4.48k
  symtype = type & BFD_MACH_O_N_TYPE;
3757
4.48k
  section = bfd_h_get_8 (abfd, raw.n_sect);
3758
4.48k
  desc = bfd_h_get_16 (abfd, raw.n_desc);
3759
4.48k
  if (wide)
3760
3.04k
    value = bfd_h_get_64 (abfd, raw.n_value);
3761
1.43k
  else
3762
1.43k
    value = bfd_h_get_32 (abfd, raw.n_value);
3763
3764
4.48k
  if (stroff >= sym->strsize)
3765
155
    {
3766
155
      _bfd_error_handler
3767
  /* xgettext:c-format */
3768
155
  (_("bfd_mach_o_read_symtab_symbol: name out of range (%lu >= %u)"),
3769
155
   stroff,
3770
155
   sym->strsize);
3771
155
      return false;
3772
155
    }
3773
3774
4.32k
  s->symbol.the_bfd = abfd;
3775
4.32k
  s->symbol.name = sym->strtab + stroff;
3776
4.32k
  s->symbol.value = value;
3777
4.32k
  s->symbol.flags = 0x0;
3778
4.32k
  s->symbol.udata.i = i;
3779
4.32k
  s->n_type = type;
3780
4.32k
  s->n_sect = section;
3781
4.32k
  s->n_desc = desc;
3782
3783
4.32k
  if (type & BFD_MACH_O_N_STAB)
3784
586
    {
3785
586
      s->symbol.flags |= BSF_DEBUGGING;
3786
586
      s->symbol.section = bfd_und_section_ptr;
3787
586
      switch (type)
3788
586
  {
3789
11
  case N_FUN:
3790
17
  case N_STSYM:
3791
36
  case N_LCSYM:
3792
47
  case N_BNSYM:
3793
49
  case N_SLINE:
3794
57
  case N_ENSYM:
3795
59
  case N_ECOMM:
3796
62
  case N_ECOML:
3797
128
  case N_GSYM:
3798
128
    if ((section > 0) && (section <= mdata->nsects))
3799
16
      {
3800
16
        s->symbol.section = mdata->sections[section - 1]->bfdsection;
3801
16
        s->symbol.value =
3802
16
    s->symbol.value - mdata->sections[section - 1]->addr;
3803
16
      }
3804
128
    break;
3805
586
  }
3806
586
    }
3807
3.74k
  else
3808
3.74k
    {
3809
3.74k
      if (type & (BFD_MACH_O_N_PEXT | BFD_MACH_O_N_EXT))
3810
397
  s->symbol.flags |= BSF_GLOBAL;
3811
3.34k
      else
3812
3.34k
  s->symbol.flags |= BSF_LOCAL;
3813
3814
3.74k
      switch (symtype)
3815
3.74k
  {
3816
3.31k
  case BFD_MACH_O_N_UNDF:
3817
3.31k
    if (type == (BFD_MACH_O_N_UNDF | BFD_MACH_O_N_EXT)
3818
137
        && s->symbol.value != 0)
3819
108
      {
3820
        /* A common symbol.  */
3821
108
        s->symbol.section = bfd_com_section_ptr;
3822
108
        s->symbol.flags = BSF_NO_FLAGS;
3823
108
      }
3824
3.20k
    else
3825
3.20k
      {
3826
3.20k
        s->symbol.section = bfd_und_section_ptr;
3827
3.20k
        if (s->n_desc & BFD_MACH_O_N_WEAK_REF)
3828
174
    s->symbol.flags |= BSF_WEAK;
3829
3.20k
      }
3830
3.31k
    break;
3831
54
  case BFD_MACH_O_N_PBUD:
3832
54
    s->symbol.section = bfd_und_section_ptr;
3833
54
    break;
3834
68
  case BFD_MACH_O_N_ABS:
3835
68
    s->symbol.section = bfd_abs_section_ptr;
3836
68
    break;
3837
41
  case BFD_MACH_O_N_SECT:
3838
41
    if ((section > 0) && (section <= mdata->nsects))
3839
16
      {
3840
16
        s->symbol.section = mdata->sections[section - 1]->bfdsection;
3841
16
        s->symbol.value =
3842
16
    s->symbol.value - mdata->sections[section - 1]->addr;
3843
16
      }
3844
25
    else
3845
25
      {
3846
        /* Mach-O uses 0 to mean "no section"; not an error.  */
3847
25
        if (section != 0)
3848
8
    {
3849
8
      _bfd_error_handler
3850
        /* xgettext:c-format */
3851
8
        (_("bfd_mach_o_read_symtab_symbol: "
3852
8
           "symbol \"%s\" specified invalid section %d (max %lu): "
3853
8
           "setting to undefined"),
3854
8
         s->symbol.name, section, mdata->nsects);
3855
8
    }
3856
25
        s->symbol.section = bfd_und_section_ptr;
3857
25
      }
3858
41
    break;
3859
57
  case BFD_MACH_O_N_INDR:
3860
    /* FIXME: we don't follow the BFD convention as this indirect symbol
3861
       won't be followed by the referenced one.  This looks harmless
3862
       unless we start using the linker.  */
3863
57
    s->symbol.flags |= BSF_INDIRECT;
3864
57
    s->symbol.section = bfd_ind_section_ptr;
3865
57
    s->symbol.value = 0;
3866
57
    break;
3867
210
  default:
3868
210
    _bfd_error_handler
3869
      /* xgettext:c-format */
3870
210
      (_("bfd_mach_o_read_symtab_symbol: "
3871
210
         "symbol \"%s\" specified invalid type field 0x%x: "
3872
210
         "setting to undefined"), s->symbol.name, symtype);
3873
210
    s->symbol.section = bfd_und_section_ptr;
3874
210
    break;
3875
3.74k
  }
3876
3.74k
    }
3877
3878
4.32k
  return true;
3879
4.32k
}
3880
3881
bool
3882
bfd_mach_o_read_symtab_strtab (bfd *abfd)
3883
686
{
3884
686
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
3885
686
  bfd_mach_o_symtab_command *sym = mdata->symtab;
3886
3887
  /* Fail if there is no symtab.  */
3888
686
  if (sym == NULL)
3889
0
    return false;
3890
3891
  /* Success if already loaded.  */
3892
686
  if (sym->strtab)
3893
0
    return true;
3894
3895
686
  if (abfd->flags & BFD_IN_MEMORY)
3896
0
    {
3897
0
      struct bfd_in_memory *b;
3898
3899
0
      b = (struct bfd_in_memory *) abfd->iostream;
3900
3901
0
      if ((sym->stroff + sym->strsize) > b->size)
3902
0
  {
3903
0
    bfd_set_error (bfd_error_file_truncated);
3904
0
    return false;
3905
0
  }
3906
0
      sym->strtab = (char *) b->buffer + sym->stroff;
3907
0
    }
3908
686
  else
3909
686
    {
3910
      /* See PR 21840 for a reproducer.  */
3911
686
      if ((sym->strsize + 1) == 0)
3912
0
  return false;
3913
686
      if (bfd_seek (abfd, sym->stroff, SEEK_SET) != 0)
3914
0
  return false;
3915
686
      sym->strtab = (char *) _bfd_alloc_and_read (abfd, sym->strsize + 1,
3916
686
              sym->strsize);
3917
686
      if (sym->strtab == NULL)
3918
0
  return false;
3919
3920
      /* Zero terminate the string table.  */
3921
686
      sym->strtab[sym->strsize] = 0;
3922
686
    }
3923
3924
686
  return true;
3925
686
}
3926
3927
bool
3928
bfd_mach_o_read_symtab_symbols (bfd *abfd)
3929
1.16k
{
3930
1.16k
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
3931
1.16k
  bfd_mach_o_symtab_command *sym = mdata->symtab;
3932
1.16k
  unsigned long i;
3933
1.16k
  size_t amt;
3934
1.16k
  ufile_ptr filesize;
3935
3936
1.16k
  if (sym == NULL || sym->nsyms == 0 || sym->symbols)
3937
    /* Return now if there are no symbols or if already loaded.  */
3938
470
    return true;
3939
3940
690
  filesize = bfd_get_file_size (abfd);
3941
690
  if (filesize != 0)
3942
690
    {
3943
690
      unsigned int wide = mach_o_wide_p (&mdata->header);
3944
690
      unsigned int symwidth
3945
690
  = wide ? BFD_MACH_O_NLIST_64_SIZE : BFD_MACH_O_NLIST_SIZE;
3946
3947
690
      if (sym->symoff > filesize
3948
690
    || sym->nsyms > (filesize - sym->symoff) / symwidth)
3949
4
  {
3950
4
    bfd_set_error (bfd_error_file_truncated);
3951
4
    sym->nsyms = 0;
3952
4
    return false;
3953
4
  }
3954
690
    }
3955
686
  if (_bfd_mul_overflow (sym->nsyms, sizeof (bfd_mach_o_asymbol), &amt)
3956
686
      || (sym->symbols = bfd_alloc (abfd, amt)) == NULL)
3957
0
    {
3958
0
      bfd_set_error (bfd_error_no_memory);
3959
0
      sym->nsyms = 0;
3960
0
      return false;
3961
0
    }
3962
3963
686
  if (!bfd_mach_o_read_symtab_strtab (abfd))
3964
0
    goto fail;
3965
3966
5.01k
  for (i = 0; i < sym->nsyms; i++)
3967
4.48k
    if (!bfd_mach_o_read_symtab_symbol (abfd, sym, &sym->symbols[i], i))
3968
155
      goto fail;
3969
3970
531
  return true;
3971
3972
155
 fail:
3973
155
  bfd_release (abfd, sym->symbols);
3974
155
  sym->symbols = NULL;
3975
155
  sym->nsyms = 0;
3976
155
  return false;
3977
686
}
3978
3979
static const char *
3980
bfd_mach_o_i386_flavour_string (unsigned int flavour)
3981
3.61k
{
3982
3.61k
  switch ((int) flavour)
3983
3.61k
    {
3984
177
    case BFD_MACH_O_x86_THREAD_STATE32:    return "x86_THREAD_STATE32";
3985
45
    case BFD_MACH_O_x86_FLOAT_STATE32:     return "x86_FLOAT_STATE32";
3986
12
    case BFD_MACH_O_x86_EXCEPTION_STATE32: return "x86_EXCEPTION_STATE32";
3987
218
    case BFD_MACH_O_x86_THREAD_STATE64:    return "x86_THREAD_STATE64";
3988
4
    case BFD_MACH_O_x86_FLOAT_STATE64:     return "x86_FLOAT_STATE64";
3989
15
    case BFD_MACH_O_x86_EXCEPTION_STATE64: return "x86_EXCEPTION_STATE64";
3990
16
    case BFD_MACH_O_x86_THREAD_STATE:      return "x86_THREAD_STATE";
3991
19
    case BFD_MACH_O_x86_FLOAT_STATE:       return "x86_FLOAT_STATE";
3992
11
    case BFD_MACH_O_x86_EXCEPTION_STATE:   return "x86_EXCEPTION_STATE";
3993
11
    case BFD_MACH_O_x86_DEBUG_STATE32:     return "x86_DEBUG_STATE32";
3994
5
    case BFD_MACH_O_x86_DEBUG_STATE64:     return "x86_DEBUG_STATE64";
3995
16
    case BFD_MACH_O_x86_DEBUG_STATE:       return "x86_DEBUG_STATE";
3996
5
    case BFD_MACH_O_x86_THREAD_STATE_NONE: return "x86_THREAD_STATE_NONE";
3997
3.06k
    default: return "UNKNOWN";
3998
3.61k
    }
3999
3.61k
}
4000
4001
static const char *
4002
bfd_mach_o_ppc_flavour_string (unsigned int flavour)
4003
1.46k
{
4004
1.46k
  switch ((int) flavour)
4005
1.46k
    {
4006
103
    case BFD_MACH_O_PPC_THREAD_STATE:      return "PPC_THREAD_STATE";
4007
15
    case BFD_MACH_O_PPC_FLOAT_STATE:       return "PPC_FLOAT_STATE";
4008
21
    case BFD_MACH_O_PPC_EXCEPTION_STATE:   return "PPC_EXCEPTION_STATE";
4009
33
    case BFD_MACH_O_PPC_VECTOR_STATE:      return "PPC_VECTOR_STATE";
4010
47
    case BFD_MACH_O_PPC_THREAD_STATE64:    return "PPC_THREAD_STATE64";
4011
17
    case BFD_MACH_O_PPC_EXCEPTION_STATE64: return "PPC_EXCEPTION_STATE64";
4012
1.23k
    default: return "UNKNOWN";
4013
1.46k
    }
4014
1.46k
}
4015
4016
static unsigned char *
4017
bfd_mach_o_alloc_and_read (bfd *abfd, file_ptr filepos,
4018
         size_t size, size_t extra)
4019
12.8k
{
4020
12.8k
  if (bfd_seek (abfd, filepos, SEEK_SET) != 0)
4021
0
    return NULL;
4022
12.8k
  unsigned char *ret = _bfd_alloc_and_read (abfd, size + extra, size);
4023
12.8k
  if (ret && extra != 0)
4024
12.4k
    memset (ret + size, 0, extra);
4025
12.8k
  return ret;
4026
12.8k
}
4027
4028
static bool
4029
bfd_mach_o_read_dylinker (bfd *abfd, bfd_mach_o_load_command *command)
4030
4.61k
{
4031
4.61k
  bfd_mach_o_dylinker_command *cmd = &command->command.dylinker;
4032
4.61k
  struct mach_o_str_command_external raw;
4033
4.61k
  unsigned int nameoff;
4034
4.61k
  size_t namelen;
4035
4036
4.61k
  if (command->len < sizeof (raw) + 8)
4037
8
    return false;
4038
4.61k
  if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4039
37
    return false;
4040
4041
4.57k
  nameoff = bfd_h_get_32 (abfd, raw.str);
4042
4.57k
  if (nameoff > command->len)
4043
33
    return false;
4044
4045
4.54k
  cmd->name_offset = nameoff;
4046
4.54k
  namelen = command->len - nameoff;
4047
4.54k
  nameoff += command->offset;
4048
4.54k
  cmd->name_str = (char *) bfd_mach_o_alloc_and_read (abfd, nameoff,
4049
4.54k
                  namelen, 1);
4050
4.54k
  return cmd->name_str != NULL;
4051
4.57k
}
4052
4053
static bool
4054
bfd_mach_o_read_dylib (bfd *abfd, bfd_mach_o_load_command *command)
4055
5.57k
{
4056
5.57k
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
4057
5.57k
  bfd_mach_o_dylib_command *cmd = &command->command.dylib;
4058
5.57k
  struct mach_o_dylib_command_external raw;
4059
5.57k
  unsigned int nameoff;
4060
5.57k
  size_t namelen;
4061
5.57k
  file_ptr pos;
4062
4063
5.57k
  if (command->len < sizeof (raw) + 8)
4064
9
    return false;
4065
5.56k
  switch (command->type)
4066
5.56k
    {
4067
711
    case BFD_MACH_O_LC_LOAD_DYLIB:
4068
1.48k
    case BFD_MACH_O_LC_LAZY_LOAD_DYLIB:
4069
2.07k
    case BFD_MACH_O_LC_LOAD_WEAK_DYLIB:
4070
2.53k
    case BFD_MACH_O_LC_ID_DYLIB:
4071
2.80k
    case BFD_MACH_O_LC_REEXPORT_DYLIB:
4072
5.56k
    case BFD_MACH_O_LC_LOAD_UPWARD_DYLIB:
4073
5.56k
      break;
4074
0
    default:
4075
0
      BFD_FAIL ();
4076
0
      return false;
4077
5.56k
    }
4078
4079
5.56k
  if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4080
87
    return false;
4081
4082
5.48k
  nameoff = bfd_h_get_32 (abfd, raw.name);
4083
5.48k
  if (nameoff > command->len)
4084
43
    return false;
4085
5.43k
  cmd->timestamp = bfd_h_get_32 (abfd, raw.timestamp);
4086
5.43k
  cmd->current_version = bfd_h_get_32 (abfd, raw.current_version);
4087
5.43k
  cmd->compatibility_version = bfd_h_get_32 (abfd, raw.compatibility_version);
4088
4089
5.43k
  cmd->name_offset = command->offset + nameoff;
4090
5.43k
  namelen = command->len - nameoff;
4091
5.43k
  pos = mdata->hdr_offset + cmd->name_offset;
4092
5.43k
  cmd->name_str = (char *) bfd_mach_o_alloc_and_read (abfd, pos, namelen, 1);
4093
5.43k
  return cmd->name_str != NULL;
4094
5.48k
}
4095
4096
static bool
4097
bfd_mach_o_read_prebound_dylib (bfd *abfd,
4098
        bfd_mach_o_load_command *command)
4099
564
{
4100
564
  bfd_mach_o_prebound_dylib_command *cmd = &command->command.prebound_dylib;
4101
564
  struct mach_o_prebound_dylib_command_external raw;
4102
564
  unsigned int nameoff;
4103
564
  unsigned int modoff;
4104
564
  unsigned int str_len;
4105
564
  unsigned char *str;
4106
4107
564
  if (command->len < sizeof (raw) + 8)
4108
7
    return false;
4109
557
  if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4110
20
    return false;
4111
4112
537
  nameoff = bfd_h_get_32 (abfd, raw.name);
4113
537
  modoff = bfd_h_get_32 (abfd, raw.linked_modules);
4114
537
  if (nameoff > command->len || modoff > command->len)
4115
111
    return false;
4116
4117
426
  str_len = command->len - sizeof (raw);
4118
426
  str = _bfd_alloc_and_read (abfd, str_len, str_len);
4119
426
  if (str == NULL)
4120
135
    return false;
4121
4122
291
  cmd->name_offset = command->offset + nameoff;
4123
291
  cmd->nmodules = bfd_h_get_32 (abfd, raw.nmodules);
4124
291
  cmd->linked_modules_offset = command->offset + modoff;
4125
4126
291
  cmd->name_str = (char *)str + nameoff - (sizeof (raw) + BFD_MACH_O_LC_SIZE);
4127
291
  cmd->linked_modules = str + modoff - (sizeof (raw) + BFD_MACH_O_LC_SIZE);
4128
291
  return true;
4129
426
}
4130
4131
static bool
4132
bfd_mach_o_read_prebind_cksum (bfd *abfd,
4133
             bfd_mach_o_load_command *command)
4134
3.22k
{
4135
3.22k
  bfd_mach_o_prebind_cksum_command *cmd = &command->command.prebind_cksum;
4136
3.22k
  struct mach_o_prebind_cksum_command_external raw;
4137
4138
3.22k
  if (command->len < sizeof (raw) + 8)
4139
9
    return false;
4140
3.21k
  if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4141
9
    return false;
4142
4143
3.20k
  cmd->cksum = bfd_get_32 (abfd, raw.cksum);
4144
3.20k
  return true;
4145
3.21k
}
4146
4147
static bool
4148
bfd_mach_o_read_twolevel_hints (bfd *abfd,
4149
        bfd_mach_o_load_command *command)
4150
1.16k
{
4151
1.16k
  bfd_mach_o_twolevel_hints_command *cmd = &command->command.twolevel_hints;
4152
1.16k
  struct mach_o_twolevel_hints_command_external raw;
4153
4154
1.16k
  if (command->len < sizeof (raw) + 8)
4155
9
    return false;
4156
1.15k
  if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4157
21
    return false;
4158
4159
1.13k
  cmd->offset = bfd_get_32 (abfd, raw.offset);
4160
1.13k
  cmd->nhints = bfd_get_32 (abfd, raw.nhints);
4161
1.13k
  return true;
4162
1.15k
}
4163
4164
static bool
4165
bfd_mach_o_read_fvmlib (bfd *abfd, bfd_mach_o_load_command *command)
4166
903
{
4167
903
  bfd_mach_o_fvmlib_command *fvm = &command->command.fvmlib;
4168
903
  struct mach_o_fvmlib_command_external raw;
4169
903
  unsigned int nameoff;
4170
903
  size_t namelen;
4171
4172
903
  if (command->len < sizeof (raw) + 8)
4173
8
    return false;
4174
895
  if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4175
33
    return false;
4176
4177
862
  nameoff = bfd_h_get_32 (abfd, raw.name);
4178
862
  if (nameoff > command->len)
4179
26
    return false;
4180
836
  fvm->minor_version = bfd_h_get_32 (abfd, raw.minor_version);
4181
836
  fvm->header_addr = bfd_h_get_32 (abfd, raw.header_addr);
4182
4183
836
  fvm->name_offset = command->offset + nameoff;
4184
836
  namelen = command->len - nameoff;
4185
836
  fvm->name_str = (char *) bfd_mach_o_alloc_and_read (abfd, fvm->name_offset,
4186
836
                  namelen, 1);
4187
836
  return fvm->name_str != NULL;
4188
862
}
4189
4190
static bool
4191
bfd_mach_o_read_thread (bfd *abfd, bfd_mach_o_load_command *command)
4192
707
{
4193
707
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
4194
707
  bfd_mach_o_thread_command *cmd = &command->command.thread;
4195
707
  unsigned int offset;
4196
707
  unsigned int nflavours;
4197
707
  unsigned int i;
4198
707
  struct mach_o_thread_command_external raw;
4199
707
  size_t amt;
4200
4201
707
  BFD_ASSERT ((command->type == BFD_MACH_O_LC_THREAD)
4202
707
        || (command->type == BFD_MACH_O_LC_UNIXTHREAD));
4203
4204
  /* Count the number of threads.  */
4205
707
  offset = 8;
4206
707
  nflavours = 0;
4207
8.04k
  while (offset + sizeof (raw) <= command->len)
4208
7.48k
    {
4209
7.48k
      unsigned int count;
4210
4211
7.48k
      if (bfd_seek (abfd, command->offset + offset, SEEK_SET) != 0
4212
7.48k
    || bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4213
99
  return false;
4214
4215
7.38k
      count = bfd_h_get_32 (abfd, raw.count);
4216
7.38k
      if (count > (unsigned) -1 / 4
4217
7.36k
    || command->len - (offset + sizeof (raw)) < count * 4)
4218
46
  return false;
4219
7.34k
      offset += sizeof (raw) + count * 4;
4220
7.34k
      nflavours++;
4221
7.34k
    }
4222
562
  if (nflavours == 0 || offset != command->len)
4223
20
    return false;
4224
4225
  /* Allocate threads.  */
4226
542
  if (_bfd_mul_overflow (nflavours, sizeof (bfd_mach_o_thread_flavour), &amt))
4227
0
    {
4228
0
      bfd_set_error (bfd_error_file_too_big);
4229
0
      return false;
4230
0
    }
4231
542
  cmd->flavours = bfd_alloc (abfd, amt);
4232
542
  if (cmd->flavours == NULL)
4233
0
    return false;
4234
542
  cmd->nflavours = nflavours;
4235
4236
542
  offset = 8;
4237
542
  nflavours = 0;
4238
6.44k
  while (offset != command->len)
4239
5.90k
    {
4240
5.90k
      if (bfd_seek (abfd, command->offset + offset, SEEK_SET) != 0
4241
5.90k
    || bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4242
0
  return false;
4243
4244
5.90k
      cmd->flavours[nflavours].flavour = bfd_h_get_32 (abfd, raw.flavour);
4245
5.90k
      cmd->flavours[nflavours].offset = command->offset + offset + sizeof (raw);
4246
5.90k
      cmd->flavours[nflavours].size = bfd_h_get_32 (abfd, raw.count) * 4;
4247
5.90k
      offset += cmd->flavours[nflavours].size + sizeof (raw);
4248
5.90k
      nflavours++;
4249
5.90k
    }
4250
4251
6.44k
  for (i = 0; i < nflavours; i++)
4252
5.90k
    {
4253
5.90k
      asection *bfdsec;
4254
5.90k
      size_t snamelen;
4255
5.90k
      char *sname;
4256
5.90k
      const char *flavourstr;
4257
5.90k
      const char *prefix = "LC_THREAD";
4258
5.90k
      unsigned int j = 0;
4259
4260
5.90k
      switch (mdata->header.cputype)
4261
5.90k
  {
4262
815
  case BFD_MACH_O_CPU_TYPE_POWERPC:
4263
1.46k
  case BFD_MACH_O_CPU_TYPE_POWERPC_64:
4264
1.46k
    flavourstr =
4265
1.46k
      bfd_mach_o_ppc_flavour_string (cmd->flavours[i].flavour);
4266
1.46k
    break;
4267
1.45k
  case BFD_MACH_O_CPU_TYPE_I386:
4268
3.61k
  case BFD_MACH_O_CPU_TYPE_X86_64:
4269
3.61k
    flavourstr =
4270
3.61k
      bfd_mach_o_i386_flavour_string (cmd->flavours[i].flavour);
4271
3.61k
    break;
4272
816
  default:
4273
816
    flavourstr = "UNKNOWN_ARCHITECTURE";
4274
816
    break;
4275
5.90k
  }
4276
4277
5.90k
      snamelen = strlen (prefix) + 1 + 20 + 1 + strlen (flavourstr) + 1;
4278
5.90k
      sname = bfd_alloc (abfd, snamelen);
4279
5.90k
      if (sname == NULL)
4280
0
  return false;
4281
4282
5.90k
      for (;;)
4283
78.5k
  {
4284
78.5k
    sprintf (sname, "%s.%s.%u", prefix, flavourstr, j);
4285
78.5k
    if (bfd_get_section_by_name (abfd, sname) == NULL)
4286
5.90k
      break;
4287
72.6k
    j++;
4288
72.6k
  }
4289
4290
5.90k
      bfdsec = bfd_make_section_with_flags (abfd, sname, SEC_HAS_CONTENTS);
4291
4292
5.90k
      bfdsec->vma = 0;
4293
5.90k
      bfdsec->lma = 0;
4294
5.90k
      bfdsec->size = cmd->flavours[i].size;
4295
5.90k
      bfdsec->filepos = cmd->flavours[i].offset;
4296
5.90k
      bfdsec->alignment_power = 0x0;
4297
4298
5.90k
      cmd->section = bfdsec;
4299
5.90k
    }
4300
4301
542
  return true;
4302
542
}
4303
4304
static bool
4305
bfd_mach_o_read_dysymtab (bfd *abfd, bfd_mach_o_load_command *command,
4306
        ufile_ptr filesize)
4307
2.45k
{
4308
2.45k
  bfd_mach_o_dysymtab_command *cmd = &command->command.dysymtab;
4309
2.45k
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
4310
4311
2.45k
  BFD_ASSERT (command->type == BFD_MACH_O_LC_DYSYMTAB);
4312
4313
2.45k
  {
4314
2.45k
    struct mach_o_dysymtab_command_external raw;
4315
4316
2.45k
    if (command->len < sizeof (raw) + 8)
4317
15
      return false;
4318
2.43k
    if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4319
100
      return false;
4320
4321
2.33k
    cmd->ilocalsym = bfd_h_get_32 (abfd, raw.ilocalsym);
4322
2.33k
    cmd->nlocalsym = bfd_h_get_32 (abfd, raw.nlocalsym);
4323
2.33k
    cmd->iextdefsym = bfd_h_get_32 (abfd, raw.iextdefsym);
4324
2.33k
    cmd->nextdefsym = bfd_h_get_32 (abfd, raw.nextdefsym);
4325
2.33k
    cmd->iundefsym = bfd_h_get_32 (abfd, raw.iundefsym);
4326
2.33k
    cmd->nundefsym = bfd_h_get_32 (abfd, raw.nundefsym);
4327
2.33k
    cmd->tocoff = bfd_h_get_32 (abfd, raw.tocoff);
4328
2.33k
    cmd->ntoc = bfd_h_get_32 (abfd, raw.ntoc);
4329
2.33k
    cmd->modtaboff = bfd_h_get_32 (abfd, raw.modtaboff);
4330
2.33k
    cmd->nmodtab = bfd_h_get_32 (abfd, raw.nmodtab);
4331
2.33k
    cmd->extrefsymoff = bfd_h_get_32 (abfd, raw.extrefsymoff);
4332
2.33k
    cmd->nextrefsyms = bfd_h_get_32 (abfd, raw.nextrefsyms);
4333
2.33k
    cmd->indirectsymoff = bfd_h_get_32 (abfd, raw.indirectsymoff);
4334
2.33k
    cmd->nindirectsyms = bfd_h_get_32 (abfd, raw.nindirectsyms);
4335
2.33k
    cmd->extreloff = bfd_h_get_32 (abfd, raw.extreloff);
4336
2.33k
    cmd->nextrel = bfd_h_get_32 (abfd, raw.nextrel);
4337
2.33k
    cmd->locreloff = bfd_h_get_32 (abfd, raw.locreloff);
4338
2.33k
    cmd->nlocrel = bfd_h_get_32 (abfd, raw.nlocrel);
4339
2.33k
  }
4340
4341
2.33k
  if (cmd->nmodtab != 0)
4342
1.60k
    {
4343
1.60k
      unsigned int i;
4344
1.60k
      int wide = bfd_mach_o_wide_p (abfd);
4345
1.60k
      unsigned int module_len = wide ? 56 : 52;
4346
1.60k
      size_t amt;
4347
4348
1.60k
      if (cmd->modtaboff > filesize
4349
1.45k
    || cmd->nmodtab > (filesize - cmd->modtaboff) / module_len)
4350
253
  {
4351
253
    bfd_set_error (bfd_error_file_truncated);
4352
253
    return false;
4353
253
  }
4354
1.35k
      if (_bfd_mul_overflow (cmd->nmodtab,
4355
1.35k
           sizeof (bfd_mach_o_dylib_module), &amt))
4356
0
  {
4357
0
    bfd_set_error (bfd_error_file_too_big);
4358
0
    return false;
4359
0
  }
4360
1.35k
      cmd->dylib_module = bfd_alloc (abfd, amt);
4361
1.35k
      if (cmd->dylib_module == NULL)
4362
0
  return false;
4363
4364
1.35k
      if (bfd_seek (abfd, cmd->modtaboff, SEEK_SET) != 0)
4365
0
  return false;
4366
4367
14.6k
      for (i = 0; i < cmd->nmodtab; i++)
4368
13.2k
  {
4369
13.2k
    bfd_mach_o_dylib_module *module = &cmd->dylib_module[i];
4370
13.2k
    unsigned long v;
4371
13.2k
    unsigned char buf[56];
4372
4373
13.2k
    if (bfd_read (buf, module_len, abfd) != module_len)
4374
34
      return false;
4375
4376
13.2k
    module->module_name_idx = bfd_h_get_32 (abfd, buf + 0);
4377
13.2k
    module->iextdefsym = bfd_h_get_32 (abfd, buf + 4);
4378
13.2k
    module->nextdefsym = bfd_h_get_32 (abfd, buf + 8);
4379
13.2k
    module->irefsym = bfd_h_get_32 (abfd, buf + 12);
4380
13.2k
    module->nrefsym = bfd_h_get_32 (abfd, buf + 16);
4381
13.2k
    module->ilocalsym = bfd_h_get_32 (abfd, buf + 20);
4382
13.2k
    module->nlocalsym = bfd_h_get_32 (abfd, buf + 24);
4383
13.2k
    module->iextrel = bfd_h_get_32 (abfd, buf + 28);
4384
13.2k
    module->nextrel = bfd_h_get_32 (abfd, buf + 32);
4385
13.2k
    v = bfd_h_get_32 (abfd, buf +36);
4386
13.2k
    module->iinit = v & 0xffff;
4387
13.2k
    module->iterm = (v >> 16) & 0xffff;
4388
13.2k
    v = bfd_h_get_32 (abfd, buf + 40);
4389
13.2k
    module->ninit = v & 0xffff;
4390
13.2k
    module->nterm = (v >> 16) & 0xffff;
4391
13.2k
    if (wide)
4392
11.5k
      {
4393
11.5k
        module->objc_module_info_size = bfd_h_get_32 (abfd, buf + 44);
4394
11.5k
        module->objc_module_info_addr = bfd_h_get_64 (abfd, buf + 48);
4395
11.5k
      }
4396
1.67k
    else
4397
1.67k
      {
4398
1.67k
        module->objc_module_info_addr = bfd_h_get_32 (abfd, buf + 44);
4399
1.67k
        module->objc_module_info_size = bfd_h_get_32 (abfd, buf + 48);
4400
1.67k
      }
4401
13.2k
  }
4402
1.35k
    }
4403
4404
2.04k
  if (cmd->ntoc != 0)
4405
1.26k
    {
4406
1.26k
      unsigned long i;
4407
1.26k
      size_t amt;
4408
1.26k
      struct mach_o_dylib_table_of_contents_external raw;
4409
4410
1.26k
      if (cmd->tocoff > filesize
4411
1.19k
    || cmd->ntoc > (filesize - cmd->tocoff) / sizeof (raw))
4412
94
  {
4413
94
    bfd_set_error (bfd_error_file_truncated);
4414
94
    return false;
4415
94
  }
4416
1.16k
      if (_bfd_mul_overflow (cmd->ntoc,
4417
1.16k
           sizeof (bfd_mach_o_dylib_table_of_content), &amt))
4418
0
  {
4419
0
    bfd_set_error (bfd_error_file_too_big);
4420
0
    return false;
4421
0
  }
4422
1.16k
      cmd->dylib_toc = bfd_alloc (abfd, amt);
4423
1.16k
      if (cmd->dylib_toc == NULL)
4424
0
  return false;
4425
4426
1.16k
      if (bfd_seek (abfd, cmd->tocoff, SEEK_SET) != 0)
4427
0
  return false;
4428
4429
69.6k
      for (i = 0; i < cmd->ntoc; i++)
4430
68.4k
  {
4431
68.4k
    bfd_mach_o_dylib_table_of_content *toc = &cmd->dylib_toc[i];
4432
4433
68.4k
    if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4434
7
      return false;
4435
4436
68.4k
    toc->symbol_index = bfd_h_get_32 (abfd, raw.symbol_index);
4437
68.4k
    toc->module_index = bfd_h_get_32 (abfd, raw.module_index);
4438
68.4k
  }
4439
1.16k
    }
4440
4441
1.94k
  if (cmd->nindirectsyms != 0)
4442
1.54k
    {
4443
1.54k
      unsigned int i;
4444
1.54k
      size_t amt;
4445
4446
1.54k
      if (cmd->indirectsymoff > filesize
4447
1.50k
    || cmd->nindirectsyms > (filesize - cmd->indirectsymoff) / 4)
4448
164
  {
4449
164
    bfd_set_error (bfd_error_file_truncated);
4450
164
    return false;
4451
164
  }
4452
1.38k
      if (_bfd_mul_overflow (cmd->nindirectsyms, sizeof (unsigned int), &amt))
4453
0
  {
4454
0
    bfd_set_error (bfd_error_file_too_big);
4455
0
    return false;
4456
0
  }
4457
1.38k
      cmd->indirect_syms = bfd_alloc (abfd, amt);
4458
1.38k
      if (cmd->indirect_syms == NULL)
4459
0
  return false;
4460
4461
1.38k
      if (bfd_seek (abfd, cmd->indirectsymoff, SEEK_SET) != 0)
4462
0
  return false;
4463
4464
9.36k
      for (i = 0; i < cmd->nindirectsyms; i++)
4465
8.00k
  {
4466
8.00k
    unsigned char raw[4];
4467
8.00k
    unsigned int *is = &cmd->indirect_syms[i];
4468
4469
8.00k
    if (bfd_read (raw, sizeof (raw), abfd) != sizeof (raw))
4470
12
      return false;
4471
4472
7.98k
    *is = bfd_h_get_32 (abfd, raw);
4473
7.98k
  }
4474
1.38k
    }
4475
4476
1.77k
  if (cmd->nextrefsyms != 0)
4477
1.57k
    {
4478
1.57k
      unsigned long v;
4479
1.57k
      unsigned int i;
4480
1.57k
      size_t amt;
4481
4482
1.57k
      if (cmd->extrefsymoff > filesize
4483
1.47k
    || cmd->nextrefsyms > (filesize - cmd->extrefsymoff) / 4)
4484
272
  {
4485
272
    bfd_set_error (bfd_error_file_truncated);
4486
272
    return false;
4487
272
  }
4488
1.30k
      if (_bfd_mul_overflow (cmd->nextrefsyms,
4489
1.30k
           sizeof (bfd_mach_o_dylib_reference), &amt))
4490
0
  {
4491
0
    bfd_set_error (bfd_error_file_too_big);
4492
0
    return false;
4493
0
  }
4494
1.30k
      cmd->ext_refs = bfd_alloc (abfd, amt);
4495
1.30k
      if (cmd->ext_refs == NULL)
4496
0
  return false;
4497
4498
1.30k
      if (bfd_seek (abfd, cmd->extrefsymoff, SEEK_SET) != 0)
4499
0
  return false;
4500
4501
141k
      for (i = 0; i < cmd->nextrefsyms; i++)
4502
140k
  {
4503
140k
    unsigned char raw[4];
4504
140k
    bfd_mach_o_dylib_reference *ref = &cmd->ext_refs[i];
4505
4506
140k
    if (bfd_read (raw, sizeof (raw), abfd) != sizeof (raw))
4507
17
      return false;
4508
4509
    /* Fields isym and flags are written as bit-fields, thus we need
4510
       a specific processing for endianness.  */
4511
140k
    v = bfd_h_get_32 (abfd, raw);
4512
140k
    if (bfd_big_endian (abfd))
4513
819
      {
4514
819
        ref->isym = (v >> 8) & 0xffffff;
4515
819
        ref->flags = v & 0xff;
4516
819
      }
4517
139k
    else
4518
139k
      {
4519
139k
        ref->isym = v & 0xffffff;
4520
139k
        ref->flags = (v >> 24) & 0xff;
4521
139k
      }
4522
140k
  }
4523
1.30k
    }
4524
4525
1.48k
  if (mdata->dysymtab)
4526
18
    return false;
4527
1.46k
  mdata->dysymtab = cmd;
4528
4529
1.46k
  return true;
4530
1.48k
}
4531
4532
static bool
4533
bfd_mach_o_read_symtab (bfd *abfd, bfd_mach_o_load_command *command,
4534
      ufile_ptr filesize)
4535
1.99k
{
4536
1.99k
  bfd_mach_o_symtab_command *symtab = &command->command.symtab;
4537
1.99k
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
4538
1.99k
  struct mach_o_symtab_command_external raw;
4539
4540
1.99k
  BFD_ASSERT (command->type == BFD_MACH_O_LC_SYMTAB);
4541
4542
1.99k
  if (command->len < sizeof (raw) + 8)
4543
10
    return false;
4544
1.98k
  if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4545
29
    return false;
4546
4547
1.96k
  symtab->symoff = bfd_h_get_32 (abfd, raw.symoff);
4548
1.96k
  symtab->nsyms = bfd_h_get_32 (abfd, raw.nsyms);
4549
1.96k
  symtab->stroff = bfd_h_get_32 (abfd, raw.stroff);
4550
1.96k
  symtab->strsize = bfd_h_get_32 (abfd, raw.strsize);
4551
1.96k
  symtab->symbols = NULL;
4552
1.96k
  symtab->strtab = NULL;
4553
4554
1.96k
  if (symtab->symoff > filesize
4555
1.91k
      || symtab->nsyms > (filesize - symtab->symoff) / BFD_MACH_O_NLIST_SIZE
4556
1.82k
      || symtab->stroff > filesize
4557
1.77k
      || symtab->strsize > filesize - symtab->stroff)
4558
274
    {
4559
274
      bfd_set_error (bfd_error_file_truncated);
4560
274
      return false;
4561
274
    }
4562
4563
1.68k
  if (symtab->nsyms != 0)
4564
1.60k
    abfd->flags |= HAS_SYMS;
4565
4566
1.68k
  if (mdata->symtab)
4567
20
    return false;
4568
1.66k
  mdata->symtab = symtab;
4569
1.66k
  return true;
4570
1.68k
}
4571
4572
static bool
4573
bfd_mach_o_read_uuid (bfd *abfd, bfd_mach_o_load_command *command)
4574
2.01k
{
4575
2.01k
  bfd_mach_o_uuid_command *cmd = &command->command.uuid;
4576
4577
2.01k
  BFD_ASSERT (command->type == BFD_MACH_O_LC_UUID);
4578
4579
2.01k
  if (command->len < 16 + 8)
4580
11
    return false;
4581
2.00k
  if (bfd_read (cmd->uuid, 16, abfd) != 16)
4582
12
    return false;
4583
4584
1.99k
  return true;
4585
2.00k
}
4586
4587
static bool
4588
bfd_mach_o_read_linkedit (bfd *abfd, bfd_mach_o_load_command *command)
4589
15.7k
{
4590
15.7k
  bfd_mach_o_linkedit_command *cmd = &command->command.linkedit;
4591
15.7k
  struct mach_o_linkedit_data_command_external raw;
4592
4593
15.7k
  if (command->len < sizeof (raw) + 8)
4594
11
    return false;
4595
15.7k
  if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4596
72
    return false;
4597
4598
15.7k
  cmd->dataoff = bfd_get_32 (abfd, raw.dataoff);
4599
15.7k
  cmd->datasize = bfd_get_32 (abfd, raw.datasize);
4600
15.7k
  return true;
4601
15.7k
}
4602
4603
static bool
4604
bfd_mach_o_read_str (bfd *abfd, bfd_mach_o_load_command *command)
4605
2.13k
{
4606
2.13k
  bfd_mach_o_str_command *cmd = &command->command.str;
4607
2.13k
  struct mach_o_str_command_external raw;
4608
2.13k
  unsigned long off;
4609
4610
2.13k
  if (command->len < sizeof (raw) + 8)
4611
8
    return false;
4612
2.12k
  if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4613
37
    return false;
4614
4615
2.08k
  off = bfd_get_32 (abfd, raw.str);
4616
2.08k
  if (off > command->len)
4617
64
    return false;
4618
4619
2.02k
  cmd->stroff = command->offset + off;
4620
2.02k
  cmd->str_len = command->len - off;
4621
2.02k
  cmd->str = (char *) bfd_mach_o_alloc_and_read (abfd, cmd->stroff,
4622
2.02k
             cmd->str_len, 1);
4623
2.02k
  return cmd->str != NULL;
4624
2.08k
}
4625
4626
static bool
4627
bfd_mach_o_read_dyld_content (bfd *abfd, bfd_mach_o_dyld_info_command *cmd)
4628
16
{
4629
  /* Read rebase content.  */
4630
16
  if (cmd->rebase_content == NULL && cmd->rebase_size != 0)
4631
8
    {
4632
8
      cmd->rebase_content
4633
8
  = bfd_mach_o_alloc_and_read (abfd, cmd->rebase_off,
4634
8
             cmd->rebase_size, 0);
4635
8
      if (cmd->rebase_content == NULL)
4636
0
  return false;
4637
8
    }
4638
4639
  /* Read bind content.  */
4640
16
  if (cmd->bind_content == NULL && cmd->bind_size != 0)
4641
7
    {
4642
7
      cmd->bind_content
4643
7
  = bfd_mach_o_alloc_and_read (abfd, cmd->bind_off,
4644
7
             cmd->bind_size, 0);
4645
7
      if (cmd->bind_content == NULL)
4646
0
  return false;
4647
7
    }
4648
4649
  /* Read weak bind content.  */
4650
16
  if (cmd->weak_bind_content == NULL && cmd->weak_bind_size != 0)
4651
0
    {
4652
0
      cmd->weak_bind_content
4653
0
  = bfd_mach_o_alloc_and_read (abfd, cmd->weak_bind_off,
4654
0
             cmd->weak_bind_size, 0);
4655
0
      if (cmd->weak_bind_content == NULL)
4656
0
  return false;
4657
0
    }
4658
4659
  /* Read lazy bind content.  */
4660
16
  if (cmd->lazy_bind_content == NULL && cmd->lazy_bind_size != 0)
4661
7
    {
4662
7
      cmd->lazy_bind_content
4663
7
  = bfd_mach_o_alloc_and_read (abfd, cmd->lazy_bind_off,
4664
7
             cmd->lazy_bind_size, 0);
4665
7
      if (cmd->lazy_bind_content == NULL)
4666
0
  return false;
4667
7
    }
4668
4669
  /* Read export content.  */
4670
16
  if (cmd->export_content == NULL && cmd->export_size != 0)
4671
9
    {
4672
9
      cmd->export_content
4673
9
  = bfd_mach_o_alloc_and_read (abfd, cmd->export_off,
4674
9
             cmd->export_size, 0);
4675
9
      if (cmd->export_content == NULL)
4676
1
  return false;
4677
9
    }
4678
4679
15
  return true;
4680
16
}
4681
4682
static bool
4683
bfd_mach_o_read_dyld_info (bfd *abfd, bfd_mach_o_load_command *command)
4684
3.15k
{
4685
3.15k
  bfd_mach_o_dyld_info_command *cmd = &command->command.dyld_info;
4686
3.15k
  struct mach_o_dyld_info_command_external raw;
4687
4688
3.15k
  if (command->len < sizeof (raw) + 8)
4689
7
    return false;
4690
3.14k
  if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4691
37
    return false;
4692
4693
3.11k
  cmd->rebase_off = bfd_get_32 (abfd, raw.rebase_off);
4694
3.11k
  cmd->rebase_size = bfd_get_32 (abfd, raw.rebase_size);
4695
3.11k
  cmd->rebase_content = NULL;
4696
3.11k
  cmd->bind_off = bfd_get_32 (abfd, raw.bind_off);
4697
3.11k
  cmd->bind_size = bfd_get_32 (abfd, raw.bind_size);
4698
3.11k
  cmd->bind_content = NULL;
4699
3.11k
  cmd->weak_bind_off = bfd_get_32 (abfd, raw.weak_bind_off);
4700
3.11k
  cmd->weak_bind_size = bfd_get_32 (abfd, raw.weak_bind_size);
4701
3.11k
  cmd->weak_bind_content = NULL;
4702
3.11k
  cmd->lazy_bind_off = bfd_get_32 (abfd, raw.lazy_bind_off);
4703
3.11k
  cmd->lazy_bind_size = bfd_get_32 (abfd, raw.lazy_bind_size);
4704
3.11k
  cmd->lazy_bind_content = NULL;
4705
3.11k
  cmd->export_off = bfd_get_32 (abfd, raw.export_off);
4706
3.11k
  cmd->export_size = bfd_get_32 (abfd, raw.export_size);
4707
3.11k
  cmd->export_content = NULL;
4708
3.11k
  return true;
4709
3.14k
}
4710
4711
static bool
4712
bfd_mach_o_read_version_min (bfd *abfd, bfd_mach_o_load_command *command)
4713
10.3k
{
4714
10.3k
  bfd_mach_o_version_min_command *cmd = &command->command.version_min;
4715
10.3k
  struct mach_o_version_min_command_external raw;
4716
4717
10.3k
  if (command->len < sizeof (raw) + 8)
4718
9
    return false;
4719
10.3k
  if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4720
34
    return false;
4721
4722
10.3k
  cmd->version = bfd_get_32 (abfd, raw.version);
4723
10.3k
  cmd->sdk = bfd_get_32 (abfd, raw.sdk);
4724
10.3k
  return true;
4725
10.3k
}
4726
4727
static bool
4728
bfd_mach_o_read_encryption_info (bfd *abfd, bfd_mach_o_load_command *command)
4729
1.17k
{
4730
1.17k
  bfd_mach_o_encryption_info_command *cmd = &command->command.encryption_info;
4731
1.17k
  struct mach_o_encryption_info_command_external raw;
4732
4733
1.17k
  if (command->len < sizeof (raw) + 8)
4734
11
    return false;
4735
1.16k
  if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4736
38
    return false;
4737
4738
1.13k
  cmd->cryptoff = bfd_get_32 (abfd, raw.cryptoff);
4739
1.13k
  cmd->cryptsize = bfd_get_32 (abfd, raw.cryptsize);
4740
1.13k
  cmd->cryptid = bfd_get_32 (abfd, raw.cryptid);
4741
1.13k
  return true;
4742
1.16k
}
4743
4744
static bool
4745
bfd_mach_o_read_encryption_info_64 (bfd *abfd, bfd_mach_o_load_command *command)
4746
1.28k
{
4747
1.28k
  bfd_mach_o_encryption_info_command *cmd = &command->command.encryption_info;
4748
1.28k
  struct mach_o_encryption_info_64_command_external raw;
4749
4750
1.28k
  if (command->len < sizeof (raw) + 8)
4751
9
    return false;
4752
1.27k
  if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4753
26
    return false;
4754
4755
1.25k
  cmd->cryptoff = bfd_get_32 (abfd, raw.cryptoff);
4756
1.25k
  cmd->cryptsize = bfd_get_32 (abfd, raw.cryptsize);
4757
1.25k
  cmd->cryptid = bfd_get_32 (abfd, raw.cryptid);
4758
1.25k
  return true;
4759
1.27k
}
4760
4761
static bool
4762
bfd_mach_o_read_main (bfd *abfd, bfd_mach_o_load_command *command)
4763
2.70k
{
4764
2.70k
  bfd_mach_o_main_command *cmd = &command->command.main;
4765
2.70k
  struct mach_o_entry_point_command_external raw;
4766
4767
2.70k
  if (command->len < sizeof (raw) + 8)
4768
6
    return false;
4769
2.69k
  if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4770
39
    return false;
4771
4772
2.65k
  cmd->entryoff = bfd_get_64 (abfd, raw.entryoff);
4773
2.65k
  cmd->stacksize = bfd_get_64 (abfd, raw.stacksize);
4774
2.65k
  return true;
4775
2.69k
}
4776
4777
static bool
4778
bfd_mach_o_read_source_version (bfd *abfd, bfd_mach_o_load_command *command)
4779
3.51k
{
4780
3.51k
  bfd_mach_o_source_version_command *cmd = &command->command.source_version;
4781
3.51k
  struct mach_o_source_version_command_external raw;
4782
3.51k
  uint64_t ver;
4783
4784
3.51k
  if (command->len < sizeof (raw) + 8)
4785
11
    return false;
4786
3.50k
  if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4787
7
    return false;
4788
4789
3.49k
  ver = bfd_get_64 (abfd, raw.version);
4790
  /* Note: we use a serie of shift to avoid shift > 32 (for which gcc
4791
     generates warnings) in case of the host doesn't support 64 bit
4792
     integers.  */
4793
3.49k
  cmd->e = ver & 0x3ff;
4794
3.49k
  ver >>= 10;
4795
3.49k
  cmd->d = ver & 0x3ff;
4796
3.49k
  ver >>= 10;
4797
3.49k
  cmd->c = ver & 0x3ff;
4798
3.49k
  ver >>= 10;
4799
3.49k
  cmd->b = ver & 0x3ff;
4800
3.49k
  ver >>= 10;
4801
3.49k
  cmd->a = ver & 0xffffff;
4802
3.49k
  return true;
4803
3.50k
}
4804
4805
static bool
4806
bfd_mach_o_read_note (bfd *abfd, bfd_mach_o_load_command *command)
4807
1.70k
{
4808
1.70k
  bfd_mach_o_note_command *cmd = &command->command.note;
4809
1.70k
  struct mach_o_note_command_external raw;
4810
4811
1.70k
  if (command->len < sizeof (raw) + 8)
4812
9
    return false;
4813
1.69k
  if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4814
36
    return false;
4815
4816
1.65k
  memcpy (cmd->data_owner, raw.data_owner, 16);
4817
1.65k
  cmd->offset = bfd_get_64 (abfd, raw.offset);
4818
1.65k
  cmd->size = bfd_get_64 (abfd, raw.size);
4819
1.65k
  return true;
4820
1.69k
}
4821
4822
static bool
4823
bfd_mach_o_read_build_version (bfd *abfd, bfd_mach_o_load_command *command)
4824
4.08k
{
4825
4.08k
  bfd_mach_o_build_version_command *cmd = &command->command.build_version;
4826
4.08k
  struct mach_o_build_version_command_external raw;
4827
4828
4.08k
  if (command->len < sizeof (raw) + 8)
4829
9
    return false;
4830
4.07k
  if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4831
39
    return false;
4832
4833
4.03k
  cmd->platform = bfd_get_32 (abfd, raw.platform);
4834
4.03k
  cmd->minos = bfd_get_32 (abfd, raw.minos);
4835
4.03k
  cmd->sdk = bfd_get_32 (abfd, raw.sdk);
4836
4.03k
  cmd->ntools = bfd_get_32 (abfd, raw.ntools);
4837
4.03k
  return true;
4838
4.07k
}
4839
4840
static bool
4841
bfd_mach_o_read_segment (bfd *abfd,
4842
       bfd_mach_o_load_command *command,
4843
       unsigned int wide)
4844
25.3k
{
4845
25.3k
  bfd_mach_o_segment_command *seg = &command->command.segment;
4846
25.3k
  unsigned long i;
4847
4848
25.3k
  if (wide)
4849
7.11k
    {
4850
7.11k
      struct mach_o_segment_command_64_external raw;
4851
4852
7.11k
      BFD_ASSERT (command->type == BFD_MACH_O_LC_SEGMENT_64);
4853
4854
7.11k
      if (command->len < sizeof (raw) + 8)
4855
19
  return false;
4856
7.09k
      if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4857
62
  return false;
4858
4859
7.03k
      memcpy (seg->segname, raw.segname, 16);
4860
7.03k
      seg->segname[16] = '\0';
4861
4862
7.03k
      seg->vmaddr = bfd_h_get_64 (abfd, raw.vmaddr);
4863
7.03k
      seg->vmsize = bfd_h_get_64 (abfd, raw.vmsize);
4864
7.03k
      seg->fileoff = bfd_h_get_64 (abfd, raw.fileoff);
4865
7.03k
      seg->filesize = bfd_h_get_64 (abfd, raw.filesize);
4866
7.03k
      seg->maxprot = bfd_h_get_32 (abfd, raw.maxprot);
4867
7.03k
      seg->initprot = bfd_h_get_32 (abfd, raw.initprot);
4868
7.03k
      seg->nsects = bfd_h_get_32 (abfd, raw.nsects);
4869
7.03k
      seg->flags = bfd_h_get_32 (abfd, raw.flags);
4870
7.03k
    }
4871
18.2k
  else
4872
18.2k
    {
4873
18.2k
      struct mach_o_segment_command_32_external raw;
4874
4875
18.2k
      BFD_ASSERT (command->type == BFD_MACH_O_LC_SEGMENT);
4876
4877
18.2k
      if (command->len < sizeof (raw) + 8)
4878
15
  return false;
4879
18.2k
      if (bfd_read (&raw, sizeof (raw), abfd) != sizeof (raw))
4880
67
  return false;
4881
4882
18.1k
      memcpy (seg->segname, raw.segname, 16);
4883
18.1k
      seg->segname[16] = '\0';
4884
4885
18.1k
      seg->vmaddr = bfd_h_get_32 (abfd, raw.vmaddr);
4886
18.1k
      seg->vmsize = bfd_h_get_32 (abfd, raw.vmsize);
4887
18.1k
      seg->fileoff = bfd_h_get_32 (abfd, raw.fileoff);
4888
18.1k
      seg->filesize = bfd_h_get_32 (abfd, raw.filesize);
4889
18.1k
      seg->maxprot = bfd_h_get_32 (abfd, raw.maxprot);
4890
18.1k
      seg->initprot = bfd_h_get_32 (abfd, raw.initprot);
4891
18.1k
      seg->nsects = bfd_h_get_32 (abfd, raw.nsects);
4892
18.1k
      seg->flags = bfd_h_get_32 (abfd, raw.flags);
4893
18.1k
    }
4894
25.1k
  seg->sect_head = NULL;
4895
25.1k
  seg->sect_tail = NULL;
4896
4897
484k
  for (i = 0; i < seg->nsects; i++)
4898
460k
    {
4899
460k
      asection *sec;
4900
4901
460k
      sec = bfd_mach_o_read_section (abfd, seg->initprot, wide);
4902
460k
      if (sec == NULL)
4903
1.09k
  return false;
4904
4905
458k
      bfd_mach_o_append_section_to_segment
4906
458k
  (seg, bfd_mach_o_get_mach_o_section (sec));
4907
458k
    }
4908
4909
24.0k
  return true;
4910
25.1k
}
4911
4912
static bool
4913
bfd_mach_o_read_segment_32 (bfd *abfd, bfd_mach_o_load_command *command)
4914
18.2k
{
4915
18.2k
  return bfd_mach_o_read_segment (abfd, command, 0);
4916
18.2k
}
4917
4918
static bool
4919
bfd_mach_o_read_segment_64 (bfd *abfd, bfd_mach_o_load_command *command)
4920
7.11k
{
4921
7.11k
  return bfd_mach_o_read_segment (abfd, command, 1);
4922
7.11k
}
4923
4924
static bool
4925
bfd_mach_o_read_command (bfd *abfd, bfd_mach_o_load_command *command,
4926
       ufile_ptr filesize)
4927
105k
{
4928
105k
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
4929
105k
  struct mach_o_load_command_external raw;
4930
105k
  unsigned int cmd;
4931
4932
  /* Read command type and length.  */
4933
105k
  if (bfd_seek (abfd, mdata->hdr_offset + command->offset, SEEK_SET) != 0
4934
105k
      || bfd_read (&raw, BFD_MACH_O_LC_SIZE, abfd) != BFD_MACH_O_LC_SIZE)
4935
460
    return false;
4936
4937
105k
  cmd = bfd_h_get_32 (abfd, raw.cmd);
4938
105k
  command->type = cmd & ~BFD_MACH_O_LC_REQ_DYLD;
4939
105k
  command->type_required = (cmd & BFD_MACH_O_LC_REQ_DYLD) != 0;
4940
105k
  command->len = bfd_h_get_32 (abfd, raw.cmdsize);
4941
105k
  if (command->len < 8 || command->len % 4 != 0)
4942
120
    return false;
4943
4944
104k
  switch (command->type)
4945
104k
    {
4946
18.2k
    case BFD_MACH_O_LC_SEGMENT:
4947
18.2k
      if (!bfd_mach_o_read_segment_32 (abfd, command))
4948
775
  return false;
4949
17.4k
      break;
4950
17.4k
    case BFD_MACH_O_LC_SEGMENT_64:
4951
7.11k
      if (!bfd_mach_o_read_segment_64 (abfd, command))
4952
479
  return false;
4953
6.63k
      break;
4954
6.63k
    case BFD_MACH_O_LC_SYMTAB:
4955
1.99k
      if (!bfd_mach_o_read_symtab (abfd, command, filesize))
4956
333
  return false;
4957
1.66k
      break;
4958
2.05k
    case BFD_MACH_O_LC_SYMSEG:
4959
2.05k
      break;
4960
335
    case BFD_MACH_O_LC_THREAD:
4961
707
    case BFD_MACH_O_LC_UNIXTHREAD:
4962
707
      if (!bfd_mach_o_read_thread (abfd, command))
4963
165
  return false;
4964
542
      break;
4965
857
    case BFD_MACH_O_LC_LOAD_DYLINKER:
4966
3.78k
    case BFD_MACH_O_LC_ID_DYLINKER:
4967
4.61k
    case BFD_MACH_O_LC_DYLD_ENVIRONMENT:
4968
4.61k
      if (!bfd_mach_o_read_dylinker (abfd, command))
4969
181
  return false;
4970
4.43k
      break;
4971
4.43k
    case BFD_MACH_O_LC_LOAD_DYLIB:
4972
1.48k
    case BFD_MACH_O_LC_LAZY_LOAD_DYLIB:
4973
1.94k
    case BFD_MACH_O_LC_ID_DYLIB:
4974
2.54k
    case BFD_MACH_O_LC_LOAD_WEAK_DYLIB:
4975
2.81k
    case BFD_MACH_O_LC_REEXPORT_DYLIB:
4976
5.57k
    case BFD_MACH_O_LC_LOAD_UPWARD_DYLIB:
4977
5.57k
      if (!bfd_mach_o_read_dylib (abfd, command))
4978
293
  return false;
4979
5.28k
      break;
4980
5.28k
    case BFD_MACH_O_LC_PREBOUND_DYLIB:
4981
564
      if (!bfd_mach_o_read_prebound_dylib (abfd, command))
4982
273
  return false;
4983
291
      break;
4984
482
    case BFD_MACH_O_LC_LOADFVMLIB:
4985
903
    case BFD_MACH_O_LC_IDFVMLIB:
4986
903
      if (!bfd_mach_o_read_fvmlib (abfd, command))
4987
150
  return false;
4988
753
      break;
4989
1.93k
    case BFD_MACH_O_LC_IDENT:
4990
2.97k
    case BFD_MACH_O_LC_FVMFILE:
4991
4.61k
    case BFD_MACH_O_LC_PREPAGE:
4992
5.46k
    case BFD_MACH_O_LC_ROUTINES:
4993
6.86k
    case BFD_MACH_O_LC_ROUTINES_64:
4994
6.86k
      break;
4995
560
    case BFD_MACH_O_LC_SUB_FRAMEWORK:
4996
808
    case BFD_MACH_O_LC_SUB_UMBRELLA:
4997
1.42k
    case BFD_MACH_O_LC_SUB_LIBRARY:
4998
1.72k
    case BFD_MACH_O_LC_SUB_CLIENT:
4999
2.13k
    case BFD_MACH_O_LC_RPATH:
5000
2.13k
      if (!bfd_mach_o_read_str (abfd, command))
5001
175
  return false;
5002
1.95k
      break;
5003
2.45k
    case BFD_MACH_O_LC_DYSYMTAB:
5004
2.45k
      if (!bfd_mach_o_read_dysymtab (abfd, command, filesize))
5005
986
  return false;
5006
1.46k
      break;
5007
3.22k
    case BFD_MACH_O_LC_PREBIND_CKSUM:
5008
3.22k
      if (!bfd_mach_o_read_prebind_cksum (abfd, command))
5009
18
  return false;
5010
3.20k
      break;
5011
3.20k
    case BFD_MACH_O_LC_TWOLEVEL_HINTS:
5012
1.16k
      if (!bfd_mach_o_read_twolevel_hints (abfd, command))
5013
30
  return false;
5014
1.13k
      break;
5015
2.01k
    case BFD_MACH_O_LC_UUID:
5016
2.01k
      if (!bfd_mach_o_read_uuid (abfd, command))
5017
23
  return false;
5018
1.99k
      break;
5019
1.99k
    case BFD_MACH_O_LC_CODE_SIGNATURE:
5020
3.40k
    case BFD_MACH_O_LC_SEGMENT_SPLIT_INFO:
5021
6.69k
    case BFD_MACH_O_LC_FUNCTION_STARTS:
5022
11.3k
    case BFD_MACH_O_LC_DATA_IN_CODE:
5023
12.5k
    case BFD_MACH_O_LC_DYLIB_CODE_SIGN_DRS:
5024
13.0k
    case BFD_MACH_O_LC_LINKER_OPTIMIZATION_HINT:
5025
14.5k
    case BFD_MACH_O_LC_DYLD_EXPORTS_TRIE:
5026
15.7k
    case BFD_MACH_O_LC_DYLD_CHAINED_FIXUPS:
5027
15.7k
      if (!bfd_mach_o_read_linkedit (abfd, command))
5028
83
  return false;
5029
15.7k
      break;
5030
15.7k
    case BFD_MACH_O_LC_ENCRYPTION_INFO:
5031
1.17k
      if (!bfd_mach_o_read_encryption_info (abfd, command))
5032
49
  return false;
5033
1.13k
      break;
5034
1.28k
    case BFD_MACH_O_LC_ENCRYPTION_INFO_64:
5035
1.28k
      if (!bfd_mach_o_read_encryption_info_64 (abfd, command))
5036
35
  return false;
5037
1.25k
      break;
5038
3.15k
    case BFD_MACH_O_LC_DYLD_INFO:
5039
3.15k
      if (!bfd_mach_o_read_dyld_info (abfd, command))
5040
44
  return false;
5041
3.11k
      break;
5042
3.11k
    case BFD_MACH_O_LC_VERSION_MIN_MACOSX:
5043
3.50k
    case BFD_MACH_O_LC_VERSION_MIN_IPHONEOS:
5044
9.10k
    case BFD_MACH_O_LC_VERSION_MIN_WATCHOS:
5045
10.3k
    case BFD_MACH_O_LC_VERSION_MIN_TVOS:
5046
10.3k
      if (!bfd_mach_o_read_version_min (abfd, command))
5047
43
  return false;
5048
10.3k
      break;
5049
10.3k
    case BFD_MACH_O_LC_MAIN:
5050
2.70k
      if (!bfd_mach_o_read_main (abfd, command))
5051
45
  return false;
5052
2.65k
      break;
5053
3.51k
    case BFD_MACH_O_LC_SOURCE_VERSION:
5054
3.51k
      if (!bfd_mach_o_read_source_version (abfd, command))
5055
18
  return false;
5056
3.49k
      break;
5057
3.49k
    case BFD_MACH_O_LC_LINKER_OPTIONS:
5058
1.53k
      break;
5059
1.70k
    case BFD_MACH_O_LC_NOTE:
5060
1.70k
      if (!bfd_mach_o_read_note (abfd, command))
5061
45
  return false;
5062
1.65k
      break;
5063
4.08k
    case BFD_MACH_O_LC_BUILD_VERSION:
5064
4.08k
      if (!bfd_mach_o_read_build_version (abfd, command))
5065
48
  return false;
5066
4.03k
      break;
5067
4.03k
    default:
5068
54
      command->len = 0;
5069
54
      _bfd_error_handler (_("%pB: unknown load command %#x"),
5070
54
        abfd, command->type);
5071
54
      return false;
5072
104k
    }
5073
5074
100k
  return true;
5075
104k
}
5076
5077
static bool
5078
bfd_mach_o_flatten_sections (bfd *abfd)
5079
4.76k
{
5080
4.76k
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
5081
4.76k
  bfd_mach_o_load_command *cmd;
5082
4.76k
  unsigned long csect;
5083
4.76k
  size_t amt;
5084
5085
  /* Count total number of sections.  */
5086
4.76k
  mdata->nsects = 0;
5087
5088
103k
  for (cmd = mdata->first_command; cmd != NULL; cmd = cmd->next)
5089
98.7k
    {
5090
98.7k
      if (cmd->type == BFD_MACH_O_LC_SEGMENT
5091
81.5k
    || cmd->type == BFD_MACH_O_LC_SEGMENT_64)
5092
23.4k
  {
5093
23.4k
    bfd_mach_o_segment_command *seg = &cmd->command.segment;
5094
5095
23.4k
    mdata->nsects += seg->nsects;
5096
23.4k
  }
5097
98.7k
    }
5098
5099
  /* Allocate sections array.  */
5100
4.76k
  if (_bfd_mul_overflow (mdata->nsects, sizeof (bfd_mach_o_section *), &amt))
5101
0
    {
5102
0
      bfd_set_error (bfd_error_file_too_big);
5103
0
      return false;
5104
0
    }
5105
4.76k
  mdata->sections = bfd_alloc (abfd, amt);
5106
4.76k
  if (mdata->sections == NULL && mdata->nsects != 0)
5107
0
    return false;
5108
5109
  /* Fill the array.  */
5110
4.76k
  csect = 0;
5111
5112
103k
  for (cmd = mdata->first_command; cmd != NULL; cmd = cmd->next)
5113
98.7k
    {
5114
98.7k
      if (cmd->type == BFD_MACH_O_LC_SEGMENT
5115
81.5k
    || cmd->type == BFD_MACH_O_LC_SEGMENT_64)
5116
23.4k
  {
5117
23.4k
    bfd_mach_o_segment_command *seg = &cmd->command.segment;
5118
23.4k
    bfd_mach_o_section *sec;
5119
5120
23.4k
    BFD_ASSERT (csect + seg->nsects <= mdata->nsects);
5121
5122
454k
    for (sec = seg->sect_head; sec != NULL; sec = sec->next)
5123
431k
      mdata->sections[csect++] = sec;
5124
23.4k
  }
5125
98.7k
    }
5126
4.76k
  BFD_ASSERT (mdata->nsects == csect);
5127
4.76k
  return true;
5128
4.76k
}
5129
5130
static bool
5131
bfd_mach_o_scan_start_address (bfd *abfd)
5132
4.76k
{
5133
4.76k
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
5134
4.76k
  bfd_mach_o_thread_command *thr = NULL;
5135
4.76k
  bfd_mach_o_load_command *cmd;
5136
4.76k
  unsigned long i;
5137
5138
97.4k
  for (cmd = mdata->first_command; cmd != NULL; cmd = cmd->next)
5139
94.4k
    if (cmd->type == BFD_MACH_O_LC_THREAD
5140
94.2k
  || cmd->type == BFD_MACH_O_LC_UNIXTHREAD)
5141
458
      {
5142
458
  thr = &cmd->command.thread;
5143
458
  break;
5144
458
      }
5145
94.0k
    else if (cmd->type == BFD_MACH_O_LC_MAIN && mdata->nsects > 1)
5146
1.29k
      {
5147
1.29k
  bfd_mach_o_main_command *main_cmd = &cmd->command.main;
5148
1.29k
  bfd_mach_o_section *text_sect = mdata->sections[0];
5149
5150
1.29k
  if (text_sect)
5151
1.29k
    {
5152
1.29k
      abfd->start_address = main_cmd->entryoff
5153
1.29k
        + (text_sect->addr - text_sect->offset);
5154
1.29k
      return true;
5155
1.29k
    }
5156
1.29k
      }
5157
5158
  /* An object file has no start address, so do not fail if not found.  */
5159
3.46k
  if (thr == NULL)
5160
3.00k
    return true;
5161
5162
  /* FIXME: create a subtarget hook ?  */
5163
5.86k
  for (i = 0; i < thr->nflavours; i++)
5164
5.47k
    {
5165
5.47k
      if ((mdata->header.cputype == BFD_MACH_O_CPU_TYPE_I386)
5166
1.38k
    && (thr->flavours[i].flavour == BFD_MACH_O_x86_THREAD_STATE32))
5167
90
  {
5168
90
    unsigned char buf[4];
5169
5170
90
    if (bfd_seek (abfd, thr->flavours[i].offset + 40, SEEK_SET) != 0
5171
90
        || bfd_read (buf, 4, abfd) != 4)
5172
20
      return false;
5173
5174
70
    abfd->start_address = bfd_h_get_32 (abfd, buf);
5175
70
  }
5176
5.38k
      else if ((mdata->header.cputype == BFD_MACH_O_CPU_TYPE_POWERPC)
5177
797
         && (thr->flavours[i].flavour == BFD_MACH_O_PPC_THREAD_STATE))
5178
98
  {
5179
98
    unsigned char buf[4];
5180
5181
98
    if (bfd_seek (abfd, thr->flavours[i].offset + 0, SEEK_SET) != 0
5182
98
        || bfd_read (buf, 4, abfd) != 4)
5183
10
      return false;
5184
5185
88
    abfd->start_address = bfd_h_get_32 (abfd, buf);
5186
88
  }
5187
5.28k
      else if ((mdata->header.cputype == BFD_MACH_O_CPU_TYPE_POWERPC_64)
5188
617
         && (thr->flavours[i].flavour == BFD_MACH_O_PPC_THREAD_STATE64))
5189
45
  {
5190
45
    unsigned char buf[8];
5191
5192
45
    if (bfd_seek (abfd, thr->flavours[i].offset + 0, SEEK_SET) != 0
5193
45
        || bfd_read (buf, 8, abfd) != 8)
5194
5
      return false;
5195
5196
40
    abfd->start_address = bfd_h_get_64 (abfd, buf);
5197
40
  }
5198
5.24k
      else if ((mdata->header.cputype == BFD_MACH_O_CPU_TYPE_X86_64)
5199
1.92k
         && (thr->flavours[i].flavour == BFD_MACH_O_x86_THREAD_STATE64))
5200
185
  {
5201
185
    unsigned char buf[8];
5202
5203
185
    if (bfd_seek (abfd, thr->flavours[i].offset + (16 * 8), SEEK_SET) != 0
5204
185
        || bfd_read (buf, 8, abfd) != 8)
5205
37
      return false;
5206
5207
148
    abfd->start_address = bfd_h_get_64 (abfd, buf);
5208
148
  }
5209
5.47k
    }
5210
5211
386
  return true;
5212
458
}
5213
5214
bool
5215
bfd_mach_o_set_arch_mach (bfd *abfd,
5216
        enum bfd_architecture arch,
5217
        unsigned long machine)
5218
10.0k
{
5219
10.0k
  bfd_mach_o_backend_data *bed = bfd_mach_o_get_backend_data (abfd);
5220
5221
  /* If this isn't the right architecture for this backend, and this
5222
     isn't the generic backend, fail.  */
5223
10.0k
  if (arch != bed->arch
5224
5.48k
      && arch != bfd_arch_unknown
5225
5.48k
      && bed->arch != bfd_arch_unknown)
5226
0
    return false;
5227
5228
10.0k
  return bfd_default_set_arch_mach (abfd, arch, machine);
5229
10.0k
}
5230
5231
static bool
5232
bfd_mach_o_scan (bfd *abfd,
5233
     bfd_mach_o_header *header,
5234
     bfd_mach_o_data_struct *mdata)
5235
10.1k
{
5236
10.1k
  unsigned int i;
5237
10.1k
  enum bfd_architecture cpu_type;
5238
10.1k
  unsigned long cpu_subtype;
5239
10.1k
  unsigned int hdrsize;
5240
5241
10.1k
  hdrsize = mach_o_wide_p (header) ?
5242
6.11k
    BFD_MACH_O_HEADER_64_SIZE : BFD_MACH_O_HEADER_SIZE;
5243
5244
10.1k
  mdata->header = *header;
5245
5246
10.1k
  abfd->flags = abfd->flags & BFD_IN_MEMORY;
5247
10.1k
  switch (header->filetype)
5248
10.1k
    {
5249
90
    case BFD_MACH_O_MH_OBJECT:
5250
90
      abfd->flags |= HAS_RELOC;
5251
90
      break;
5252
1.00k
    case BFD_MACH_O_MH_EXECUTE:
5253
1.00k
      abfd->flags |= EXEC_P;
5254
1.00k
      break;
5255
46
    case BFD_MACH_O_MH_DYLIB:
5256
63
    case BFD_MACH_O_MH_BUNDLE:
5257
63
      abfd->flags |= DYNAMIC;
5258
63
      break;
5259
10.1k
    }
5260
5261
10.1k
  bfd_mach_o_convert_architecture (header->cputype, header->cpusubtype,
5262
10.1k
           &cpu_type, &cpu_subtype);
5263
10.1k
  if (cpu_type == bfd_arch_unknown)
5264
213
    {
5265
213
      _bfd_error_handler
5266
  /* xgettext:c-format */
5267
213
  (_("bfd_mach_o_scan: unknown architecture 0x%lx/0x%lx"),
5268
213
   header->cputype, header->cpusubtype);
5269
213
      return false;
5270
213
    }
5271
5272
9.96k
  bfd_set_arch_mach (abfd, cpu_type, cpu_subtype);
5273
5274
9.96k
  if (header->ncmds != 0)
5275
9.82k
    {
5276
9.82k
      bfd_mach_o_load_command *cmd;
5277
9.82k
      size_t amt;
5278
9.82k
      ufile_ptr filesize = bfd_get_file_size (abfd);
5279
5280
9.82k
      if (filesize == 0)
5281
0
  filesize = (ufile_ptr) -1;
5282
5283
9.82k
      mdata->first_command = NULL;
5284
9.82k
      mdata->last_command = NULL;
5285
5286
9.82k
      if (header->ncmds > (filesize - hdrsize) / BFD_MACH_O_LC_SIZE)
5287
278
  {
5288
278
    bfd_set_error (bfd_error_file_truncated);
5289
278
    return false;
5290
278
  }
5291
9.55k
      if (_bfd_mul_overflow (header->ncmds,
5292
9.55k
           sizeof (bfd_mach_o_load_command), &amt))
5293
0
  {
5294
0
    bfd_set_error (bfd_error_file_too_big);
5295
0
    return false;
5296
0
  }
5297
9.55k
      cmd = bfd_alloc (abfd, amt);
5298
9.55k
      if (cmd == NULL)
5299
0
  return false;
5300
5301
110k
      for (i = 0; i < header->ncmds; i++)
5302
105k
  {
5303
105k
    bfd_mach_o_load_command *cur = &cmd[i];
5304
5305
105k
    bfd_mach_o_append_command (abfd, cur);
5306
5307
105k
    if (i == 0)
5308
9.55k
      cur->offset = hdrsize;
5309
96.0k
    else
5310
96.0k
      {
5311
96.0k
        bfd_mach_o_load_command *prev = &cmd[i - 1];
5312
96.0k
        cur->offset = prev->offset + prev->len;
5313
96.0k
      }
5314
5315
105k
    if (!bfd_mach_o_read_command (abfd, cur, filesize))
5316
4.92k
      {
5317
4.92k
        bfd_set_error (bfd_error_wrong_format);
5318
4.92k
        return false;
5319
4.92k
      }
5320
105k
  }
5321
9.55k
    }
5322
5323
  /* Sections should be flatten before scanning start address.  */
5324
4.76k
  if (!bfd_mach_o_flatten_sections (abfd))
5325
0
    return false;
5326
4.76k
  if (!bfd_mach_o_scan_start_address (abfd))
5327
72
    return false;
5328
5329
4.68k
  return true;
5330
4.76k
}
5331
5332
bool
5333
bfd_mach_o_mkobject_init (bfd *abfd)
5334
94
{
5335
94
  bfd_mach_o_data_struct *mdata = NULL;
5336
5337
94
  mdata = bfd_zalloc (abfd, sizeof (bfd_mach_o_data_struct));
5338
94
  if (mdata == NULL)
5339
0
    return false;
5340
94
  abfd->tdata.mach_o_data = mdata;
5341
5342
94
  mdata->header.magic = 0;
5343
94
  mdata->header.cputype = 0;
5344
94
  mdata->header.cpusubtype = 0;
5345
94
  mdata->header.filetype = 0;
5346
94
  mdata->header.ncmds = 0;
5347
94
  mdata->header.sizeofcmds = 0;
5348
94
  mdata->header.flags = 0;
5349
94
  mdata->header.byteorder = BFD_ENDIAN_UNKNOWN;
5350
94
  mdata->first_command = NULL;
5351
94
  mdata->last_command = NULL;
5352
94
  mdata->nsects = 0;
5353
94
  mdata->sections = NULL;
5354
94
  mdata->dyn_reloc_cache = NULL;
5355
5356
94
  return true;
5357
94
}
5358
5359
static bool
5360
bfd_mach_o_gen_mkobject (bfd *abfd)
5361
1
{
5362
1
  bfd_mach_o_data_struct *mdata;
5363
5364
1
  if (!bfd_mach_o_mkobject_init (abfd))
5365
0
    return false;
5366
5367
1
  mdata = bfd_mach_o_get_data (abfd);
5368
1
  mdata->header.magic = BFD_MACH_O_MH_MAGIC;
5369
1
  mdata->header.cputype = 0;
5370
1
  mdata->header.cpusubtype = 0;
5371
1
  mdata->header.byteorder = abfd->xvec->byteorder;
5372
1
  mdata->header.version = 1;
5373
5374
1
  return true;
5375
1
}
5376
5377
bfd_cleanup
5378
bfd_mach_o_header_p (bfd *abfd,
5379
         file_ptr hdr_off,
5380
         bfd_mach_o_filetype file_type,
5381
         bfd_mach_o_cpu_type cpu_type)
5382
886k
{
5383
886k
  bfd_mach_o_header header;
5384
886k
  bfd_mach_o_data_struct *mdata;
5385
5386
886k
  if (!bfd_mach_o_read_header (abfd, hdr_off, &header))
5387
852k
    goto wrong;
5388
5389
34.0k
  if (! (header.byteorder == BFD_ENDIAN_BIG
5390
32.1k
   || header.byteorder == BFD_ENDIAN_LITTLE))
5391
0
    {
5392
0
      _bfd_error_handler (_("unknown header byte-order value %#x"),
5393
0
        header.byteorder);
5394
0
      goto wrong;
5395
0
    }
5396
5397
34.0k
  if (! ((header.byteorder == BFD_ENDIAN_BIG
5398
1.86k
    && abfd->xvec->byteorder == BFD_ENDIAN_BIG
5399
348
    && abfd->xvec->header_byteorder == BFD_ENDIAN_BIG)
5400
33.6k
   || (header.byteorder == BFD_ENDIAN_LITTLE
5401
32.1k
       && abfd->xvec->byteorder == BFD_ENDIAN_LITTLE
5402
26.9k
       && abfd->xvec->header_byteorder == BFD_ENDIAN_LITTLE)))
5403
6.68k
    goto wrong;
5404
5405
  /* Check cputype and filetype.
5406
     In case of wildcard, do not accept magics that are handled by existing
5407
     targets.  */
5408
27.3k
  if (cpu_type)
5409
21.6k
    {
5410
21.6k
      if (header.cputype != cpu_type)
5411
17.0k
  goto wrong;
5412
21.6k
    }
5413
5.73k
  else
5414
5.73k
    {
5415
#ifndef BFD64
5416
      /* Do not recognize 64 architectures if not configured for 64bit targets.
5417
   This could happen only for generic targets.  */
5418
      if (mach_o_wide_p (&header))
5419
   goto wrong;
5420
#endif
5421
5.73k
    }
5422
5423
10.2k
  if (file_type)
5424
73
    {
5425
73
      if (header.filetype != file_type)
5426
73
  goto wrong;
5427
73
    }
5428
10.1k
  else
5429
10.1k
    {
5430
10.1k
      switch (header.filetype)
5431
10.1k
  {
5432
13
  case BFD_MACH_O_MH_CORE:
5433
    /* Handled by core_p */
5434
13
    goto wrong;
5435
10.1k
  default:
5436
10.1k
    break;
5437
10.1k
  }
5438
10.1k
    }
5439
5440
10.1k
  mdata = (bfd_mach_o_data_struct *) bfd_zalloc (abfd, sizeof (*mdata));
5441
10.1k
  if (mdata == NULL)
5442
0
    return NULL;
5443
10.1k
  abfd->tdata.mach_o_data = mdata;
5444
5445
10.1k
  mdata->hdr_offset = hdr_off;
5446
5447
10.1k
  if (!bfd_mach_o_scan (abfd, &header, mdata))
5448
5.48k
    {
5449
5.48k
      bfd_release (abfd, mdata);
5450
5.48k
      return NULL;
5451
5.48k
    }
5452
5453
4.68k
  return _bfd_no_cleanup;
5454
5455
876k
 wrong:
5456
876k
  bfd_set_error (bfd_error_wrong_format);
5457
876k
  return NULL;
5458
10.1k
}
5459
5460
static bfd_cleanup
5461
bfd_mach_o_gen_object_p (bfd *abfd)
5462
272k
{
5463
272k
  return bfd_mach_o_header_p (abfd, 0, 0, 0);
5464
272k
}
5465
5466
static bfd_cleanup
5467
bfd_mach_o_gen_core_p (bfd *abfd)
5468
20.4k
{
5469
20.4k
  return bfd_mach_o_header_p (abfd, 0, BFD_MACH_O_MH_CORE, 0);
5470
20.4k
}
5471
5472
/* Return the base address of ABFD, ie the address at which the image is
5473
   mapped.  The possible initial pagezero is ignored.  */
5474
5475
bfd_vma
5476
bfd_mach_o_get_base_address (bfd *abfd)
5477
0
{
5478
0
  bfd_mach_o_data_struct *mdata;
5479
0
  bfd_mach_o_load_command *cmd;
5480
5481
  /* Check for Mach-O.  */
5482
0
  if (!bfd_mach_o_valid (abfd))
5483
0
    return 0;
5484
0
  mdata = bfd_mach_o_get_data (abfd);
5485
5486
0
  for (cmd = mdata->first_command; cmd != NULL; cmd = cmd->next)
5487
0
    {
5488
0
      if ((cmd->type == BFD_MACH_O_LC_SEGMENT
5489
0
     || cmd->type == BFD_MACH_O_LC_SEGMENT_64))
5490
0
  {
5491
0
    struct bfd_mach_o_segment_command *segcmd = &cmd->command.segment;
5492
5493
0
    if (segcmd->initprot != 0)
5494
0
      return segcmd->vmaddr;
5495
0
  }
5496
0
    }
5497
0
  return 0;
5498
0
}
5499
5500
typedef struct mach_o_fat_archentry
5501
{
5502
  unsigned long cputype;
5503
  unsigned long cpusubtype;
5504
  unsigned long offset;
5505
  unsigned long size;
5506
  unsigned long align;
5507
} mach_o_fat_archentry;
5508
5509
typedef struct mach_o_fat_data_struct
5510
{
5511
  unsigned long magic;
5512
  unsigned long nfat_arch;
5513
  mach_o_fat_archentry *archentries;
5514
} mach_o_fat_data_struct;
5515
5516
/* Check for overlapping archive elements.  Note that we can't allow
5517
   multiple elements at the same offset even if one is empty, because
5518
   bfd_mach_o_fat_openr_next_archived_file assume distinct offsets.  */
5519
static bool
5520
overlap_previous (const mach_o_fat_archentry *elt, unsigned long i)
5521
225
{
5522
225
  unsigned long j = i;
5523
475
  while (j-- != 0)
5524
264
    if (elt[i].offset == elt[j].offset
5525
257
  || (elt[i].offset > elt[j].offset
5526
257
      ? elt[i].offset - elt[j].offset < elt[j].size
5527
257
      : elt[j].offset - elt[i].offset < elt[i].size))
5528
14
      return true;
5529
211
  return false;
5530
225
}
5531
5532
bfd_cleanup
5533
bfd_mach_o_fat_archive_p (bfd *abfd)
5534
110k
{
5535
110k
  mach_o_fat_data_struct *adata = NULL;
5536
110k
  struct mach_o_fat_header_external hdr;
5537
110k
  unsigned long i;
5538
110k
  size_t amt;
5539
110k
  ufile_ptr filesize;
5540
5541
110k
  if (bfd_seek (abfd, 0, SEEK_SET) != 0
5542
110k
      || bfd_read (&hdr, sizeof (hdr), abfd) != sizeof (hdr))
5543
563
    {
5544
563
      if (bfd_get_error () != bfd_error_system_call)
5545
261
  goto wrong;
5546
302
      goto error;
5547
563
    }
5548
5549
109k
  adata = bfd_alloc (abfd, sizeof (mach_o_fat_data_struct));
5550
109k
  if (adata == NULL)
5551
0
    goto error;
5552
5553
109k
  adata->magic = bfd_getb32 (hdr.magic);
5554
109k
  adata->nfat_arch = bfd_getb32 (hdr.nfat_arch);
5555
109k
  if (adata->magic != 0xcafebabe)
5556
109k
    goto wrong;
5557
  /* Avoid matching Java bytecode files, which have the same magic number.
5558
     In the Java bytecode file format this field contains the JVM version,
5559
     which starts at 43.0.  */
5560
401
  if (adata->nfat_arch > 30)
5561
70
    goto wrong;
5562
5563
331
  if (_bfd_mul_overflow (adata->nfat_arch,
5564
331
       sizeof (mach_o_fat_archentry), &amt))
5565
0
    {
5566
0
      bfd_set_error (bfd_error_file_too_big);
5567
0
      goto error;
5568
0
    }
5569
331
  adata->archentries = bfd_alloc (abfd, amt);
5570
331
  if (adata->archentries == NULL)
5571
0
    goto error;
5572
5573
331
  filesize = bfd_get_file_size (abfd);
5574
542
  for (i = 0; i < adata->nfat_arch; i++)
5575
499
    {
5576
499
      struct mach_o_fat_arch_external arch;
5577
499
      if (bfd_read (&arch, sizeof (arch), abfd) != sizeof (arch))
5578
23
  goto error;
5579
476
      adata->archentries[i].cputype = bfd_getb32 (arch.cputype);
5580
476
      adata->archentries[i].cpusubtype = bfd_getb32 (arch.cpusubtype);
5581
476
      adata->archentries[i].offset = bfd_getb32 (arch.offset);
5582
476
      adata->archentries[i].size = bfd_getb32 (arch.size);
5583
476
      adata->archentries[i].align = bfd_getb32 (arch.align);
5584
476
      if ((filesize != 0
5585
476
     && (adata->archentries[i].offset > filesize
5586
352
         || (adata->archentries[i].size
5587
352
       > filesize - adata->archentries[i].offset)))
5588
244
    || (adata->archentries[i].offset
5589
244
        < sizeof (hdr) + adata->nfat_arch * sizeof (arch))
5590
225
    || overlap_previous (adata->archentries, i))
5591
265
  {
5592
265
    bfd_release (abfd, adata);
5593
265
    bfd_set_error (bfd_error_malformed_archive);
5594
265
    return NULL;
5595
265
  }
5596
476
    }
5597
5598
43
  abfd->tdata.mach_o_fat_data = adata;
5599
5600
43
  return _bfd_no_cleanup;
5601
5602
109k
 wrong:
5603
109k
  bfd_set_error (bfd_error_wrong_format);
5604
109k
 error:
5605
109k
  if (adata != NULL)
5606
109k
    bfd_release (abfd, adata);
5607
109k
  return NULL;
5608
109k
}
5609
5610
/* Set the filename for a fat binary member ABFD, whose bfd architecture is
5611
   ARCH_TYPE/ARCH_SUBTYPE and corresponding entry in header is ENTRY.
5612
   Set arelt_data and origin fields too.  */
5613
5614
static bool
5615
bfd_mach_o_fat_member_init (bfd *abfd,
5616
          enum bfd_architecture arch_type,
5617
          unsigned long arch_subtype,
5618
          mach_o_fat_archentry *entry)
5619
20
{
5620
20
  struct areltdata *areltdata;
5621
  /* Create the member filename. Use ARCH_NAME.  */
5622
20
  const bfd_arch_info_type *ap = bfd_lookup_arch (arch_type, arch_subtype);
5623
20
  const char *filename;
5624
5625
20
  if (ap)
5626
6
    {
5627
      /* Use the architecture name if known.  */
5628
6
      filename = bfd_set_filename (abfd, ap->printable_name);
5629
6
    }
5630
14
  else
5631
14
    {
5632
      /* Forge a uniq id.  */
5633
14
      char buf[2 + 8 + 1 + 2 + 8 + 1];
5634
14
      snprintf (buf, sizeof (buf), "0x%lx-0x%lx",
5635
14
    entry->cputype, entry->cpusubtype);
5636
14
      filename = bfd_set_filename (abfd, buf);
5637
14
    }
5638
20
  if (!filename)
5639
0
    return false;
5640
5641
20
  areltdata = bfd_zmalloc (sizeof (struct areltdata));
5642
20
  if (areltdata == NULL)
5643
0
    return false;
5644
20
  areltdata->parsed_size = entry->size;
5645
20
  abfd->arelt_data = areltdata;
5646
20
  abfd->iostream = NULL;
5647
20
  abfd->origin = entry->offset;
5648
20
  return true;
5649
20
}
5650
5651
bfd *
5652
bfd_mach_o_fat_openr_next_archived_file (bfd *archive, bfd *prev)
5653
34
{
5654
34
  mach_o_fat_data_struct *adata;
5655
34
  mach_o_fat_archentry *entry = NULL;
5656
34
  unsigned long i;
5657
34
  bfd *nbfd;
5658
34
  enum bfd_architecture arch_type;
5659
34
  unsigned long arch_subtype;
5660
5661
34
  adata = (mach_o_fat_data_struct *) archive->tdata.mach_o_fat_data;
5662
34
  BFD_ASSERT (adata != NULL);
5663
5664
  /* Find index of previous entry.  */
5665
34
  if (prev == NULL)
5666
14
    {
5667
      /* Start at first one.  */
5668
14
      i = 0;
5669
14
    }
5670
20
  else
5671
20
    {
5672
      /* Find index of PREV.  */
5673
34
      for (i = 0; i < adata->nfat_arch; i++)
5674
34
  {
5675
34
    if (adata->archentries[i].offset == prev->origin)
5676
20
      break;
5677
34
  }
5678
5679
20
      if (i == adata->nfat_arch)
5680
0
  {
5681
    /* Not found.  */
5682
0
    bfd_set_error (bfd_error_bad_value);
5683
0
    return NULL;
5684
0
  }
5685
5686
      /* Get next entry.  */
5687
20
      i++;
5688
20
    }
5689
5690
34
  if (i >= adata->nfat_arch)
5691
14
    {
5692
14
      bfd_set_error (bfd_error_no_more_archived_files);
5693
14
      return NULL;
5694
14
    }
5695
5696
20
  entry = &adata->archentries[i];
5697
20
  nbfd = _bfd_new_bfd_contained_in (archive);
5698
20
  if (nbfd == NULL)
5699
0
    return NULL;
5700
5701
20
  bfd_mach_o_convert_architecture (entry->cputype, entry->cpusubtype,
5702
20
           &arch_type, &arch_subtype);
5703
5704
20
  if (!bfd_mach_o_fat_member_init (nbfd, arch_type, arch_subtype, entry))
5705
0
    {
5706
0
      bfd_close (nbfd);
5707
0
      return NULL;
5708
0
    }
5709
5710
20
  bfd_set_arch_mach (nbfd, arch_type, arch_subtype);
5711
5712
20
  return nbfd;
5713
20
}
5714
5715
/* Analogous to stat call.  */
5716
5717
static int
5718
bfd_mach_o_fat_stat_arch_elt (bfd *abfd, struct stat *buf)
5719
0
{
5720
0
  if (abfd->arelt_data == NULL)
5721
0
    {
5722
0
      bfd_set_error (bfd_error_invalid_operation);
5723
0
      return -1;
5724
0
    }
5725
5726
0
  buf->st_mtime = 0;
5727
0
  buf->st_uid = 0;
5728
0
  buf->st_gid = 0;
5729
0
  buf->st_mode = 0644;
5730
0
  buf->st_size = arelt_size (abfd);
5731
5732
0
  return 0;
5733
0
}
5734
5735
/* If ABFD format is FORMAT and architecture is ARCH, return it.
5736
   If ABFD is a fat image containing a member that corresponds to FORMAT
5737
   and ARCH, returns it.
5738
   In other case, returns NULL.
5739
   This function allows transparent uses of fat images.  */
5740
5741
bfd *
5742
bfd_mach_o_fat_extract (bfd *abfd,
5743
      bfd_format format,
5744
      const bfd_arch_info_type *arch)
5745
0
{
5746
0
  bfd *res;
5747
0
  mach_o_fat_data_struct *adata;
5748
0
  unsigned int i;
5749
5750
0
  if (bfd_check_format (abfd, format))
5751
0
    {
5752
0
      if (bfd_get_arch_info (abfd) == arch)
5753
0
  return abfd;
5754
0
      return NULL;
5755
0
    }
5756
0
  if (!bfd_check_format (abfd, bfd_archive)
5757
0
      || abfd->xvec != &mach_o_fat_vec)
5758
0
    return NULL;
5759
5760
  /* This is a Mach-O fat image.  */
5761
0
  adata = (mach_o_fat_data_struct *) abfd->tdata.mach_o_fat_data;
5762
0
  BFD_ASSERT (adata != NULL);
5763
5764
0
  for (i = 0; i < adata->nfat_arch; i++)
5765
0
    {
5766
0
      struct mach_o_fat_archentry *e = &adata->archentries[i];
5767
0
      enum bfd_architecture cpu_type;
5768
0
      unsigned long cpu_subtype;
5769
5770
0
      bfd_mach_o_convert_architecture (e->cputype, e->cpusubtype,
5771
0
               &cpu_type, &cpu_subtype);
5772
0
      if (cpu_type != arch->arch || cpu_subtype != arch->mach)
5773
0
  continue;
5774
5775
      /* The architecture is found.  */
5776
0
      res = _bfd_new_bfd_contained_in (abfd);
5777
0
      if (res == NULL)
5778
0
  return NULL;
5779
5780
0
      if (bfd_mach_o_fat_member_init (res, cpu_type, cpu_subtype, e)
5781
0
    && bfd_check_format (res, format))
5782
0
  {
5783
0
    BFD_ASSERT (bfd_get_arch_info (res) == arch);
5784
0
    return res;
5785
0
  }
5786
0
      bfd_close (res);
5787
0
      return NULL;
5788
0
    }
5789
5790
0
  return NULL;
5791
0
}
5792
5793
static bool
5794
bfd_mach_o_fat_close_and_cleanup (bfd *abfd)
5795
63
{
5796
63
  _bfd_unlink_from_archive_parent (abfd);
5797
63
  return true;
5798
63
}
5799
5800
int
5801
bfd_mach_o_lookup_command (bfd *abfd,
5802
         bfd_mach_o_load_command_type type,
5803
         bfd_mach_o_load_command **mcommand)
5804
24
{
5805
24
  struct mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
5806
24
  struct bfd_mach_o_load_command *cmd;
5807
24
  unsigned int num;
5808
5809
24
  BFD_ASSERT (mdata != NULL);
5810
24
  BFD_ASSERT (mcommand != NULL);
5811
5812
24
  num = 0;
5813
155
  for (cmd = mdata->first_command; cmd != NULL; cmd = cmd->next)
5814
131
    {
5815
131
      if (cmd->type != type)
5816
126
  continue;
5817
5818
5
      if (num == 0)
5819
4
  *mcommand = cmd;
5820
5
      num++;
5821
5
    }
5822
5823
24
  return num;
5824
24
}
5825
5826
unsigned long
5827
bfd_mach_o_stack_addr (enum bfd_mach_o_cpu_type type)
5828
0
{
5829
0
  switch (type)
5830
0
    {
5831
0
    case BFD_MACH_O_CPU_TYPE_MC680x0:
5832
0
      return 0x04000000;
5833
0
    case BFD_MACH_O_CPU_TYPE_POWERPC:
5834
0
      return 0xc0000000;
5835
0
    case BFD_MACH_O_CPU_TYPE_I386:
5836
0
      return 0xc0000000;
5837
0
    case BFD_MACH_O_CPU_TYPE_SPARC:
5838
0
      return 0xf0000000;
5839
0
    case BFD_MACH_O_CPU_TYPE_HPPA:
5840
0
      return 0xc0000000 - 0x04000000;
5841
0
    default:
5842
0
      return 0;
5843
0
    }
5844
0
}
5845
5846
/* The following two tables should be kept, as far as possible, in order of
5847
   most frequently used entries to optimize their use from gas.  */
5848
5849
const bfd_mach_o_xlat_name bfd_mach_o_section_type_name[] =
5850
{
5851
  { "regular", BFD_MACH_O_S_REGULAR},
5852
  { "coalesced", BFD_MACH_O_S_COALESCED},
5853
  { "zerofill", BFD_MACH_O_S_ZEROFILL},
5854
  { "cstring_literals", BFD_MACH_O_S_CSTRING_LITERALS},
5855
  { "4byte_literals", BFD_MACH_O_S_4BYTE_LITERALS},
5856
  { "8byte_literals", BFD_MACH_O_S_8BYTE_LITERALS},
5857
  { "16byte_literals", BFD_MACH_O_S_16BYTE_LITERALS},
5858
  { "literal_pointers", BFD_MACH_O_S_LITERAL_POINTERS},
5859
  { "mod_init_func_pointers", BFD_MACH_O_S_MOD_INIT_FUNC_POINTERS},
5860
  { "mod_fini_func_pointers", BFD_MACH_O_S_MOD_FINI_FUNC_POINTERS},
5861
  { "gb_zerofill", BFD_MACH_O_S_GB_ZEROFILL},
5862
  { "interposing", BFD_MACH_O_S_INTERPOSING},
5863
  { "dtrace_dof", BFD_MACH_O_S_DTRACE_DOF},
5864
  { "non_lazy_symbol_pointers", BFD_MACH_O_S_NON_LAZY_SYMBOL_POINTERS},
5865
  { "lazy_symbol_pointers", BFD_MACH_O_S_LAZY_SYMBOL_POINTERS},
5866
  { "symbol_stubs", BFD_MACH_O_S_SYMBOL_STUBS},
5867
  { "lazy_dylib_symbol_pointers", BFD_MACH_O_S_LAZY_DYLIB_SYMBOL_POINTERS},
5868
  { NULL, 0}
5869
};
5870
5871
const bfd_mach_o_xlat_name bfd_mach_o_section_attribute_name[] =
5872
{
5873
  { "pure_instructions", BFD_MACH_O_S_ATTR_PURE_INSTRUCTIONS },
5874
  { "some_instructions", BFD_MACH_O_S_ATTR_SOME_INSTRUCTIONS },
5875
  { "loc_reloc", BFD_MACH_O_S_ATTR_LOC_RELOC },
5876
  { "ext_reloc", BFD_MACH_O_S_ATTR_EXT_RELOC },
5877
  { "debug", BFD_MACH_O_S_ATTR_DEBUG },
5878
  { "live_support", BFD_MACH_O_S_ATTR_LIVE_SUPPORT },
5879
  { "no_dead_strip", BFD_MACH_O_S_ATTR_NO_DEAD_STRIP },
5880
  { "strip_static_syms", BFD_MACH_O_S_ATTR_STRIP_STATIC_SYMS },
5881
  { "no_toc", BFD_MACH_O_S_ATTR_NO_TOC },
5882
  { "self_modifying_code", BFD_MACH_O_S_SELF_MODIFYING_CODE },
5883
  { "modifying_code", BFD_MACH_O_S_SELF_MODIFYING_CODE },
5884
  { NULL, 0}
5885
};
5886
5887
/* Get the section type from NAME.  Return 256 if NAME is unknown.  */
5888
5889
unsigned int
5890
bfd_mach_o_get_section_type_from_name (bfd *abfd, const char *name)
5891
0
{
5892
0
  const bfd_mach_o_xlat_name *x;
5893
0
  bfd_mach_o_backend_data *bed = bfd_mach_o_get_backend_data (abfd);
5894
5895
0
  for (x = bfd_mach_o_section_type_name; x->name; x++)
5896
0
    if (strcmp (x->name, name) == 0)
5897
0
      {
5898
  /* We found it... does the target support it?  */
5899
0
  if (bed->bfd_mach_o_section_type_valid_for_target == NULL
5900
0
      || bed->bfd_mach_o_section_type_valid_for_target (x->val))
5901
0
    return x->val; /* OK.  */
5902
0
  else
5903
0
    break; /* Not supported.  */
5904
0
      }
5905
  /* Maximum section ID = 0xff.  */
5906
0
  return 256;
5907
0
}
5908
5909
/* Get the section attribute from NAME.  Return -1 if NAME is unknown.  */
5910
5911
unsigned int
5912
bfd_mach_o_get_section_attribute_from_name (const char *name)
5913
0
{
5914
0
  const bfd_mach_o_xlat_name *x;
5915
5916
0
  for (x = bfd_mach_o_section_attribute_name; x->name; x++)
5917
0
    if (strcmp (x->name, name) == 0)
5918
0
      return x->val;
5919
0
  return (unsigned int)-1;
5920
0
}
5921
5922
int
5923
bfd_mach_o_core_fetch_environment (bfd *abfd,
5924
           unsigned char **rbuf,
5925
           unsigned int *rlen)
5926
0
{
5927
0
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
5928
0
  unsigned long stackaddr = bfd_mach_o_stack_addr (mdata->header.cputype);
5929
0
  bfd_mach_o_load_command *cmd;
5930
5931
0
  for (cmd = mdata->first_command; cmd != NULL; cmd = cmd->next)
5932
0
    {
5933
0
      bfd_mach_o_segment_command *seg;
5934
5935
0
      if (cmd->type != BFD_MACH_O_LC_SEGMENT)
5936
0
  continue;
5937
5938
0
      seg = &cmd->command.segment;
5939
5940
0
      if ((seg->vmaddr + seg->vmsize) == stackaddr)
5941
0
  {
5942
0
    unsigned long start = seg->fileoff;
5943
0
    unsigned long end = seg->fileoff + seg->filesize;
5944
0
    unsigned char *buf = bfd_malloc (1024);
5945
0
    unsigned long size = 1024;
5946
5947
0
    if (buf == NULL)
5948
0
      return -1;
5949
0
    for (;;)
5950
0
      {
5951
0
        bfd_size_type nread = 0;
5952
0
        unsigned long offset;
5953
0
        int found_nonnull = 0;
5954
5955
0
        if (size > (end - start))
5956
0
    size = (end - start);
5957
5958
0
        buf = bfd_realloc_or_free (buf, size);
5959
0
        if (buf == NULL)
5960
0
    return -1;
5961
5962
0
        if (bfd_seek (abfd, end - size, SEEK_SET) != 0)
5963
0
    {
5964
0
      free (buf);
5965
0
      return -1;
5966
0
    }
5967
5968
0
        nread = bfd_read (buf, size, abfd);
5969
5970
0
        if (nread != size)
5971
0
    {
5972
0
      free (buf);
5973
0
      return -1;
5974
0
    }
5975
5976
0
        for (offset = 4; offset <= size; offset += 4)
5977
0
    {
5978
0
      unsigned long val;
5979
5980
0
      val = bfd_get_32(abfd, buf + size - offset);
5981
5982
0
      if (! found_nonnull)
5983
0
        {
5984
0
          if (val != 0)
5985
0
      found_nonnull = 1;
5986
0
        }
5987
0
      else if (val == 0x0)
5988
0
        {
5989
0
          unsigned long bottom;
5990
0
          unsigned long top;
5991
5992
0
          bottom = seg->fileoff + seg->filesize - offset;
5993
0
          top = seg->fileoff + seg->filesize - 4;
5994
0
          *rbuf = bfd_malloc (top - bottom);
5995
0
          if (*rbuf == NULL)
5996
0
      return -1;
5997
0
          *rlen = top - bottom;
5998
5999
0
          memcpy (*rbuf, buf + size - *rlen, *rlen);
6000
0
          free (buf);
6001
0
          return 0;
6002
0
        }
6003
0
    }
6004
6005
0
        if (size == (end - start))
6006
0
    break;
6007
6008
0
        size *= 2;
6009
0
      }
6010
6011
0
    free (buf);
6012
0
  }
6013
0
    }
6014
6015
0
  return -1;
6016
0
}
6017
6018
char *
6019
bfd_mach_o_core_file_failing_command (bfd *abfd)
6020
0
{
6021
0
  unsigned char *buf = NULL;
6022
0
  unsigned int len = 0;
6023
0
  int ret;
6024
6025
0
  ret = bfd_mach_o_core_fetch_environment (abfd, &buf, &len);
6026
0
  if (ret < 0 || len == 0)
6027
0
    return NULL;
6028
0
  buf[len - 1] = 0;
6029
0
  return (char *) buf;
6030
0
}
6031
6032
int
6033
bfd_mach_o_core_file_failing_signal (bfd *abfd ATTRIBUTE_UNUSED)
6034
0
{
6035
0
  return 0;
6036
0
}
6037
6038
static bfd_mach_o_uuid_command *
6039
bfd_mach_o_lookup_uuid_command (bfd *abfd)
6040
24
{
6041
24
  bfd_mach_o_load_command *uuid_cmd = NULL;
6042
24
  int ncmd = bfd_mach_o_lookup_command (abfd, BFD_MACH_O_LC_UUID, &uuid_cmd);
6043
24
  if (ncmd != 1 || uuid_cmd == NULL)
6044
21
    return NULL;
6045
3
  return &uuid_cmd->command.uuid;
6046
24
}
6047
6048
/* Return true if ABFD is a dSYM file and its UUID matches UUID_CMD. */
6049
6050
static bool
6051
bfd_mach_o_dsym_for_uuid_p (bfd *abfd, const bfd_mach_o_uuid_command *uuid_cmd)
6052
0
{
6053
0
  bfd_mach_o_uuid_command *dsym_uuid_cmd;
6054
6055
0
  BFD_ASSERT (abfd);
6056
0
  BFD_ASSERT (uuid_cmd);
6057
6058
0
  if (!bfd_check_format (abfd, bfd_object))
6059
0
    return false;
6060
6061
0
  if (bfd_get_flavour (abfd) != bfd_target_mach_o_flavour
6062
0
      || bfd_mach_o_get_data (abfd) == NULL
6063
0
      || bfd_mach_o_get_data (abfd)->header.filetype != BFD_MACH_O_MH_DSYM)
6064
0
    return false;
6065
6066
0
  dsym_uuid_cmd = bfd_mach_o_lookup_uuid_command (abfd);
6067
0
  if (dsym_uuid_cmd == NULL)
6068
0
    return false;
6069
6070
0
  if (memcmp (uuid_cmd->uuid, dsym_uuid_cmd->uuid,
6071
0
        sizeof (uuid_cmd->uuid)) != 0)
6072
0
    return false;
6073
6074
0
  return true;
6075
0
}
6076
6077
/* Find a BFD in DSYM_FILENAME which matches ARCH and UUID_CMD.
6078
   The caller is responsible for closing the returned BFD object and
6079
   its my_archive if the returned BFD is in a fat dSYM. */
6080
6081
static bfd *
6082
bfd_mach_o_find_dsym (const char *dsym_filename,
6083
          const bfd_mach_o_uuid_command *uuid_cmd,
6084
          const bfd_arch_info_type *arch)
6085
3
{
6086
3
  bfd *base_dsym_bfd, *dsym_bfd;
6087
6088
3
  BFD_ASSERT (uuid_cmd);
6089
6090
3
  base_dsym_bfd = bfd_openr (dsym_filename, NULL);
6091
3
  if (base_dsym_bfd == NULL)
6092
3
    return NULL;
6093
6094
0
  dsym_bfd = bfd_mach_o_fat_extract (base_dsym_bfd, bfd_object, arch);
6095
0
  if (bfd_mach_o_dsym_for_uuid_p (dsym_bfd, uuid_cmd))
6096
0
    return dsym_bfd;
6097
6098
0
  bfd_close (dsym_bfd);
6099
0
  if (base_dsym_bfd != dsym_bfd)
6100
0
    bfd_close (base_dsym_bfd);
6101
6102
0
  return NULL;
6103
0
}
6104
6105
/* Return a BFD created from a dSYM file for ABFD.
6106
   The caller is responsible for closing the returned BFD object, its
6107
   filename, and its my_archive if the returned BFD is in a fat dSYM. */
6108
6109
static bfd *
6110
bfd_mach_o_follow_dsym (bfd *abfd)
6111
24
{
6112
24
  char *dsym_filename;
6113
24
  bfd_mach_o_uuid_command *uuid_cmd;
6114
24
  bfd *dsym_bfd, *base_bfd = abfd;
6115
24
  const char *base_basename;
6116
6117
24
  if (abfd == NULL || bfd_get_flavour (abfd) != bfd_target_mach_o_flavour)
6118
0
    return NULL;
6119
6120
24
  if (abfd->my_archive && !bfd_is_thin_archive (abfd->my_archive))
6121
0
    base_bfd = abfd->my_archive;
6122
  /* BFD may have been opened from a stream. */
6123
24
  if (bfd_get_filename (base_bfd) == NULL)
6124
0
    {
6125
0
      bfd_set_error (bfd_error_invalid_operation);
6126
0
      return NULL;
6127
0
    }
6128
24
  base_basename = lbasename (bfd_get_filename (base_bfd));
6129
6130
24
  uuid_cmd = bfd_mach_o_lookup_uuid_command (abfd);
6131
24
  if (uuid_cmd == NULL)
6132
21
    return NULL;
6133
6134
  /* TODO: We assume the DWARF file has the same as the binary's.
6135
     It seems apple's GDB checks all files in the dSYM bundle directory.
6136
     http://opensource.apple.com/source/gdb/gdb-1708/src/gdb/macosx/macosx-tdep.c
6137
  */
6138
3
  dsym_filename = (char *)bfd_malloc (strlen (bfd_get_filename (base_bfd))
6139
3
               + strlen (dsym_subdir) + 1
6140
3
               + strlen (base_basename) + 1);
6141
3
  if (dsym_filename == NULL)
6142
0
    return NULL;
6143
6144
3
  sprintf (dsym_filename, "%s%s/%s",
6145
3
     bfd_get_filename (base_bfd), dsym_subdir, base_basename);
6146
6147
3
  dsym_bfd = bfd_mach_o_find_dsym (dsym_filename, uuid_cmd,
6148
3
           bfd_get_arch_info (abfd));
6149
3
  if (dsym_bfd == NULL)
6150
3
    free (dsym_filename);
6151
6152
3
  return dsym_bfd;
6153
3
}
6154
6155
bool
6156
bfd_mach_o_find_nearest_line (bfd *abfd,
6157
            asymbol **symbols,
6158
            asection *section,
6159
            bfd_vma offset,
6160
            const char **filename_ptr,
6161
            const char **functionname_ptr,
6162
            unsigned int *line_ptr,
6163
            unsigned int *discriminator_ptr)
6164
5.78k
{
6165
5.78k
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
6166
5.78k
  if (mdata == NULL)
6167
0
    return false;
6168
5.78k
  switch (mdata->header.filetype)
6169
5.78k
    {
6170
1.49k
    case BFD_MACH_O_MH_OBJECT:
6171
1.49k
      break;
6172
167
    case BFD_MACH_O_MH_EXECUTE:
6173
226
    case BFD_MACH_O_MH_DYLIB:
6174
291
    case BFD_MACH_O_MH_BUNDLE:
6175
349
    case BFD_MACH_O_MH_KEXT_BUNDLE:
6176
349
      if (mdata->dwarf2_find_line_info == NULL)
6177
24
  {
6178
24
    mdata->dsym_bfd = bfd_mach_o_follow_dsym (abfd);
6179
    /* When we couldn't find dSYM for this binary, we look for
6180
       the debug information in the binary itself. In this way,
6181
       we won't try finding separated dSYM again because
6182
       mdata->dwarf2_find_line_info will be filled. */
6183
24
    if (! mdata->dsym_bfd)
6184
24
      break;
6185
0
    if (! _bfd_dwarf2_slurp_debug_info (abfd, mdata->dsym_bfd,
6186
0
                dwarf_debug_sections, symbols,
6187
0
                &mdata->dwarf2_find_line_info,
6188
0
                false))
6189
0
      return false;
6190
0
  }
6191
325
      break;
6192
3.94k
    default:
6193
3.94k
      return false;
6194
5.78k
    }
6195
1.84k
  return _bfd_dwarf2_find_nearest_line (abfd, symbols, NULL, section, offset,
6196
1.84k
          filename_ptr, functionname_ptr,
6197
1.84k
          line_ptr, discriminator_ptr,
6198
1.84k
          dwarf_debug_sections,
6199
1.84k
          &mdata->dwarf2_find_line_info);
6200
5.78k
}
6201
6202
bool
6203
bfd_mach_o_close_and_cleanup (bfd *abfd)
6204
246k
{
6205
246k
  bfd_mach_o_data_struct *mdata = bfd_mach_o_get_data (abfd);
6206
246k
  if (bfd_get_format (abfd) == bfd_object && mdata != NULL)
6207
3.38k
    {
6208
3.38k
      if (mdata->dsym_bfd != NULL)
6209
0
  {
6210
0
    bfd *fat_bfd = mdata->dsym_bfd->my_archive;
6211
#if 0
6212
    /* FIXME: PR 19435: This calculation to find the memory allocated by
6213
       bfd_mach_o_follow_dsym for the filename does not always end up
6214
       selecting the correct pointer.  Unfortunately this problem is
6215
       very hard to reproduce on a non Mach-O native system, so until it
6216
       can be traced and fixed on such a system, this code will remain
6217
       commented out.  This does mean that there will be a memory leak,
6218
       but it is small, and happens when we are closing down, so it
6219
       should not matter too much.  */
6220
    char *dsym_filename = (char *)(fat_bfd
6221
           ? bfd_get_filename (fat_bfd)
6222
           : bfd_get_filename (mdata->dsym_bfd));
6223
#endif
6224
0
    bfd_close (mdata->dsym_bfd);
6225
0
    mdata->dsym_bfd = NULL;
6226
0
    if (fat_bfd)
6227
0
      bfd_close (fat_bfd);
6228
#if 0
6229
    free (dsym_filename);
6230
#endif
6231
0
  }
6232
3.38k
    }
6233
6234
246k
  return _bfd_generic_close_and_cleanup (abfd);
6235
246k
}
6236
6237
bool
6238
bfd_mach_o_bfd_free_cached_info (bfd *abfd)
6239
246k
{
6240
246k
  bfd_mach_o_data_struct *mdata;
6241
6242
246k
  if ((bfd_get_format (abfd) == bfd_object
6243
242k
       || bfd_get_format (abfd) == bfd_core)
6244
3.38k
      && (mdata = bfd_mach_o_get_data (abfd)) != NULL)
6245
3.38k
    {
6246
3.38k
      _bfd_dwarf2_cleanup_debug_info (abfd, &mdata->dwarf2_find_line_info);
6247
3.38k
      free (mdata->dyn_reloc_cache);
6248
3.38k
      mdata->dyn_reloc_cache = NULL;
6249
6250
241k
      for (asection *asect = abfd->sections; asect; asect = asect->next)
6251
238k
  {
6252
238k
    free (asect->relocation);
6253
238k
    asect->relocation = NULL;
6254
238k
  }
6255
3.38k
    }
6256
6257
  /* Do not call _bfd_generic_bfd_free_cached_info here.
6258
     bfd_mach_o_close_and_cleanup uses tdata.  */
6259
  return true;
6260
246k
}
6261
6262
#define bfd_mach_o_bfd_reloc_type_lookup _bfd_norelocs_bfd_reloc_type_lookup
6263
#define bfd_mach_o_bfd_reloc_name_lookup _bfd_norelocs_bfd_reloc_name_lookup
6264
6265
#define bfd_mach_o_canonicalize_one_reloc NULL
6266
#define bfd_mach_o_swap_reloc_out NULL
6267
#define bfd_mach_o_print_thread NULL
6268
#define bfd_mach_o_tgt_seg_table NULL
6269
#define bfd_mach_o_section_type_valid_for_tgt NULL
6270
6271
#define TARGET_NAME   mach_o_be_vec
6272
#define TARGET_STRING   "mach-o-be"
6273
#define TARGET_ARCHITECTURE bfd_arch_unknown
6274
#define TARGET_PAGESIZE   1
6275
#define TARGET_BIG_ENDIAN 1
6276
#define TARGET_ARCHIVE    0
6277
#define TARGET_PRIORITY   1
6278
#include "mach-o-target.c"
6279
6280
#undef TARGET_NAME
6281
#undef TARGET_STRING
6282
#undef TARGET_ARCHITECTURE
6283
#undef TARGET_PAGESIZE
6284
#undef TARGET_BIG_ENDIAN
6285
#undef TARGET_ARCHIVE
6286
#undef TARGET_PRIORITY
6287
6288
#define TARGET_NAME   mach_o_le_vec
6289
#define TARGET_STRING   "mach-o-le"
6290
#define TARGET_ARCHITECTURE bfd_arch_unknown
6291
#define TARGET_PAGESIZE   1
6292
#define TARGET_BIG_ENDIAN 0
6293
#define TARGET_ARCHIVE    0
6294
#define TARGET_PRIORITY   1
6295
6296
#include "mach-o-target.c"
6297
6298
#undef TARGET_NAME
6299
#undef TARGET_STRING
6300
#undef TARGET_ARCHITECTURE
6301
#undef TARGET_PAGESIZE
6302
#undef TARGET_BIG_ENDIAN
6303
#undef TARGET_ARCHIVE
6304
#undef TARGET_PRIORITY
6305
6306
/* Not yet handled: creating an archive.  */
6307
#define bfd_mach_o_mkarchive        _bfd_noarchive_mkarchive
6308
6309
#define bfd_mach_o_close_and_cleanup      bfd_mach_o_fat_close_and_cleanup
6310
6311
/* Not used.  */
6312
#define bfd_mach_o_generic_stat_arch_elt    bfd_mach_o_fat_stat_arch_elt
6313
#define bfd_mach_o_openr_next_archived_file   bfd_mach_o_fat_openr_next_archived_file
6314
#define bfd_mach_o_archive_p  bfd_mach_o_fat_archive_p
6315
6316
#define TARGET_NAME   mach_o_fat_vec
6317
#define TARGET_STRING   "mach-o-fat"
6318
#define TARGET_ARCHITECTURE bfd_arch_unknown
6319
#define TARGET_PAGESIZE   1
6320
#define TARGET_BIG_ENDIAN 1
6321
#define TARGET_ARCHIVE    1
6322
#define TARGET_PRIORITY   0
6323
6324
#include "mach-o-target.c"
6325
6326
#undef TARGET_NAME
6327
#undef TARGET_STRING
6328
#undef TARGET_ARCHITECTURE
6329
#undef TARGET_PAGESIZE
6330
#undef TARGET_BIG_ENDIAN
6331
#undef TARGET_ARCHIVE
6332
#undef TARGET_PRIORITY