Coverage Report

Created: 2026-03-10 08:46

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/binutils-gdb/bfd/srec.c
Line
Count
Source
1
/* BFD back-end for s-record objects.
2
   Copyright (C) 1990-2026 Free Software Foundation, Inc.
3
   Written by Steve Chamberlain of Cygnus Support <sac@cygnus.com>.
4
5
   This file is part of BFD, the Binary File Descriptor library.
6
7
   This program is free software; you can redistribute it and/or modify
8
   it under the terms of the GNU General Public License as published by
9
   the Free Software Foundation; either version 3 of the License, or
10
   (at your option) any later version.
11
12
   This program is distributed in the hope that it will be useful,
13
   but WITHOUT ANY WARRANTY; without even the implied warranty of
14
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15
   GNU General Public License for more details.
16
17
   You should have received a copy of the GNU General Public License
18
   along with this program; if not, write to the Free Software
19
   Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
20
   MA 02110-1301, USA.  */
21
22
23
/* SUBSECTION
24
  S-Record handling
25
26
   DESCRIPTION
27
28
  Ordinary S-Records cannot hold anything but addresses and
29
  data, so that's all that we implement.
30
31
  The only interesting thing is that S-Records may come out of
32
  order and there is no header, so an initial scan is required
33
  to discover the minimum and maximum addresses used to create
34
  the vma and size of the only section we create.  We
35
  arbitrarily call this section ".text".
36
37
  When bfd_get_section_contents is called the file is read
38
  again, and this time the data is placed into a bfd_alloc'd
39
  area.
40
41
  Any number of sections may be created for output, we save them
42
  up and output them when it's time to close the bfd.
43
44
  An s record looks like:
45
46
   EXAMPLE
47
  S<type><length><address><data><checksum>
48
49
   DESCRIPTION
50
  Where
51
  o length
52
  is the number of bytes following upto the checksum. Note that
53
  this is not the number of chars following, since it takes two
54
  chars to represent a byte.
55
  o type
56
  is one of:
57
  0) header record
58
  1) two byte address data record
59
  2) three byte address data record
60
  3) four byte address data record
61
  7) four byte address termination record
62
  8) three byte address termination record
63
  9) two byte address termination record
64
65
  o address
66
  is the start address of the data following, or in the case of
67
  a termination record, the start address of the image
68
  o data
69
  is the data.
70
  o checksum
71
  is the sum of all the raw byte data in the record, from the length
72
  upwards, modulo 256 and subtracted from 255.
73
74
   SUBSECTION
75
  Symbol S-Record handling
76
77
   DESCRIPTION
78
  Some ICE equipment understands an addition to the standard
79
  S-Record format; symbols and their addresses can be sent
80
  before the data.
81
82
  The format of this is:
83
  ($$ <modulename>
84
    (<space> <symbol> <address>)*)
85
  $$
86
87
  so a short symbol table could look like:
88
89
   EXAMPLE
90
  $$ flash.x
91
  $$ flash.c
92
    _port6 $0
93
    _delay $4
94
    _start $14
95
    _etext $8036
96
    _edata $8036
97
    _end $8036
98
  $$
99
100
   DESCRIPTION
101
  We allow symbols to be anywhere in the data stream - the module names
102
  are always ignored.  */
103
104
#include "sysdep.h"
105
#include "bfd.h"
106
#include "libbfd.h"
107
#include "libiberty.h"
108
#include "safe-ctype.h"
109
110
111
/* Macros for converting between hex and binary.  */
112
113
static const char digs[] = "0123456789ABCDEF";
114
115
133k
#define NIBBLE(x)    hex_value(x)
116
66.2k
#define HEX(buffer) ((NIBBLE ((buffer)[0])<<4) + NIBBLE ((buffer)[1]))
117
#define TOHEX(d, x, ch) \
118
486
  d[1] = digs[(x) & 0xf]; \
119
486
  d[0] = digs[((x)>>4)&0xf]; \
120
486
  ch += ((x) & 0xff);
121
21.9k
#define ISHEX(x)    hex_p(x)
122
123
/* The maximum number of address+data+crc bytes on a line is FF.  */
124
15
#define MAXCHUNK 0xff
125
126
/* Default size for a CHUNK.  */
127
#define DEFAULT_CHUNK 16
128
129
/* The number of data bytes we actually fit onto a line on output.
130
   This variable can be modified by objcopy's --srec-len parameter.
131
   For a 0x75 byte record you should set --srec-len=0x70.  */
132
unsigned int _bfd_srec_len = DEFAULT_CHUNK;
133
134
/* The type of srec output (free or forced to S3).
135
   This variable can be modified by objcopy's --srec-forceS3
136
   parameter.  */
137
bool _bfd_srec_forceS3 = false;
138
139
/* When writing an S-record file, the S-records can not be output as
140
   they are seen.  This structure is used to hold them in memory.  */
141
142
struct srec_data_list_struct
143
{
144
  struct srec_data_list_struct *next;
145
  bfd_byte *data;
146
  bfd_vma where;
147
  bfd_size_type size;
148
};
149
150
typedef struct srec_data_list_struct srec_data_list_type;
151
152
/* When scanning the S-record file, a linked list of srec_symbol
153
   structures is built to represent the symbol table (if there is
154
   one).  */
155
156
struct srec_symbol
157
{
158
  struct srec_symbol *next;
159
  const char *name;
160
  bfd_vma val;
161
};
162
163
/* The S-record tdata information.  */
164
165
typedef struct srec_data_struct
166
  {
167
    srec_data_list_type *head;
168
    srec_data_list_type *tail;
169
    unsigned int type;
170
    struct srec_symbol *symbols;
171
    struct srec_symbol *symtail;
172
    asymbol *csymbols;
173
  }
174
tdata_type;
175
176
/* Initialize by filling in the hex conversion array.  */
177
178
static void
179
srec_init (void)
180
194k
{
181
194k
  static bool inited = false;
182
183
194k
  if (! inited)
184
9
    {
185
9
      inited = true;
186
9
      hex_init ();
187
9
    }
188
194k
}
189
190
/* Set up the S-record tdata information.  */
191
192
static bool
193
srec_mkobject (bfd *abfd)
194
453
{
195
453
  tdata_type *tdata;
196
197
453
  srec_init ();
198
199
453
  tdata = (tdata_type *) bfd_alloc (abfd, sizeof (tdata_type));
200
453
  if (tdata == NULL)
201
0
    return false;
202
203
453
  abfd->tdata.srec_data = tdata;
204
453
  tdata->type = 1;
205
453
  tdata->head = NULL;
206
453
  tdata->tail = NULL;
207
453
  tdata->symbols = NULL;
208
453
  tdata->symtail = NULL;
209
453
  tdata->csymbols = NULL;
210
211
453
  return true;
212
453
}
213
214
/* Read a byte from an S record file.  Set *ERRORPTR if an error
215
   occurred.  Return EOF on error or end of file.  */
