OpenCores
URL https://opencores.org/ocsvn/or1k/or1k/trunk

Subversion Repositories or1k

[/] [or1k/] [trunk/] [insight/] [bfd/] [cisco-core.c] - Diff between revs 578 and 1765

Go to most recent revision | Only display areas with differences | Details | Blame | View Log

Rev 578 Rev 1765
/* BFD back-end for CISCO crash dumps.
/* BFD back-end for CISCO crash dumps.
 
 
Copyright 1994, 1997, 1999, 2000 Free Software Foundation, Inc.
Copyright 1994, 1997, 1999, 2000 Free Software Foundation, Inc.
 
 
This file is part of BFD, the Binary File Descriptor library.
This file is part of BFD, the Binary File Descriptor library.
 
 
This program is free software; you can redistribute it and/or modify
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
(at your option) any later version.
 
 
This program is distributed in the hope that it will be useful,
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
GNU General Public License for more details.
GNU General Public License for more details.
 
 
You should have received a copy of the GNU General Public License
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  */
 
 
#include "bfd.h"
#include "bfd.h"
#include "sysdep.h"
#include "sysdep.h"
#include "libbfd.h"
#include "libbfd.h"
/* core_file_failing_signal returns a host signal (this probably should
/* core_file_failing_signal returns a host signal (this probably should
   be fixed).  */
   be fixed).  */
#include <signal.h>
#include <signal.h>
 
 
/* for MSVC builds */
/* for MSVC builds */
#ifndef SIGTRAP
#ifndef SIGTRAP
# define SIGTRAP 5
# define SIGTRAP 5
#endif
#endif
#ifndef SIGEMT
#ifndef SIGEMT
# define SIGEMT 6
# define SIGEMT 6
#endif
#endif
#ifndef SIGBUS
#ifndef SIGBUS
# define SIGBUS 10
# define SIGBUS 10
#endif
#endif


int crash_info_locs[] = {
int crash_info_locs[] = {
  0x0250,       /* mips, ppc, x86, i960 */
  0x0250,       /* mips, ppc, x86, i960 */
  0x0400,       /* m68k, mips, x86, i960 */
  0x0400,       /* m68k, mips, x86, i960 */
  0x0FFC,       /* m68k, mips, ppc, x86, i960 */
  0x0FFC,       /* m68k, mips, ppc, x86, i960 */
  0x3000,       /* ppc */
  0x3000,       /* ppc */
  0x4FFC,       /* m68k */
  0x4FFC,       /* m68k */
  -1
  -1
};
};
 
 
#define CRASH_MAGIC     0xdead1234
#define CRASH_MAGIC     0xdead1234
#define MASK_ADDR(x)    ((x) & 0x0fffffff)      /* Mask crash info address */
#define MASK_ADDR(x)    ((x) & 0x0fffffff)      /* Mask crash info address */
 
 
typedef enum {
typedef enum {
    CRASH_REASON_NOTCRASHED = 0,
    CRASH_REASON_NOTCRASHED = 0,
    CRASH_REASON_EXCEPTION = 1,
    CRASH_REASON_EXCEPTION = 1,
    CRASH_REASON_CORRUPT = 2,
    CRASH_REASON_CORRUPT = 2,
} crashreason;
} crashreason;
 
 
typedef struct {
typedef struct {
  char magic[4];                /* Magic number */
  char magic[4];                /* Magic number */
  char version[4];              /* Version number */
  char version[4];              /* Version number */
  char reason[4];               /* Crash reason */
  char reason[4];               /* Crash reason */
  char cpu_vector[4];           /* CPU vector for exceptions */
  char cpu_vector[4];           /* CPU vector for exceptions */
  char registers[4];            /* Pointer to saved registers */
  char registers[4];            /* Pointer to saved registers */
  char rambase[4];              /* Base of RAM (not in V1 crash info) */
  char rambase[4];              /* Base of RAM (not in V1 crash info) */
  char textbase[4];             /* Base of .text section (not in V3 crash info) */
  char textbase[4];             /* Base of .text section (not in V3 crash info) */
  char database[4];             /* Base of .data section (not in V3 crash info) */
  char database[4];             /* Base of .data section (not in V3 crash info) */
  char bssbase[4];              /* Base of .bss section (not in V3 crash info) */
  char bssbase[4];              /* Base of .bss section (not in V3 crash info) */
} crashinfo_external;
} crashinfo_external;


