Blame libelf/elf32_xlatetom.c

Packit Service 97d2fb
/* Convert from file to memory representation.
Packit Service 97d2fb
   Copyright (C) 1998, 1999, 2000, 2002, 2012, 2015 Red Hat, Inc.
Packit Service 97d2fb
   This file is part of elfutils.
Packit Service 97d2fb
   Written by Ulrich Drepper <drepper@redhat.com>, 1998.
Packit Service 97d2fb
Packit Service 97d2fb
   This file is free software; you can redistribute it and/or modify
Packit Service 97d2fb
   it under the terms of either
Packit Service 97d2fb
Packit Service 97d2fb
     * the GNU Lesser General Public License as published by the Free
Packit Service 97d2fb
       Software Foundation; either version 3 of the License, or (at
Packit Service 97d2fb
       your option) any later version
Packit Service 97d2fb
Packit Service 97d2fb
   or
Packit Service 97d2fb
Packit Service 97d2fb
     * the GNU General Public License as published by the Free
Packit Service 97d2fb
       Software Foundation; either version 2 of the License, or (at
Packit Service 97d2fb
       your option) any later version
Packit Service 97d2fb
Packit Service 97d2fb
   or both in parallel, as here.
Packit Service 97d2fb
Packit Service 97d2fb
   elfutils is distributed in the hope that it will be useful, but
Packit Service 97d2fb
   WITHOUT ANY WARRANTY; without even the implied warranty of
Packit Service 97d2fb
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit Service 97d2fb
   General Public License for more details.
Packit Service 97d2fb
Packit Service 97d2fb
   You should have received copies of the GNU General Public License and
Packit Service 97d2fb
   the GNU Lesser General Public License along with this program.  If
Packit Service 97d2fb
   not, see <http://www.gnu.org/licenses/>.  */
Packit Service 97d2fb
Packit Service 97d2fb
#ifdef HAVE_CONFIG_H
Packit Service 97d2fb
# include <config.h>
Packit Service 97d2fb
#endif
Packit Service 97d2fb
Packit Service 97d2fb
#include <assert.h>
Packit Service 97d2fb
#include <endian.h>
Packit Service 97d2fb
#include <string.h>
Packit Service 97d2fb
Packit Service 97d2fb
#include "libelfP.h"
Packit Service 97d2fb
Packit Service 97d2fb
#ifndef LIBELFBITS
Packit Service 97d2fb
# define LIBELFBITS	32
Packit Service 97d2fb
#endif
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
Elf_Data *
Packit Service 97d2fb
elfw2(LIBELFBITS, xlatetom) (Elf_Data *dest, const Elf_Data *src,
Packit Service 97d2fb
			     unsigned int encode)
Packit Service 97d2fb
{
Packit Service 97d2fb
  /* First test whether the input data is really suitable for this
Packit Service 97d2fb
     type.  This means, whether there is an integer number of records.
Packit Service 97d2fb
     Note that for this implementation the memory and file size of the
Packit Service 97d2fb
     data types are identical.  */
Packit Service 97d2fb
  size_t recsize = __libelf_type_sizes[ELFW(ELFCLASS,LIBELFBITS) - 1][src->d_type];
Packit Service 97d2fb
Packit Service 97d2fb
Packit Service 97d2fb
  /* We shouldn't require integer number of records when processing
Packit Service 97d2fb
     notes.  Payload bytes follow the header immediately, it's not an
Packit Service 97d2fb
     array of records as is the case otherwise.  */
Packit Service 97d2fb
  if (src->d_type != ELF_T_NHDR && src->d_type != ELF_T_NHDR8
Packit Service 97d2fb
      && src->d_size % recsize != 0)
Packit Service 97d2fb
    {
Packit Service 97d2fb
      __libelf_seterrno (ELF_E_INVALID_DATA);
Packit Service 97d2fb
      return NULL;
Packit Service 97d2fb
    }
Packit Service 97d2fb
Packit Service 97d2fb
  /* Next see whether the converted data fits in the output buffer.  */
Packit Service 97d2fb
  if (src->d_size > dest->d_size)
Packit Service 97d2fb
    {
Packit Service 97d2fb
      __libelf_seterrno (ELF_E_DEST_SIZE);
Packit Service 97d2fb
      return NULL;
Packit Service 97d2fb
    }
Packit Service 97d2fb
Packit Service 97d2fb
  /* Test the encode parameter.  */
Packit Service 97d2fb
  if (encode != ELFDATA2LSB && encode != ELFDATA2MSB)
Packit Service 97d2fb
    {
Packit Service 97d2fb
      __libelf_seterrno (ELF_E_INVALID_ENCODING);
Packit Service 97d2fb
      return NULL;
Packit Service 97d2fb
    }
Packit Service 97d2fb
Packit Service 97d2fb
  /* Determine the translation function to use.
Packit Service 97d2fb
Packit Service 97d2fb
     At this point we make an assumption which is valid for all
Packit Service 97d2fb
     existing implementations so far: the memory and file sizes are
Packit Service 97d2fb
     the same.  This has very important consequences:
Packit Service 97d2fb
     a) The requirement that the source and destination buffer can
Packit Service 97d2fb
	overlap can easily be fulfilled.
Packit Service 97d2fb
     b) We need only one function to convert from and memory to file
Packit Service 97d2fb
	and vice versa since the function only has to copy and/or
Packit Service 97d2fb
	change the byte order.
Packit Service 97d2fb
  */
Packit Service 97d2fb
  if ((BYTE_ORDER == LITTLE_ENDIAN && encode == ELFDATA2LSB)
Packit Service 97d2fb
      || (BYTE_ORDER == BIG_ENDIAN && encode == ELFDATA2MSB))
Packit Service 97d2fb
    {
Packit Service 97d2fb
      /* We simply have to copy since the byte order is the same.  */
Packit Service 97d2fb
      if (src->d_buf != dest->d_buf)
Packit Service 97d2fb
	memmove (dest->d_buf, src->d_buf, src->d_size);
Packit Service 97d2fb
    }
Packit Service 97d2fb
  else
Packit Service 97d2fb
    {
Packit Service 97d2fb
      xfct_t fctp;
Packit Service 97d2fb
      fctp = __elf_xfctstom[ELFW(ELFCLASS, LIBELFBITS) - 1][src->d_type];
Packit Service 97d2fb
Packit Service 97d2fb
      /* Do the real work.  */
Packit Service 97d2fb
      (*fctp) (dest->d_buf, src->d_buf, src->d_size, 0);
Packit Service 97d2fb
    }
Packit Service 97d2fb
Packit Service 97d2fb
  /* Now set the real destination type and length since the operation was
Packit Service 97d2fb
     successful.  */
Packit Service 97d2fb
  dest->d_type = src->d_type;
Packit Service 97d2fb
  dest->d_size = src->d_size;
Packit Service 97d2fb
Packit Service 97d2fb
  return dest;
Packit Service 97d2fb
}
Packit Service 97d2fb
INTDEF(elfw2(LIBELFBITS, xlatetom))