216
217
static int
218
srec_get_byte (bfd *abfd, bool *errorptr)
219
220k
{
220
220k
  bfd_byte c;
221
222
220k
  if (bfd_read (&c, 1, abfd) != 1)
223
196
    {
224
196
      if (bfd_get_error () != bfd_error_file_truncated)
225
8
  *errorptr = true;
226
196
      return EOF;
227
196
    }
228
229
220k
  return (int) (c & 0xff);
230
220k
}
231
232
/* Report a problem in an S record file.  FIXME: This probably should
233
   not call fprintf, but we really do need some mechanism for printing
234
   error messages.  */
235
236
static void
237
srec_bad_byte (bfd *abfd,
238
         unsigned int lineno,
239
         int c,
240
         bool error)
241
244
{
242
244
  if (c == EOF)
243
128
    {
244
128
      if (! error)
245
121
  bfd_set_error (bfd_error_file_truncated);
246
128
    }
247
116
  else
248
116
    {
249
116
      char buf[40];
250
251
116
      if (! ISPRINT (c))
252
70
  sprintf (buf, "\\%03o", (unsigned int) c & 0xff);
253
46
      else
254
46
  {
255
46
    buf[0] = c;
256
46
    buf[1] = '\0';
257
46
  }
258
116
      _bfd_error_handler
259
  /* xgettext:c-format */
260
116
  (_("%pB:%d: unexpected character `%s' in S-record file"),
261
116
   abfd, lineno, buf);
262
116
      bfd_set_error (bfd_error_bad_value);
263
116
    }
264
244
}
265
266
/* Add a new symbol found in an S-record file.  */
267
268
static bool
269
srec_new_symbol (bfd *abfd, const char *name, bfd_vma val)
270
5.00k
{
271
5.00k
  struct srec_symbol *n;
272
273
5.00k
  n = (struct srec_symbol *) bfd_alloc (abfd, sizeof (* n));
274
5.00k
  if (n == NULL)
275
0
    return false;
276
277
5.00k
  n->name = name;
278
5.00k
  n->val = val;
279
280
5.00k
  if (abfd->tdata.srec_data->symbols == NULL)
281
127
    abfd->tdata.srec_data->symbols = n;
282
4.88k
  else
283
4.88k
    abfd->tdata.srec_data->symtail->next = n;
284
5.00k
  abfd->tdata.srec_data->symtail = n;
285
5.00k
  n->next = NULL;
286
287
5.00k
  ++abfd->symcount;
288
289
5.00k
  return true;
290
5.00k
}
291
292
/* Read the S record file and turn it into sections.  We create a new
293
   section for each contiguous set of bytes.  */