struct cisco_core_struct
struct cisco_core_struct
{
{
  int sig;
  int sig;
};
};


/* Examine the file for a crash info struct at the offset given by
/* Examine the file for a crash info struct at the offset given by
   CRASH_INFO_LOC.  */
   CRASH_INFO_LOC.  */
 
 
static const bfd_target *
static const bfd_target *
cisco_core_file_validate (abfd, crash_info_loc)
cisco_core_file_validate (abfd, crash_info_loc)
     bfd *abfd;
     bfd *abfd;
     int crash_info_loc;
     int crash_info_loc;
{
{
  char buf[4];
  char buf[4];
  unsigned int crashinfo_offset;
  unsigned int crashinfo_offset;
  crashinfo_external crashinfo;
  crashinfo_external crashinfo;
  int nread;
  int nread;
  unsigned int magic;
  unsigned int magic;
  unsigned int version;
  unsigned int version;
  unsigned int rambase;
  unsigned int rambase;
  sec_ptr asect;
  sec_ptr asect;
  struct stat statbuf;
  struct stat statbuf;
 
 
  if (bfd_seek (abfd, crash_info_loc, SEEK_SET) != 0)
  if (bfd_seek (abfd, crash_info_loc, SEEK_SET) != 0)
    return NULL;
    return NULL;
 
 
  nread = bfd_read (buf, 1, 4, abfd);
  nread = bfd_read (buf, 1, 4, abfd);
  if (nread != 4)
  if (nread != 4)
    {
    {
      if (bfd_get_error () != bfd_error_system_call)
      if (bfd_get_error () != bfd_error_system_call)
        bfd_set_error (bfd_error_wrong_format);
        bfd_set_error (bfd_error_wrong_format);
      return NULL;
      return NULL;
    }
    }
  crashinfo_offset = MASK_ADDR (bfd_get_32 (abfd, buf));
  crashinfo_offset = MASK_ADDR (bfd_get_32 (abfd, buf));
 
 
  if (bfd_seek (abfd, crashinfo_offset, SEEK_SET) != 0)
  if (bfd_seek (abfd, crashinfo_offset, SEEK_SET) != 0)
    {
    {
      /* Most likely we failed because of a bogus (huge) offset */
      /* Most likely we failed because of a bogus (huge) offset */
      bfd_set_error (bfd_error_wrong_format);
      bfd_set_error (bfd_error_wrong_format);
      return NULL;
      return NULL;
    }
    }
 
 
  nread = bfd_read (&crashinfo, 1, sizeof (crashinfo), abfd);
  nread = bfd_read (&crashinfo, 1, sizeof (crashinfo), abfd);
  if (nread != sizeof (crashinfo))
  if (nread != sizeof (crashinfo))
    {
    {
      if (bfd_get_error () != bfd_error_system_call)
      if (bfd_get_error () != bfd_error_system_call)
        bfd_set_error (bfd_error_wrong_format);
        bfd_set_error (bfd_error_wrong_format);
      return NULL;
      return NULL;
    }
    }
 
 
  if (bfd_stat (abfd, &statbuf) < 0)
  if (bfd_stat (abfd, &statbuf) < 0)
    {
    {
      bfd_set_error (bfd_error_system_call);
      bfd_set_error (bfd_error_system_call);
      return NULL;
      return NULL;
    }
    }
 
 
  magic = bfd_get_32 (abfd, crashinfo.magic);
  magic = bfd_get_32 (abfd, crashinfo.magic);
  if (magic != CRASH_MAGIC)
  if (magic != CRASH_MAGIC)
    {
    {
      bfd_set_error (bfd_error_wrong_format);
      bfd_set_error (bfd_error_wrong_format);
      return NULL;
      return NULL;
    }
    }
 
 
  version = bfd_get_32 (abfd, crashinfo.version);
  version = bfd_get_32 (abfd, crashinfo.version);
  if (version == 0)
  if (version == 0)
    {
    {
      bfd_set_error (bfd_error_wrong_format);
      bfd_set_error (bfd_error_wrong_format);
      return NULL;
      return NULL;
    }
    }
  else if (version == 1)
  else if (version == 1)
    {
    {
      /* V1 core dumps don't specify the dump base, assume 0 */
      /* V1 core dumps don't specify the dump base, assume 0 */
      rambase = 0;
      rambase = 0;
    }
    }
  else
  else
    {
    {
      rambase = bfd_get_32 (abfd, crashinfo.rambase);
      rambase = bfd_get_32 (abfd, crashinfo.rambase);
    }
    }
 
 
  /* OK, we believe you.  You're a core file.  */
  /* OK, we believe you.  You're a core file.  */
 
 
  abfd->tdata.cisco_core_data =
  abfd->tdata.cisco_core_data =
    ((struct cisco_core_struct *)
    ((struct cisco_core_struct *)
     bfd_zmalloc (sizeof (struct cisco_core_struct)));
     bfd_zmalloc (sizeof (struct cisco_core_struct)));
  if (abfd->tdata.cisco_core_data == NULL)
  if (abfd->tdata.cisco_core_data == NULL)
    return NULL;
    return NULL;
 
 
  switch ((crashreason) bfd_get_32 (abfd, crashinfo.reason))
  switch ((crashreason) bfd_get_32 (abfd, crashinfo.reason))
    {
    {
    case CRASH_REASON_NOTCRASHED:
    case CRASH_REASON_NOTCRASHED:
      /* Crash file probably came from write core.  */
      /* Crash file probably came from write core.  */
      abfd->tdata.cisco_core_data->sig = 0;
      abfd->tdata.cisco_core_data->sig = 0;
      break;
      break;
    case CRASH_REASON_CORRUPT:
    case CRASH_REASON_CORRUPT:
      /* The crash context area was corrupt -- proceed with caution.
      /* The crash context area was corrupt -- proceed with caution.
         We have no way of passing this information back to the caller.  */
         We have no way of passing this information back to the caller.  */
      abfd->tdata.cisco_core_data->sig = 0;
      abfd->tdata.cisco_core_data->sig = 0;
      break;
      break;
    case CRASH_REASON_EXCEPTION:
    case CRASH_REASON_EXCEPTION:
      /* Crash occured due to CPU exception.  */
      /* Crash occured due to CPU exception.  */
 
 
      /* This is 68k-specific; for MIPS we'll need to interpret
      /* This is 68k-specific; for MIPS we'll need to interpret
         cpu_vector differently based on the target configuration
         cpu_vector differently based on the target configuration
         (since CISCO core files don't seem to have the processor
         (since CISCO core files don't seem to have the processor
         encoded in them).  */
         encoded in them).  */
 
 
      switch (bfd_get_32 (abfd, crashinfo.cpu_vector))
      switch (bfd_get_32 (abfd, crashinfo.cpu_vector))
        {
        {
           /* bus error           */
           /* bus error           */
        case 2 : abfd->tdata.cisco_core_data->sig = SIGBUS; break;
        case 2 : abfd->tdata.cisco_core_data->sig = SIGBUS; break;
           /* address error       */
           /* address error       */
        case 3 : abfd->tdata.cisco_core_data->sig = SIGBUS; break;
        case 3 : abfd->tdata.cisco_core_data->sig = SIGBUS; break;
           /* illegal instruction */
           /* illegal instruction */
        case 4 : abfd->tdata.cisco_core_data->sig = SIGILL;  break;
        case 4 : abfd->tdata.cisco_core_data->sig = SIGILL;  break;
           /* zero divide         */
           /* zero divide         */
        case 5 : abfd->tdata.cisco_core_data->sig = SIGFPE;  break;
        case 5 : abfd->tdata.cisco_core_data->sig = SIGFPE;  break;
           /* chk instruction     */
           /* chk instruction     */
        case 6 : abfd->tdata.cisco_core_data->sig = SIGFPE; break;
        case 6 : abfd->tdata.cisco_core_data->sig = SIGFPE; break;
           /* trapv instruction   */
           /* trapv instruction   */
        case 7 : abfd->tdata.cisco_core_data->sig = SIGFPE; break;
        case 7 : abfd->tdata.cisco_core_data->sig = SIGFPE; break;
           /* privilege violation */
           /* privilege violation */
        case 8 : abfd->tdata.cisco_core_data->sig = SIGSEGV; break;
        case 8 : abfd->tdata.cisco_core_data->sig = SIGSEGV; break;
           /* trace trap          */
           /* trace trap          */
        case 9 : abfd->tdata.cisco_core_data->sig = SIGTRAP;  break;
        case 9 : abfd->tdata.cisco_core_data->sig = SIGTRAP;  break;
           /* line 1010 emulator  */
           /* line 1010 emulator  */
        case 10: abfd->tdata.cisco_core_data->sig = SIGILL;  break;
        case 10: abfd->tdata.cisco_core_data->sig = SIGILL;  break;
           /* line 1111 emulator  */
           /* line 1111 emulator  */
        case 11: abfd->tdata.cisco_core_data->sig = SIGILL;  break;
        case 11: abfd->tdata.cisco_core_data->sig = SIGILL;  break;
 
 
          /* Coprocessor protocol violation.  Using a standard MMU or FPU
          /* Coprocessor protocol violation.  Using a standard MMU or FPU
             this cannot be triggered by software.  Call it a SIGBUS.  */
             this cannot be triggered by software.  Call it a SIGBUS.  */
        case 13: abfd->tdata.cisco_core_data->sig = SIGBUS;  break;
        case 13: abfd->tdata.cisco_core_data->sig = SIGBUS;  break;
 
 
          /* interrupt           */
          /* interrupt           */
        case 31: abfd->tdata.cisco_core_data->sig = SIGINT;  break;
        case 31: abfd->tdata.cisco_core_data->sig = SIGINT;  break;
          /* breakpoint          */
          /* breakpoint          */
        case 33: abfd->tdata.cisco_core_data->sig = SIGTRAP;  break;
        case 33: abfd->tdata.cisco_core_data->sig = SIGTRAP;  break;
 
 
          /* floating point err  */
          /* floating point err  */
        case 48: abfd->tdata.cisco_core_data->sig = SIGFPE;  break;
        case 48: abfd->tdata.cisco_core_data->sig = SIGFPE;  break;
          /* floating point err  */
          /* floating point err  */
        case 49: abfd->tdata.cisco_core_data->sig = SIGFPE;  break;
        case 49: abfd->tdata.cisco_core_data->sig = SIGFPE;  break;
          /* zero divide         */
          /* zero divide         */
        case 50: abfd->tdata.cisco_core_data->sig = SIGFPE;  break;
        case 50: abfd->tdata.cisco_core_data->sig = SIGFPE;  break;
          /* underflow           */
          /* underflow           */
        case 51: abfd->tdata.cisco_core_data->sig = SIGFPE;  break;
        case 51: abfd->tdata.cisco_core_data->sig = SIGFPE;  break;
          /* operand error       */
          /* operand error       */
        case 52: abfd->tdata.cisco_core_data->sig = SIGFPE;  break;
        case 52: abfd->tdata.cisco_core_data->sig = SIGFPE;  break;
           /* overflow            */
           /* overflow            */
        case 53: abfd->tdata.cisco_core_data->sig = SIGFPE;  break;
        case 53: abfd->tdata.cisco_core_data->sig = SIGFPE;  break;
          /* NAN                 */
          /* NAN                 */
        case 54: abfd->tdata.cisco_core_data->sig = SIGFPE;  break;
        case 54: abfd->tdata.cisco_core_data->sig = SIGFPE;  break;
        default:
        default:
#ifndef SIGEMT
#ifndef SIGEMT
#define SIGEMT SIGTRAP
#define SIGEMT SIGTRAP
#endif
#endif
          /* "software generated"*/
          /* "software generated"*/
          abfd->tdata.cisco_core_data->sig = SIGEMT;
          abfd->tdata.cisco_core_data->sig = SIGEMT;
        }
        }
      break;
      break;
    default:
    default:
      /* Unknown crash reason.  */
      /* Unknown crash reason.  */
      abfd->tdata.cisco_core_data->sig = 0;
      abfd->tdata.cisco_core_data->sig = 0;
      break;
      break;
    }
    }
 
 
  abfd->sections = NULL;
  abfd->sections = NULL;
  abfd->section_count = 0;
  abfd->section_count = 0;
 
 
  /* Create a ".reg" section to allow access to the saved
  /* Create a ".reg" section to allow access to the saved
     registers.  */
     registers.  */
 
 
  asect = (asection *) bfd_zmalloc (sizeof (asection));
  asect = (asection *) bfd_zmalloc (sizeof (asection));
  if (asect == NULL)
  if (asect == NULL)
    goto error_return;
    goto error_return;
  asect->name = ".reg";
  asect->name = ".reg";
  asect->flags = SEC_HAS_CONTENTS;
  asect->flags = SEC_HAS_CONTENTS;
  asect->vma = 0;
  asect->vma = 0;
  asect->filepos = bfd_get_32 (abfd, crashinfo.registers) - rambase;
  asect->filepos = bfd_get_32 (abfd, crashinfo.registers) - rambase;
  /* Since we don't know the exact size of the saved register info,
  /* Since we don't know the exact size of the saved register info,
     choose a register section size that is either the remaining part
     choose a register section size that is either the remaining part
     of the file, or 1024, whichever is smaller.  */
     of the file, or 1024, whichever is smaller.  */
  nread = statbuf.st_size - asect->filepos;
  nread = statbuf.st_size - asect->filepos;
  asect->_raw_size = (nread < 1024) ? nread : 1024;
  asect->_raw_size = (nread < 1024) ? nread : 1024;
  asect->next = abfd->sections;
  asect->next = abfd->sections;
  abfd->sections = asect;
  abfd->sections = asect;
  ++abfd->section_count;
  ++abfd->section_count;
 
 
  /* Create a ".crash" section to allow access to the saved
  /* Create a ".crash" section to allow access to the saved
     crash information.  */
     crash information.  */
 
 
  asect = (asection *) bfd_zmalloc (sizeof (asection));
  asect = (asection *) bfd_zmalloc (sizeof (asection));
  if (asect == NULL)
  if (asect == NULL)
    goto error_return;
    goto error_return;
  asect->name = ".crash";
  asect->name = ".crash";
  asect->flags = SEC_HAS_CONTENTS;
  asect->flags = SEC_HAS_CONTENTS;
  asect->vma = 0;
  asect->vma = 0;
  asect->filepos = crashinfo_offset;
  asect->filepos = crashinfo_offset;
  asect->_raw_size = sizeof (crashinfo);
  asect->_raw_size = sizeof (crashinfo);
  asect->next = abfd->sections;
  asect->next = abfd->sections;
  abfd->sections = asect;
  abfd->sections = asect;
  ++abfd->section_count;
  ++abfd->section_count;
 
 
  /* Create a ".data" section that maps the entire file, which is
  /* Create a ".data" section that maps the entire file, which is
     essentially a dump of the target system's RAM.  */
     essentially a dump of the target system's RAM.  */
 
 
  asect = (asection *) bfd_zmalloc (sizeof (asection));
  asect = (asection *) bfd_zmalloc (sizeof (asection));
  if (asect == NULL)
  if (asect == NULL)
    goto error_return;
    goto error_return;
  asect->name = ".data";
  asect->name = ".data";
  asect->flags = SEC_ALLOC | SEC_LOAD | SEC_HAS_CONTENTS;
  asect->flags = SEC_ALLOC | SEC_LOAD | SEC_HAS_CONTENTS;
  /* The size of memory is the size of the core file itself.  */
  /* The size of memory is the size of the core file itself.  */
  asect->_raw_size = statbuf.st_size;
  asect->_raw_size = statbuf.st_size;
  asect->vma = rambase;
  asect->vma = rambase;
  asect->filepos = 0;
  asect->filepos = 0;
  asect->next = abfd->sections;
  asect->next = abfd->sections;
  abfd->sections = asect;
  abfd->sections = asect;
  ++abfd->section_count;
  ++abfd->section_count;
 
 
  return abfd->xvec;
  return abfd->xvec;
 
 
  /* Get here if we have already started filling out the BFD
  /* Get here if we have already started filling out the BFD
     and there is an error of some kind.  */
     and there is an error of some kind.  */
 
 
 error_return:
 error_return:
  {
  {
    sec_ptr nextsect;
    sec_ptr nextsect;
    for (asect = abfd->sections; asect != NULL;)
    for (asect = abfd->sections; asect != NULL;)
      {
      {
        nextsect = asect->next;
        nextsect = asect->next;
        free (asect);
        free (asect);
        asect = nextsect;
        asect = nextsect;
      }
      }
    free (abfd->tdata.cisco_core_data);
    free (abfd->tdata.cisco_core_data);
    return NULL;
    return NULL;
  }
  }
}
}
 
 
static const bfd_target *
static const bfd_target *
cisco_core_file_p (abfd)
cisco_core_file_p (abfd)
     bfd *abfd;
     bfd *abfd;
{
{
  int *crash_info_locp;
  int *crash_info_locp;
  const bfd_target *target = NULL;
  const bfd_target *target = NULL;
 
 
  for (crash_info_locp = crash_info_locs;
  for (crash_info_locp = crash_info_locs;
       *crash_info_locp != -1  &&  target == NULL;
       *crash_info_locp != -1  &&  target == NULL;
       crash_info_locp++)
       crash_info_locp++)
    {
    {
      target = cisco_core_file_validate (abfd, *crash_info_locp);
      target = cisco_core_file_validate (abfd, *crash_info_locp);
    }
    }
  return (target);
  return (target);
}
}
 
 
char *
char *
cisco_core_file_failing_command (abfd)
cisco_core_file_failing_command (abfd)
     bfd *abfd;
     bfd *abfd;
{
{
  return NULL;
  return NULL;
}
}
 
 
int
int
cisco_core_file_failing_signal (abfd)
cisco_core_file_failing_signal (abfd)
     bfd *abfd;
     bfd *abfd;
{
{
  return abfd->tdata.cisco_core_data->sig;
  return abfd->tdata.cisco_core_data->sig;
}
}
 
 
boolean
boolean
cisco_core_file_matches_executable_p (core_bfd, exec_bfd)
cisco_core_file_matches_executable_p (core_bfd, exec_bfd)
     bfd *core_bfd;
     bfd *core_bfd;
     bfd *exec_bfd;
     bfd *exec_bfd;
{
{
  return true;
  return true;
}
}