294
295
static bool
296
srec_scan (bfd *abfd)
297
399
{
298
399
  int c;
299
399
  unsigned int lineno = 1;
300
399
  bool error = false;
301
399
  bfd_byte *buf = NULL;
302
399
  size_t bufsize = 0;
303
399
  asection *sec = NULL;
304
399
  char *symbuf = NULL;
305
306
399
  if (bfd_seek (abfd, 0, SEEK_SET) != 0)
307
0
    goto error_return;
308
309
30.5k
  while ((c = srec_get_byte (abfd, &error)) != EOF)
310
30.5k
    {
311
      /* We only build sections from contiguous S-records, so if this
312
   is not an S-record, then stop building a section.  */
313
30.5k
      if (c != 'S' && c != '\r' && c != '\n')
314
12.8k
  sec = NULL;
315
316
30.5k
      switch (c)
317
30.5k
  {
318
46
  default:
319
46
    srec_bad_byte (abfd, lineno, c, error);
320
46
    goto error_return;
321
322
5.33k
  case '\n':
323
5.33k
    ++lineno;
324
5.33k
    break;
325
326
1.51k
  case '\r':
327
1.51k
    break;
328
329
4.81k
  case '$':
330
    /* Starting a module name, which we ignore.  */
331
143k
    while ((c = srec_get_byte (abfd, &error)) != '\n'
332
138k
     && c != EOF)
333
138k
      ;
334
4.81k
    if (c == EOF)
335
38
      {
336
38
        srec_bad_byte (abfd, lineno, c, error);
337
38
        goto error_return;
338
38
      }
339
340
4.77k
    ++lineno;
341
4.77k
    break;
342
343
8.01k
  case ' ':
344
8.01k
    do
345
9.64k
      {
346
9.64k
        bfd_size_type alc;
347
9.64k
        char *p, *symname;
348
9.64k
        bfd_vma symval;
349
350
        /* Starting a symbol definition.  */
351
12.5k
        while ((c = srec_get_byte (abfd, &error)) != EOF
352
12.5k
         && (c == ' ' || c == '\t'))
353
2.90k
    ;
354
355
9.64k
        if (c == '\n' || c == '\r')
356
4.54k
    break;
357
358
5.09k
        if (c == EOF)
359
32
    {
360
32
      srec_bad_byte (abfd, lineno, c, error);
361
32
      goto error_return;
362
32
    }
363
364
5.06k
        alc = 10;
365
5.06k
        symbuf = (char *) bfd_malloc (alc + 1);
366
5.06k
        if (symbuf == NULL)
367
0
    goto error_return;
368
369
5.06k
        p = symbuf;
370
371
5.06k
        *p++ = c;
372
24.0k
        while ((c = srec_get_byte (abfd, &error)) != EOF
373
24.0k
         && ! ISSPACE (c))
374
19.0k
    {
375
19.0k
      if ((bfd_size_type) (p - symbuf) >= alc)
376
760
        {
377
760
          char *n;
378
379
760
          alc *= 2;
380
760
          n = (char *) bfd_realloc (symbuf, alc + 1);
381
760
          if (n == NULL)
382
0
      goto error_return;
383
760
          p = n + (p - symbuf);
384
760
          symbuf = n;
385
760
        }
386
387
19.0k
      *p++ = c;
388
19.0k
    }
389
390
5.06k
        if (c == EOF)
391
37
    {
392
37
      srec_bad_byte (abfd, lineno, c, error);
393
37
      goto error_return;
394
37
    }
395
396
5.02k
        *p++ = '\0';
397
5.02k
        symname = (char *) bfd_alloc (abfd, (bfd_size_type) (p - symbuf));
398
5.02k
        if (symname == NULL)
399
0
    goto error_return;
400
5.02k
        strcpy (symname, symbuf);
401
5.02k
        free (symbuf);
402
5.02k
        symbuf = NULL;
403
404
7.22k
        while ((c = srec_get_byte (abfd, &error)) != EOF
405
7.20k
         && (c == ' ' || c == '\t'))
406
2.19k
    ;
407
5.02k
        if (c == EOF)
408
14
    {
409
14
      srec_bad_byte (abfd, lineno, c, error);
410
14
      goto error_return;
411
14
    }
412
413
        /* Skip a dollar sign before the hex value.  */
414
5.01k
        if (c == '$')
415
2.11k
    {
416
2.11k
      c = srec_get_byte (abfd, &error);
417
2.11k
      if (c == EOF)
418
4
        {
419
4
          srec_bad_byte (abfd, lineno, c, error);
420
4
          goto error_return;
421
4
        }
422
2.11k
    }
423
424
5.01k
        symval = 0;
425
5.01k
        while (ISHEX (c))
426
1.14k
    {
427
1.14k
      symval <<= 4;
428
1.14k
      symval += NIBBLE (c);
429
1.14k
      c = srec_get_byte (abfd, &error);
430
1.14k
      if (c == EOF)
431
3
        {
432
3
          srec_bad_byte (abfd, lineno, c, error);
433
3
          goto error_return;
434
3
        }
435
1.14k
    }
436
437
5.00k
        if (! srec_new_symbol (abfd, symname, symval))
438
0
    goto error_return;
439
5.00k
      }
440
8.01k
    while (c == ' ' || c == '\t')
441
7.92k
      ;
442
443
7.92k
    if (c == '\n')
444
2.31k
      ++lineno;
445
5.60k
    else if (c != '\r')
446
53
      {
447
53
        srec_bad_byte (abfd, lineno, c, error);
448
53
        goto error_return;
449
53
      }
450
451
7.87k
    break;
452
453
10.7k
  case 'S':
454
10.7k
    {
455
10.7k
      file_ptr pos;
456
10.7k
      unsigned char hdr[3];
457
10.7k
      unsigned int bytes, min_bytes;
458
10.7k
      bfd_vma address;
459
10.7k
      bfd_byte *data;
460
10.7k
      unsigned char check_sum;
461
462
      /* Starting an S-record.  */
463
464
10.7k
      pos = bfd_tell (abfd) - 1;
465
466
10.7k
      if (bfd_read (hdr, 3, abfd) != 3)
467
6
        goto error_return;
468
469
10.7k
      if (! ISHEX (hdr[1]) || ! ISHEX (hdr[2]))
470
17
        {
471
17
    if (! ISHEX (hdr[1]))
472
9
      c = hdr[1];
473
8
    else
474
8
      c = hdr[2];
475
17
    srec_bad_byte (abfd, lineno, c, error);
476
17
    goto error_return;
477
17
        }
478
479
10.7k
      check_sum = bytes = HEX (hdr + 1);
480
10.7k
      min_bytes = 3;
481
10.7k
      if (hdr[0] == '2' || hdr[0] == '8')
482
4.70k
        min_bytes = 4;
483
6.06k
      else if (hdr[0] == '3' || hdr[0] == '7')
484
18
        min_bytes = 5;
485
10.7k
      if (bytes < min_bytes)
486
1
        {
487
    /* xgettext:c-format */
488
1
    _bfd_error_handler (_("%pB:%d: byte count %d too small"),
489
1
            abfd, lineno, bytes);
490
1
    bfd_set_error (bfd_error_bad_value);
491
1
    goto error_return;
492
1
        }
493
494
10.7k
      if (bytes * 2 > bufsize)
495
195
        {
496
195
    free (buf);
497
195
    buf = bfd_malloc (bytes * 2);
498
195
    if (buf == NULL)
499
0
      goto error_return;
500
195
    bufsize = bytes * 2;
501
195
        }
502
503
10.7k
      if (bfd_read (buf, bytes * 2, abfd) != bytes * 2)
504
37
        goto error_return;
505
506
      /* Ignore the checksum byte.  */
507
10.7k
      --bytes;
508
509
10.7k
      address = 0;
510
10.7k
      data = buf;
511
10.7k
      switch (hdr[0])
512
10.7k
        {
513
210
        case '0':
514
269
        case '5':
515
    /* Prologue--ignore the file name, but stop building a
516
       section at this point.  */
517
269
    sec = NULL;
518
269
    break;
519
520
11
        case '3':
521
11
    check_sum += HEX (data);
522
11
    address = HEX (data);
523
11
    data += 2;
524
11
    --bytes;
525
    /* Fall through.  */
526
4.69k
        case '2':
527
4.69k
    check_sum += HEX (data);
528
4.69k
    address = (address << 8) | HEX (data);
529
4.69k
    data += 2;
530
4.69k
    --bytes;
531
    /* Fall through.  */
532
8.32k
        case '1':
533
8.32k
    check_sum += HEX (data);
534
8.32k
    address = (address << 8) | HEX (data);
535
8.32k
    data += 2;
536
8.32k
    check_sum += HEX (data);
537
8.32k
    address = (address << 8) | HEX (data);
538
8.32k
    data += 2;
539
8.32k
    bytes -= 2;
540
541
8.32k
    if (sec != NULL
542
5.86k
        && sec->vma + sec->size == address)
543
860
      {
544
        /* This data goes at the end of the section we are
545
           currently building.  */
546
860
        sec->size += bytes;
547
860
      }
548
7.46k
    else
549
7.46k
      {
550
7.46k
        char secbuf[20];
551
7.46k
        char *secname;
552
7.46k
        size_t amt;
553
7.46k
        flagword flags;
554
555
7.46k
        sprintf (secbuf, ".sec%d", bfd_count_sections (abfd) + 1);
556
7.46k
        amt = strlen (secbuf) + 1;
557
7.46k
        secname = (char *) bfd_alloc (abfd, amt);
558
7.46k
        strcpy (secname, secbuf);
559
7.46k
        flags = SEC_HAS_CONTENTS | SEC_LOAD | SEC_ALLOC;
560
7.46k
        sec = bfd_make_section_with_flags (abfd, secname, flags);
561
7.46k
        if (sec == NULL)
562
0
          goto error_return;
563
7.46k
        sec->vma = address;
564
7.46k
        sec->lma = address;
565
7.46k
        sec->size = bytes;
566
7.46k
        sec->filepos = pos;
567
7.46k
      }
568
569
12.2k
    while (bytes > 0)
570
3.92k
      {
571
3.92k
        check_sum += HEX (data);
572
3.92k
        data += 2;
573
3.92k
        bytes--;
574
3.92k
      }
575
8.32k
    check_sum = 255 - (check_sum & 0xff);
576
8.32k
    if (check_sum != HEX (data))
577
39
      {
578
39
        _bfd_error_handler
579
          /* xgettext:c-format */
580
39
          (_("%pB:%d: bad checksum in S-record file"),
581
39
           abfd, lineno);
582
39
        bfd_set_error (bfd_error_bad_value);
583
39
        goto error_return;
584
39
      }
585
586
8.28k
    break;
587
588
8.28k
        case '7':
589
1
    check_sum += HEX (data);
590
1
    address = HEX (data);
591
1
    data += 2;
592
    /* Fall through.  */
593
8
        case '8':
594
8
    check_sum += HEX (data);
595
8
    address = (address << 8) | HEX (data);
596
8
    data += 2;
597
    /* Fall through.  */
598
9
        case '9':
599
9
    check_sum += HEX (data);
600
9
    address = (address << 8) | HEX (data);
601
9
    data += 2;
602
9
    check_sum += HEX (data);
603
9
    address = (address << 8) | HEX (data);
604
9
    data += 2;
605
606
    /* This is a termination record.  */
607
9
    abfd->start_address = address;
608
609
9
    check_sum = 255 - (check_sum & 0xff);
610
9
    if (check_sum != HEX (data))
611
3
      {
612
3
        _bfd_error_handler
613
          /* xgettext:c-format */
614
3
          (_("%pB:%d: bad checksum in S-record file"),
615
3
           abfd, lineno);
616
3
        bfd_set_error (bfd_error_bad_value);
617
3
        goto error_return;
618
3
      }
619
620
6
    free (buf);
621
6
    return true;
622
10.7k
        }
623
10.7k
    }
624
10.6k
    break;
625
30.5k
  }
626
30.5k
    }
627
628
63
  if (error)
629
1
    goto error_return;
630
631
62
  free (buf);
632
62
  return true;
633
634
331
 error_return:
635
331
  free (symbuf);
636
331
  free (buf);
637
331
  return false;
638
63
}
639
640
/* Check whether an existing file is an S-record file.  */
641
642
static bfd_cleanup
643
srec_object_p (bfd *abfd)
644
96.8k
{
645
96.8k
  bfd_byte b[4];
646
647
96.8k
  srec_init ();
648
649
96.8k
  if (bfd_seek (abfd, 0, SEEK_SET) != 0
650
96.8k
      || bfd_read (b, 4, abfd) != 4)
651
247
    return NULL;
652
653
96.5k
  if (b[0] != 'S' || !ISHEX (b[1]) || !ISHEX (b[2]) || !ISHEX (b[3]))
654
96.4k
    {
655
96.4k
      bfd_set_error (bfd_error_wrong_format);
656
96.4k
      return NULL;
657
96.4k
    }
658
659
119
  if (!srec_mkobject (abfd))
660
0
    return NULL;
661
662
119
  if (!srec_scan (abfd))
663
96
    {
664
96
      bfd_release (abfd, abfd->tdata.any);
665
96
      return NULL;
666
96
    }
667
668
23
  if (abfd->symcount > 0)
669
7
    abfd->flags |= HAS_SYMS;
670
671
23
  return _bfd_no_cleanup;
672
119
}
673
674
/* Check whether an existing file is an S-record file with symbols.  */
675
676
static bfd_cleanup
677
symbolsrec_object_p (bfd *abfd)
678
96.8k
{
679
96.8k
  char b[2];
680
681
96.8k
  srec_init ();
682
683
96.8k
  if (bfd_seek (abfd, 0, SEEK_SET) != 0
684
96.8k
      || bfd_read (b, 2, abfd) != 2)
685
190
    return NULL;
686
687
96.6k
  if (b[0] != '$' || b[1] != '$')
688
96.3k
    {
689
96.3k
      bfd_set_error (bfd_error_wrong_format);
690
96.3k
      return NULL;
691
96.3k
    }
692
693
280
  if (!srec_mkobject (abfd))
694
0
    return NULL;
695
696
280
  if (!srec_scan (abfd))
697
235
    {
698
235
      bfd_release (abfd, abfd->tdata.any);
699
235
      return NULL;
700
235
    }
701
702
45
  if (abfd->symcount > 0)
703
17
    abfd->flags |= HAS_SYMS;
704
705
45
  return _bfd_no_cleanup;
706
280
}
707
708
/* Read in the contents of a section in an S-record file.  */
709
710
static bool
711
srec_read_section (bfd *abfd, asection *section, bfd_byte *contents)
712
73
{
713
73
  int c;
714
73
  bfd_size_type sofar = 0;
715
73
  bool error = false;
716
73
  bfd_byte *buf = NULL;
717
73
  size_t bufsize = 0;
718
719
73
  if (bfd_seek (abfd, section->filepos, SEEK_SET) != 0)
720
0
    goto error_return;
721
722
146
  while ((c = srec_get_byte (abfd, &error)) != EOF)
723
141
    {
724
141
      bfd_byte hdr[3];
725
141
      unsigned int bytes;
726
141
      bfd_vma address;
727
141
      bfd_byte *data;
728
729
141
      if (c == '\r' || c == '\n')
730
0
  continue;
731
732
      /* This is called after srec_scan has already been called, so we
733
   ought to know the exact format.  */
734
141
      if (c != 'S')
735
1
  goto error_return;
736
737
140
      if (bfd_read (hdr, 3, abfd) != 3)
738
0
  goto error_return;
739
740
140
      BFD_ASSERT (ISHEX (hdr[1]) && ISHEX (hdr[2]));
741
742
140
      bytes = HEX (hdr + 1);
743
744
140
      if (bytes * 2 > bufsize)
745
75
  {
746
75
    free (buf);
747
75
    buf = bfd_malloc (bytes * 2);
748
75
    if (buf == NULL)
749
0
      goto error_return;
750
75
    bufsize = bytes * 2;
751
75
  }
752
753
140
      if (bfd_read (buf, bytes * 2, abfd) != bytes * 2)
754
0
  goto error_return;
755
756
140
      address = 0;
757
140
      data = buf;
758
140
      switch (hdr[0])
759
140
  {
760
15
  default:
761
15
    if (sofar != section->size)
762
0
      goto error_return;
763
15
    free (buf);
764
15
    return true;
765
766
0
  case '3':
767
0
    address = HEX (data);
768
0
    data += 2;
769
0
    --bytes;
770
    /* Fall through.  */
771
4
  case '2':
772
4
    address = (address << 8) | HEX (data);
773
4
    data += 2;
774
4
    --bytes;
775
    /* Fall through.  */
776
125
  case '1':
777
125
    address = (address << 8) | HEX (data);
778
125
    data += 2;
779
125
    address = (address << 8) | HEX (data);
780
125
    data += 2;
781
125
    bytes -= 2;
782
783
125
    if (address != section->vma + sofar)
784
52
      {
785
        /* We've come to the end of this section.  */
786
52
        if (sofar != section->size)
787
0
    goto error_return;
788
52
        free (buf);
789
52
        return true;
790
52
      }
791
792
    /* Don't consider checksum.  */
793
73
    --bytes;
794
795
146
    while (bytes-- != 0)
796
73
      {
797
73
        contents[sofar] = HEX (data);
798
73
        data += 2;
799
73
        ++sofar;
800
73
      }
801
802
73
    break;
803
140
  }
804
140
    }
805
806
5
  if (error)
807
0
    goto error_return;
808
809
5
  if (sofar != section->size)
810
0
    goto error_return;
811
812
5
  free (buf);
813
5
  return true;
814
815
1
 error_return:
816
1
  free (buf);
817
1
  return false;
818
5
}
819
820
/* Get the contents of a section in an S-record file.  */
821
822
static bool
823
srec_get_section_contents (bfd *abfd,
824
         asection *section,
825
         void * location,
826
         file_ptr offset,
827
         bfd_size_type count)
828
73
{
829
73
  if (count == 0)
830
0
    return true;
831
832
73
  if (offset + count < count
833
73
      || offset + count > section->size)
834
0
    {
835
0
      bfd_set_error (bfd_error_invalid_operation);
836
0
      return false;
837
0
    }
838
839
73
  if (section->used_by_bfd == NULL)
840
73
    {
841
73
      section->used_by_bfd = bfd_alloc (abfd, section->size);
842
73
      if (section->used_by_bfd == NULL)
843
0
  return false;
844
845
73
      if (! srec_read_section (abfd, section,
846
73
             (bfd_byte *) section->used_by_bfd))
847
1
  return false;
848
73
    }
849
850
72
  memcpy (location, (bfd_byte *) section->used_by_bfd + offset,
851
72
    (size_t) count);
852
853
72
  return true;
854
73
}
855
856
/* Set the architecture.  We accept an unknown architecture here.  */
857
858
static bool
859
srec_set_arch_mach (bfd *abfd, enum bfd_architecture arch, unsigned long mach)
860
18
{
861
18
  if (arch != bfd_arch_unknown)
862
0
    return bfd_default_set_arch_mach (abfd, arch, mach);
863
864
18
  abfd->arch_info = & bfd_default_arch_struct;
865
18
  return true;
866
18
}
867
868
/* We have to save up all the Srecords for a splurge before output.  */
869
870
static bool
871
srec_set_section_contents (bfd *abfd,
872
         sec_ptr section,
873
         const void * location,
874
         file_ptr offset,
875
         bfd_size_type bytes_to_do)