extern const bfd_target cisco_core_little_vec;
extern const bfd_target cisco_core_little_vec;
 
 
const bfd_target cisco_core_big_vec =
const bfd_target cisco_core_big_vec =
  {
  {
    "cisco-ios-core-big",
    "cisco-ios-core-big",
    bfd_target_unknown_flavour,
    bfd_target_unknown_flavour,
    BFD_ENDIAN_BIG,             /* target byte order */
    BFD_ENDIAN_BIG,             /* target byte order */
    BFD_ENDIAN_BIG,             /* target headers byte order */
    BFD_ENDIAN_BIG,             /* target headers byte order */
    (HAS_RELOC | EXEC_P |       /* object flags */
    (HAS_RELOC | EXEC_P |       /* object flags */
     HAS_LINENO | HAS_DEBUG |
     HAS_LINENO | HAS_DEBUG |
     HAS_SYMS | HAS_LOCALS | WP_TEXT | D_PAGED),
     HAS_SYMS | HAS_LOCALS | WP_TEXT | D_PAGED),
    (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC), /* section flags */
    (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC), /* section flags */
    0,                                                      /* symbol prefix */
    0,                                                      /* symbol prefix */
    ' ',                                                   /* ar_pad_char */
    ' ',                                                   /* ar_pad_char */
    16,                                                    /* ar_max_namelen */
    16,                                                    /* ar_max_namelen */
    bfd_getb64, bfd_getb_signed_64, bfd_putb64,
    bfd_getb64, bfd_getb_signed_64, bfd_putb64,
    bfd_getb32, bfd_getb_signed_32, bfd_putb32,
    bfd_getb32, bfd_getb_signed_32, bfd_putb32,
    bfd_getb16, bfd_getb_signed_16, bfd_putb16, /* data */
    bfd_getb16, bfd_getb_signed_16, bfd_putb16, /* data */
    bfd_getb64, bfd_getb_signed_64, bfd_putb64,
    bfd_getb64, bfd_getb_signed_64, bfd_putb64,
    bfd_getb32, bfd_getb_signed_32, bfd_putb32,
    bfd_getb32, bfd_getb_signed_32, bfd_putb32,
    bfd_getb16, bfd_getb_signed_16, bfd_putb16, /* hdrs */
    bfd_getb16, bfd_getb_signed_16, bfd_putb16, /* hdrs */
 
 
    {                           /* bfd_check_format */
    {                           /* bfd_check_format */
     _bfd_dummy_target,         /* unknown format */
     _bfd_dummy_target,         /* unknown format */
     _bfd_dummy_target,         /* object file */
     _bfd_dummy_target,         /* object file */
     _bfd_dummy_target,         /* archive */
     _bfd_dummy_target,         /* archive */
     cisco_core_file_p  /* a core file */
     cisco_core_file_p  /* a core file */
    },
    },
    {                           /* bfd_set_format */
    {                           /* bfd_set_format */
     bfd_false, bfd_false,
     bfd_false, bfd_false,
     bfd_false, bfd_false
     bfd_false, bfd_false
    },
    },
    {                           /* bfd_write_contents */
    {                           /* bfd_write_contents */
     bfd_false, bfd_false,
     bfd_false, bfd_false,
     bfd_false, bfd_false
     bfd_false, bfd_false
    },
    },
 
 
       BFD_JUMP_TABLE_GENERIC (_bfd_generic),
       BFD_JUMP_TABLE_GENERIC (_bfd_generic),
       BFD_JUMP_TABLE_COPY (_bfd_generic),
       BFD_JUMP_TABLE_COPY (_bfd_generic),
       BFD_JUMP_TABLE_CORE (cisco),
       BFD_JUMP_TABLE_CORE (cisco),
       BFD_JUMP_TABLE_ARCHIVE (_bfd_noarchive),
       BFD_JUMP_TABLE_ARCHIVE (_bfd_noarchive),
       BFD_JUMP_TABLE_SYMBOLS (_bfd_nosymbols),
       BFD_JUMP_TABLE_SYMBOLS (_bfd_nosymbols),
       BFD_JUMP_TABLE_RELOCS (_bfd_norelocs),
       BFD_JUMP_TABLE_RELOCS (_bfd_norelocs),
       BFD_JUMP_TABLE_WRITE (_bfd_generic),
       BFD_JUMP_TABLE_WRITE (_bfd_generic),
       BFD_JUMP_TABLE_LINK (_bfd_nolink),
       BFD_JUMP_TABLE_LINK (_bfd_nolink),
       BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic),
       BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic),
 
 
    & cisco_core_little_vec,
    & cisco_core_little_vec,
 
 
    (PTR) 0                      /* backend_data */
    (PTR) 0                      /* backend_data */
};
};
 
 
const bfd_target cisco_core_little_vec =
const bfd_target cisco_core_little_vec =
  {
  {
    "cisco-ios-core-little",
    "cisco-ios-core-little",
    bfd_target_unknown_flavour,
    bfd_target_unknown_flavour,
    BFD_ENDIAN_LITTLE,          /* target byte order */
    BFD_ENDIAN_LITTLE,          /* target byte order */
    BFD_ENDIAN_LITTLE,          /* target headers byte order */
    BFD_ENDIAN_LITTLE,          /* target headers byte order */
    (HAS_RELOC | EXEC_P |       /* object flags */
    (HAS_RELOC | EXEC_P |       /* object flags */
     HAS_LINENO | HAS_DEBUG |
     HAS_LINENO | HAS_DEBUG |
     HAS_SYMS | HAS_LOCALS | WP_TEXT | D_PAGED),
     HAS_SYMS | HAS_LOCALS | WP_TEXT | D_PAGED),
    (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC), /* section flags */
    (SEC_HAS_CONTENTS | SEC_ALLOC | SEC_LOAD | SEC_RELOC), /* section flags */
    0,                                                      /* symbol prefix */
    0,                                                      /* symbol prefix */
    ' ',                                                   /* ar_pad_char */
    ' ',                                                   /* ar_pad_char */
    16,                                                    /* ar_max_namelen */
    16,                                                    /* ar_max_namelen */
    bfd_getl64, bfd_getl_signed_64, bfd_putl64,
    bfd_getl64, bfd_getl_signed_64, bfd_putl64,
    bfd_getl32, bfd_getl_signed_32, bfd_putl32,
    bfd_getl32, bfd_getl_signed_32, bfd_putl32,
    bfd_getl16, bfd_getl_signed_16, bfd_putl16, /* data */
    bfd_getl16, bfd_getl_signed_16, bfd_putl16, /* data */
    bfd_getl64, bfd_getl_signed_64, bfd_putl64,
    bfd_getl64, bfd_getl_signed_64, bfd_putl64,
    bfd_getl32, bfd_getl_signed_32, bfd_putl32,
    bfd_getl32, bfd_getl_signed_32, bfd_putl32,
    bfd_getl16, bfd_getl_signed_16, bfd_putl16, /* hdrs */
    bfd_getl16, bfd_getl_signed_16, bfd_putl16, /* hdrs */
 
 
    {                           /* bfd_check_format */
    {                           /* bfd_check_format */
     _bfd_dummy_target,         /* unknown format */
     _bfd_dummy_target,         /* unknown format */
     _bfd_dummy_target,         /* object file */
     _bfd_dummy_target,         /* object file */
     _bfd_dummy_target,         /* archive */
     _bfd_dummy_target,         /* archive */
     cisco_core_file_p  /* a core file */
     cisco_core_file_p  /* a core file */
    },
    },
    {                           /* bfd_set_format */
    {                           /* bfd_set_format */
     bfd_false, bfd_false,
     bfd_false, bfd_false,
     bfd_false, bfd_false
     bfd_false, bfd_false
    },
    },
    {                           /* bfd_write_contents */
    {                           /* bfd_write_contents */
     bfd_false, bfd_false,
     bfd_false, bfd_false,
     bfd_false, bfd_false
     bfd_false, bfd_false
    },
    },
 
 
       BFD_JUMP_TABLE_GENERIC (_bfd_generic),
       BFD_JUMP_TABLE_GENERIC (_bfd_generic),
       BFD_JUMP_TABLE_COPY (_bfd_generic),
       BFD_JUMP_TABLE_COPY (_bfd_generic),
       BFD_JUMP_TABLE_CORE (cisco),
       BFD_JUMP_TABLE_CORE (cisco),
       BFD_JUMP_TABLE_ARCHIVE (_bfd_noarchive),
       BFD_JUMP_TABLE_ARCHIVE (_bfd_noarchive),
       BFD_JUMP_TABLE_SYMBOLS (_bfd_nosymbols),
       BFD_JUMP_TABLE_SYMBOLS (_bfd_nosymbols),
       BFD_JUMP_TABLE_RELOCS (_bfd_norelocs),
       BFD_JUMP_TABLE_RELOCS (_bfd_norelocs),
       BFD_JUMP_TABLE_WRITE (_bfd_generic),
       BFD_JUMP_TABLE_WRITE (_bfd_generic),
       BFD_JUMP_TABLE_LINK (_bfd_nolink),
       BFD_JUMP_TABLE_LINK (_bfd_nolink),
       BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic),
       BFD_JUMP_TABLE_DYNAMIC (_bfd_nodynamic),
 
 
    &cisco_core_big_vec,
    &cisco_core_big_vec,
 
 
    (PTR) 0                      /* backend_data */
    (PTR) 0                      /* backend_data */
};
};
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.