876
15
{
877
15
  int opb = bfd_octets_per_byte (abfd, NULL);
878
15
  tdata_type *tdata = abfd->tdata.srec_data;
879
15
  srec_data_list_type *entry;
880
881
15
  entry = (srec_data_list_type *) bfd_alloc (abfd, sizeof (* entry));
882
15
  if (entry == NULL)
883
0
    return false;
884
885
15
  if (bytes_to_do
886
15
      && (section->flags & SEC_ALLOC)
887
15
      && (section->flags & SEC_LOAD))
888
15
    {
889
15
      bfd_byte *data;
890
891
15
      data = (bfd_byte *) bfd_alloc (abfd, bytes_to_do);
892
15
      if (data == NULL)
893
0
  return false;
894
15
      memcpy ((void *) data, location, (size_t) bytes_to_do);
895
896
      /* If _bfd_srec_forceS3 is TRUE then always select S3 records,
897
   regardless of the size of the addresses.  */
898
15
      if (_bfd_srec_forceS3)
899
0
  tdata->type = 3;
900
15
      else if ((section->lma + (offset + bytes_to_do) / opb - 1) <= 0xffff)
901
0
  ;  /* The default, S1, is OK.  */
902
15
      else if ((section->lma + (offset + bytes_to_do) / opb - 1) <= 0xffffff
903
15
         && tdata->type <= 2)
904
15
  tdata->type = 2;
905
0
      else
906
0
  tdata->type = 3;
907
908
15
      entry->data = data;
909
15
      entry->where = section->lma + offset / opb;
910
15
      entry->size = bytes_to_do;
911
912
      /* Sort the records by address.  Optimize for the common case of
913
   adding a record to the end of the list.  */
914
15
      if (tdata->tail != NULL
915
10
    && entry->where >= tdata->tail->where)
916
10
  {
917
10
    tdata->tail->next = entry;
918
10
    entry->next = NULL;
919
10
    tdata->tail = entry;
920
10
  }
921
5
      else
922
5
  {
923
5
    srec_data_list_type **look;
924
925
5
    for (look = &tdata->head;
926
5
         *look != NULL && (*look)->where < entry->where;
927
5
         look = &(*look)->next)
928
0
      ;
929
5
    entry->next = *look;
930
5
    *look = entry;
931
5
    if (entry->next == NULL)
932
5
      tdata->tail = entry;
933
5
  }
934
15
    }
935
15
  return true;
936
15
}
937
938
/* Write a record of type, of the supplied number of bytes. The
939
   supplied bytes and length don't have a checksum. That's worked out
940
   here.  */
941
942
static bool
943
srec_write_record (bfd *abfd,
944
       unsigned int type,
945
       bfd_vma address,
946
       const bfd_byte *data,
947
       const bfd_byte *end)
948
49
{
949
49
  char buffer[2 * MAXCHUNK + 6];
950
49
  unsigned int check_sum = 0;
951
49
  const bfd_byte *src = data;
952
49
  char *dst = buffer;
953
49
  char *length;
954
49
  bfd_size_type wrlen;
955
956
49
  *dst++ = 'S';
957
49
  *dst++ = '0' + type;
958
959
49
  length = dst;
960
49
  dst += 2;     /* Leave room for dst.  */
961
962
49
  switch (type)
963
49
    {
964
0
    case 3:
965
0
    case 7:
966
0
      TOHEX (dst, (address >> 24), check_sum);
967
0
      dst += 2;
968
      /* Fall through.  */
969
5
    case 8:
970
20
    case 2:
971
20
      TOHEX (dst, (address >> 16), check_sum);
972
20
      dst += 2;
973
      /* Fall through.  */
974
32
    case 9:
975
32
    case 1:
976
49
    case 0:
977
49
      TOHEX (dst, (address >> 8), check_sum);
978
49
      dst += 2;
979
49
      TOHEX (dst, (address), check_sum);
980
49
      dst += 2;
981
49
      break;
982
983
49
    }
984
319
  for (src = data; src < end; src++)
985
270
    {
986
270
      TOHEX (dst, *src, check_sum);
987
270
      dst += 2;
988
270
    }
989
990
  /* Fill in the length.  */
991
49
  TOHEX (length, (dst - length) / 2, check_sum);
992
49
  check_sum &= 0xff;
993
49
  check_sum = 255 - check_sum;
994
49
  TOHEX (dst, check_sum, check_sum);
995
49
  dst += 2;
996
997
49
  *dst++ = '\r';
998
49
  *dst++ = '\n';
999
49
  wrlen = dst - buffer;
1000
1001
49
  return bfd_write (buffer, wrlen, abfd) == wrlen;
1002
49
}
1003
1004
static bool
1005
srec_write_header (bfd *abfd)
1006
17
{
1007
17
  unsigned int len = strlen (bfd_get_filename (abfd));
1008
1009
  /* I'll put an arbitrary 40 char limit on header size.  */
1010
17
  if (len > 40)
1011
0
    len = 40;
1012
1013
17
  return srec_write_record (abfd, 0, (bfd_vma) 0,
1014
17
          (bfd_byte *) bfd_get_filename (abfd),
1015
17
          (bfd_byte *) bfd_get_filename (abfd) + len);
1016
17
}
1017
1018
static bool
1019
srec_write_section (bfd *abfd,
1020
        tdata_type *tdata,
1021
        srec_data_list_type *list)
1022
15
{
1023
15
  unsigned int octets_written = 0;
1024
15
  bfd_byte *location = list->data;
1025
1026
  /* Validate number of data bytes to write.  The srec length byte
1027
     counts the address, data and crc bytes.  S1 (tdata->type == 1)
1028
     records have two address bytes, S2 (tdata->type == 2) records
1029
     have three, and S3 (tdata->type == 3) records have four.
1030
     The total length can't exceed 255, and a zero data length will
1031
     spin for a long time.  */
1032
15
  if (_bfd_srec_len == 0)
1033
0
    _bfd_srec_len = 1;
1034
15
  else if (_bfd_srec_len > MAXCHUNK - tdata->type - 2)
1035
0
    _bfd_srec_len = MAXCHUNK - tdata->type - 2;
1036
1037
30
  while (octets_written < list->size)
1038
15
    {
1039
15
      bfd_vma address;
1040
15
      unsigned int octets_this_chunk = list->size - octets_written;
1041
1042
15
      if (octets_this_chunk > _bfd_srec_len)
1043
0
  octets_this_chunk = _bfd_srec_len;
1044
1045
15
      address = list->where + (octets_written
1046
15
             / bfd_octets_per_byte (abfd, NULL));
1047
1048
15
      if (! srec_write_record (abfd,
1049
15
             tdata->type,
1050
15
             address,
1051
15
             location,
1052
15
             location + octets_this_chunk))
1053
0
  return false;
1054
1055
15
      octets_written += octets_this_chunk;
1056
15
      location += octets_this_chunk;
1057
15
    }
1058
1059
15
  return true;
1060
15
}
1061
1062
static bool
1063
srec_write_terminator (bfd *abfd, tdata_type *tdata)
1064
17
{
1065
17
  return srec_write_record (abfd, 10 - tdata->type,
1066
17
          abfd->start_address, NULL, NULL);
1067
17
}
1068
1069
static bool
1070
srec_write_symbols (bfd *abfd)
1071
8
{
1072
  /* Dump out the symbols of a bfd.  */
1073
8
  int i;
1074
8
  int count = bfd_get_symcount (abfd);
1075
1076
8
  if (count)
1077
0
    {
1078
0
      bfd_size_type len;
1079
0
      asymbol **table = bfd_get_outsymbols (abfd);
1080
1081
0
      len = strlen (bfd_get_filename (abfd));
1082
0
      if (bfd_write ("$$ ", 3, abfd) != 3
1083
0
    || bfd_write (bfd_get_filename (abfd), len, abfd) != len
1084
0
    || bfd_write ("\r\n", 2, abfd) != 2)
1085
0
  goto fail;
1086
1087
0
      for (i = 0; i < count; i++)
1088
0
  {
1089
0
    asymbol *s = table[i];
1090
1091
0
    if (! bfd_is_local_label (abfd, s)
1092
0
        && (s->flags & BSF_DEBUGGING) == 0
1093
0
        && s->section != NULL
1094
0
        && s->section->output_section != NULL)
1095
0
      {
1096
        /* Just dump out non debug symbols.  */
1097
0
        char buf[43];
1098
1099
0
        len = strlen (s->name);
1100
0
        if (bfd_write ("  ", 2, abfd) != 2
1101
0
      || bfd_write (s->name, len, abfd) != len)
1102
0
    goto fail;
1103
1104
0
        sprintf (buf, " $%" PRIx64 "\r\n",
1105
0
           (uint64_t) (s->value
1106
0
           + s->section->output_section->lma
1107
0
           + s->section->output_offset));
1108
0
        len = strlen (buf);
1109
0
        if (bfd_write (buf, len, abfd) != len)
1110
0
    goto fail;
1111
0
      }
1112
0
  }
1113
0
      if (bfd_write ("$$ \r\n", 5, abfd) != 5)
1114
0
  goto fail;
1115
0
    }
1116
1117
8
  return true;
1118
1119
0
 fail:
1120
0
  return false;
1121
8
}
1122
1123
static bool
1124
internal_srec_write_object_contents (bfd *abfd, int symbols)
1125
17
{
1126
17
  tdata_type *tdata = abfd->tdata.srec_data;
1127
17
  srec_data_list_type *list;
1128
1129
17
  if (symbols)
1130
8
    {
1131
8
      if (! srec_write_symbols (abfd))
1132
0
  return false;
1133
8
    }
1134
1135
17
  if (! srec_write_header (abfd))
1136
0
    return false;
1137
1138
  /* Now wander though all the sections provided and output them.  */
1139
17
  list = tdata->head;
1140
1141
32
  while (list != (srec_data_list_type *) NULL)
1142
15
    {
1143
15
      if (! srec_write_section (abfd, tdata, list))
1144
0
  return false;
1145
15
      list = list->next;
1146
15
    }
1147
17
  return srec_write_terminator (abfd, tdata);
1148
17
}
1149
1150
static bool
1151
srec_write_object_contents (bfd *abfd)
1152
9
{
1153
9
  return internal_srec_write_object_contents (abfd, 0);
1154
9
}
1155
1156
static bool
1157
symbolsrec_write_object_contents (bfd *abfd)
1158
8
{
1159
8
  return internal_srec_write_object_contents (abfd, 1);
1160
8
}
1161
1162
static int
1163
srec_sizeof_headers (bfd *abfd ATTRIBUTE_UNUSED,
1164
         struct bfd_link_info *info ATTRIBUTE_UNUSED)
1165
0
{
1166
0
  return 0;
1167
0
}
1168
1169
/* Return the amount of memory needed to read the symbol table.  */
1170
1171
static long
1172
srec_get_symtab_upper_bound (bfd *abfd)
1173
32
{
1174
32
  return (bfd_get_symcount (abfd) + 1) * sizeof (asymbol *);
1175
32
}
1176
1177
/* Return the symbol table.  */
1178
1179
static long
1180
srec_canonicalize_symtab (bfd *abfd, asymbol **alocation)
1181
32
{
1182
32
  bfd_size_type symcount = bfd_get_symcount (abfd);
1183
32
  asymbol *csymbols;
1184
32
  unsigned int i;
1185
1186
32
  csymbols = abfd->tdata.srec_data->csymbols;
1187
32
  if (csymbols == NULL && symcount != 0)
1188
14
    {
1189
14
      asymbol *c;
1190
14
      struct srec_symbol *s;
1191
1192
14
      csymbols = (asymbol *) bfd_alloc (abfd, symcount * sizeof (asymbol));
1193
14
      if (csymbols == NULL)
1194
0
  return -1;
1195
14
      abfd->tdata.srec_data->csymbols = csymbols;
1196
1197
14
      for (s = abfd->tdata.srec_data->symbols, c = csymbols;
1198
1.10k
     s != NULL;
1199
1.08k
     s = s->next, ++c)
1200
1.08k
  {
1201
1.08k
    c->the_bfd = abfd;
1202
1.08k
    c->name = s->name;
1203
1.08k
    c->value = s->val;
1204
1.08k
    c->flags = BSF_GLOBAL;
1205
1.08k
    c->section = bfd_abs_section_ptr;
1206
1.08k
    c->udata.p = NULL;
1207
1.08k
  }
1208
14
    }
1209
1210
2.00k
  for (i = 0; i < symcount; i++)
1211
1.97k
    *alocation++ = csymbols++;
1212
32
  *alocation = NULL;
1213
1214
32
  return symcount;
1215
32
}
1216
1217
static void
1218
srec_get_symbol_info (bfd *ignore_abfd ATTRIBUTE_UNUSED,
1219
          asymbol *symbol,
1220
          symbol_info *ret)
1221
883
{
1222
883
  bfd_symbol_info (symbol, ret);
1223
883
}
1224
1225
static void
1226
srec_print_symbol (bfd *abfd,
1227
       void * afile,
1228
       asymbol *symbol,
1229
       bfd_print_symbol_type how)
1230
0
{
1231
0
  FILE *file = (FILE *) afile;
1232
1233
0
  switch (how)
1234
0
    {
1235
0
    case bfd_print_symbol_name:
1236
0
      fprintf (file, "%s", symbol->name);
1237
0
      break;
1238
0
    default:
1239
0
      bfd_print_symbol_vandf (abfd, (void *) file, symbol);
1240
0
      fprintf (file, " %-5s %s",
1241
0
         symbol->section->name,
1242
0
         symbol->name);
1243
0
    }
1244
0
}
1245
1246
#define srec_close_and_cleanup        _bfd_generic_close_and_cleanup
1247
#define srec_bfd_free_cached_info     _bfd_generic_bfd_free_cached_info
1248
#define srec_new_section_hook       _bfd_generic_new_section_hook
1249
#define srec_bfd_is_target_special_symbol   _bfd_bool_bfd_asymbol_false
1250
#define srec_bfd_is_local_label_name      bfd_generic_is_local_label_name
1251
#define srec_get_lineno         _bfd_nosymbols_get_lineno
1252
#define srec_find_nearest_line        _bfd_nosymbols_find_nearest_line
1253
#define srec_find_nearest_line_with_alt     _bfd_nosymbols_find_nearest_line_with_alt
1254
#define srec_find_line          _bfd_nosymbols_find_line
1255
#define srec_find_inliner_info        _bfd_nosymbols_find_inliner_info
1256
#define srec_make_empty_symbol        _bfd_generic_make_empty_symbol
1257
#define srec_get_symbol_version_string      _bfd_nosymbols_get_symbol_version_string
1258
#define srec_bfd_make_debug_symbol      _bfd_nosymbols_bfd_make_debug_symbol
1259
#define srec_read_minisymbols       _bfd_generic_read_minisymbols
1260
#define srec_minisymbol_to_symbol     _bfd_generic_minisymbol_to_symbol
1261
#define srec_bfd_get_relocated_section_contents   bfd_generic_get_relocated_section_contents
1262
#define srec_bfd_relax_section        bfd_generic_relax_section
1263
#define srec_bfd_gc_sections        bfd_generic_gc_sections
1264
#define srec_bfd_lookup_section_flags     bfd_generic_lookup_section_flags
1265
#define srec_bfd_is_group_section     bfd_generic_is_group_section
1266
#define srec_bfd_group_name       bfd_generic_group_name
1267
#define srec_bfd_discard_group        bfd_generic_discard_group
1268
#define srec_section_already_linked     _bfd_generic_section_already_linked
1269
#define srec_bfd_define_common_symbol     bfd_generic_define_common_symbol
1270
#define srec_bfd_link_hide_symbol     _bfd_generic_link_hide_symbol
1271
#define srec_bfd_define_start_stop      bfd_generic_define_start_stop
1272
#define srec_bfd_link_hash_table_create     _bfd_generic_link_hash_table_create
1273
#define srec_bfd_link_add_symbols     _bfd_generic_link_add_symbols
1274
#define srec_bfd_link_just_syms       _bfd_generic_link_just_syms
1275
#define srec_bfd_copy_link_hash_symbol_type   _bfd_generic_copy_link_hash_symbol_type
1276
#define srec_bfd_final_link       _bfd_generic_final_link
1277
#define srec_bfd_link_split_section     _bfd_generic_link_split_section
1278
#define srec_bfd_link_check_relocs      _bfd_generic_link_check_relocs
1279
1280
const bfd_target srec_vec =
1281
{
1282
  "srec",     /* Name.  */
1283
  bfd_target_srec_flavour,
1284
  BFD_ENDIAN_UNKNOWN,   /* Target byte order.  */
1285
  BFD_ENDIAN_UNKNOWN,   /* Target headers byte order.  */
1286
  EXEC_P,     /* Object flags.  */
1287
  (SEC_CODE | SEC_DATA | SEC_ROM | SEC_HAS_CONTENTS
1288
   | SEC_ALLOC | SEC_LOAD), /* Section flags.  */
1289
  0,        /* Leading underscore.  */
1290
  ' ',        /* AR_pad_char.  */
1291
  16,       /* AR_max_namelen.  */
1292
  0,        /* match priority.  */
1293
  TARGET_KEEP_UNUSED_SECTION_SYMBOLS, /* keep unused section symbols.  */
1294
  TARGET_MERGE_SECTIONS,
1295
  bfd_getb64, bfd_getb_signed_64, bfd_putb64,
1296
  bfd_getb32, bfd_getb_signed_32, bfd_putb32,
1297
  bfd_getb16, bfd_getb_signed_16, bfd_putb16, /* Data.  */
1298
  bfd_getb64, bfd_getb_signed_64, bfd_putb64,
1299
  bfd_getb32, bfd_getb_signed_32, bfd_putb32,
1300
  bfd_getb16, bfd_getb_signed_16, bfd_putb16, /* Hdrs.  */
1301
1302
  {
1303
    _bfd_dummy_target,
1304
    srec_object_p,    /* bfd_check_format.  */
1305
    _bfd_dummy_target,
1306
    _bfd_dummy_target,
1307
  },
1308
  {
1309
    _bfd_bool_bfd_false_error,
1310
    srec_mkobject,
1311
    _bfd_bool_bfd_false_error,
1312
    _bfd_bool_bfd_false_error,
1313
  },
1314
  {       /* bfd_write_contents.  */
1315
    _bfd_bool_bfd_false_error,
1316
    srec_write_object_contents,
1317
    _bfd_bool_bfd_false_error,
1318
    _bfd_bool_bfd_false_error,
1319
  },
1320
1321
  BFD_JUMP_TABLE_GENERIC (srec),
1322
  BFD_JUMP_TABLE_COPY (_bfd_generic),
1323
  BFD_JUMP_TABLE_CORE (_bfd_nocore),
1324
  BFD_JUMP_TABLE_ARCHIVE (_bfd_noarchive),
1325
  BFD_JUMP_TABLE_SYMBOLS (srec),
1326
  BFD_JUMP_TABLE_RELOCS (_bfd_norelocs),
1327
  BFD_JUMP_TABLE_WRITE (srec),
1328
  BFD_JUMP_TABLE_LINK (srec),
1329
  BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic),
1330
1331
  NULL,
1332
1333
  NULL
1334
};
1335
1336
const bfd_target symbolsrec_vec =
1337
{
1338
  "symbolsrec",     /* Name.  */
1339
  bfd_target_srec_flavour,
1340
  BFD_ENDIAN_UNKNOWN,   /* Target byte order.  */
1341
  BFD_ENDIAN_UNKNOWN,   /* Target headers byte order.  */
1342
  EXEC_P | HAS_SYMS,    /* Object flags.  */
1343
  (SEC_CODE | SEC_DATA | SEC_ROM | SEC_HAS_CONTENTS
1344
   | SEC_ALLOC | SEC_LOAD), /* Section flags.  */
1345
  0,        /* Leading underscore.  */
1346
  ' ',        /* AR_pad_char.  */
1347
  16,       /* AR_max_namelen.  */
1348
  0,        /* match priority.  */
1349
  TARGET_KEEP_UNUSED_SECTION_SYMBOLS, /* keep unused section symbols.  */
1350
  TARGET_MERGE_SECTIONS,
1351
  bfd_getb64, bfd_getb_signed_64, bfd_putb64,
1352
  bfd_getb32, bfd_getb_signed_32, bfd_putb32,
1353
  bfd_getb16, bfd_getb_signed_16, bfd_putb16, /* Data.  */
1354
  bfd_getb64, bfd_getb_signed_64, bfd_putb64,
1355
  bfd_getb32, bfd_getb_signed_32, bfd_putb32,
1356
  bfd_getb16, bfd_getb_signed_16, bfd_putb16, /* Headers.  */
1357
1358
  {
1359
    _bfd_dummy_target,
1360
    symbolsrec_object_p,  /* bfd_check_format.  */
1361
    _bfd_dummy_target,
1362
    _bfd_dummy_target,
1363
  },
1364
  {
1365
    _bfd_bool_bfd_false_error,
1366
    srec_mkobject,
1367
    _bfd_bool_bfd_false_error,
1368
    _bfd_bool_bfd_false_error,
1369
  },
1370
  {       /* bfd_write_contents.  */
1371
    _bfd_bool_bfd_false_error,
1372
    symbolsrec_write_object_contents,
1373
    _bfd_bool_bfd_false_error,
1374
    _bfd_bool_bfd_false_error,
1375
  },
1376
1377
  BFD_JUMP_TABLE_GENERIC (srec),
1378
  BFD_JUMP_TABLE_COPY (_bfd_generic),
1379
  BFD_JUMP_TABLE_CORE (_bfd_nocore),
1380
  BFD_JUMP_TABLE_ARCHIVE (_bfd_noarchive),
1381
  BFD_JUMP_TABLE_SYMBOLS (srec),
1382
  BFD_JUMP_TABLE_RELOCS (_bfd_norelocs),
1383
  BFD_JUMP_TABLE_WRITE (srec),
1384
  BFD_JUMP_TABLE_LINK (srec),
1385
  BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic),
1386
1387
  NULL,
1388
1389
  NULL
1390
};