Blame tests/asm-tst7.c.libasm-ebl

Packit 5f0dbf
/* Copyright (C) 2002, 2005 Red Hat, Inc.
Packit 5f0dbf
   This file is part of elfutils.
Packit 5f0dbf
   Written by Ulrich Drepper <drepper@redhat.com>, 2002.
Packit 5f0dbf
Packit 5f0dbf
   This file is free software; you can redistribute it and/or modify
Packit 5f0dbf
   it under the terms of the GNU General Public License as published by
Packit 5f0dbf
   the Free Software Foundation; either version 3 of the License, or
Packit 5f0dbf
   (at your option) any later version.
Packit 5f0dbf
Packit 5f0dbf
   elfutils is distributed in the hope that it will be useful, but
Packit 5f0dbf
   WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 5f0dbf
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit 5f0dbf
   GNU General Public License for more details.
Packit 5f0dbf
Packit 5f0dbf
   You should have received a copy of the GNU General Public License
Packit 5f0dbf
   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
Packit 5f0dbf
Packit 5f0dbf
#ifdef HAVE_CONFIG_H
Packit 5f0dbf
# include <config.h>
Packit 5f0dbf
#endif
Packit 5f0dbf
Packit 5f0dbf
#include <fcntl.h>
Packit 5f0dbf
#include <inttypes.h>
Packit 5f0dbf
#include ELFUTILS_HEADER(asm)
Packit 5f0dbf
#include <libelf.h>
Packit 5f0dbf
#include <stdio.h>
Packit 5f0dbf
#include <unistd.h>
Packit 5f0dbf
Packit 5f0dbf
Packit 5f0dbf
static const char fname[] = "asm-tst7-out.o";
Packit 5f0dbf
Packit 5f0dbf
Packit 5f0dbf
int
Packit 5f0dbf
main (void)
Packit 5f0dbf
{
Packit 5f0dbf
  int result = 0;
Packit 5f0dbf
  size_t cnt;
Packit 5f0dbf
  AsmCtx_t *ctx;
Packit 5f0dbf
  Elf *elf;
Packit 5f0dbf
  int fd;
Packit 5f0dbf
Packit 5f0dbf
  elf_version (EV_CURRENT);
Packit 5f0dbf
Packit 5f0dbf
  Ebl *ebl = ebl_openbackend_machine (EM_386);
Packit 5f0dbf
  if (ebl == NULL)
Packit 5f0dbf
    {
Packit 5f0dbf
      puts ("cannot open backend library");
Packit 5f0dbf
      return 1;
Packit 5f0dbf
    }
Packit 5f0dbf
Packit 5f0dbf
  ctx = asm_begin (fname, ebl, false);
Packit 5f0dbf
  if (ctx == NULL)
Packit 5f0dbf
    {
Packit 5f0dbf
      printf ("cannot create assembler context: %s\n", asm_errmsg (-1));
Packit 5f0dbf
      return 1;
Packit 5f0dbf
    }
Packit 5f0dbf
Packit 5f0dbf
  if (asm_newcomsym (ctx, "commsym", 4, 16) == NULL)
Packit 5f0dbf
    {
Packit 5f0dbf
      printf ("cannot create common symbol: %s\n", asm_errmsg (-1));
Packit 5f0dbf
      asm_abort (ctx);
Packit 5f0dbf
      return 1;
Packit 5f0dbf
    }
Packit 5f0dbf
Packit 5f0dbf
  /* Create the output file.  */
Packit 5f0dbf
  if (asm_end (ctx) != 0)
Packit 5f0dbf
    {
Packit 5f0dbf
      printf ("cannot create output file: %s\n", asm_errmsg (-1));
Packit 5f0dbf
      asm_abort (ctx);
Packit 5f0dbf
      return 1;
Packit 5f0dbf
    }
Packit 5f0dbf
Packit 5f0dbf
  /* Check the file.  */
Packit 5f0dbf
  fd = open (fname, O_RDONLY);
Packit 5f0dbf
  if (fd == -1)
Packit 5f0dbf
    {
Packit 5f0dbf
      printf ("cannot open generated file: %m\n");
Packit 5f0dbf
      result = 1;
Packit 5f0dbf
      goto out;
Packit 5f0dbf
    }
Packit 5f0dbf
Packit 5f0dbf
  elf = elf_begin (fd, ELF_C_READ, NULL);
Packit 5f0dbf
  if (elf == NULL)
Packit 5f0dbf
    {
Packit 5f0dbf
      printf ("cannot create ELF descriptor: %s\n", elf_errmsg (-1));
Packit 5f0dbf
      result = 1;
Packit 5f0dbf
      goto out_close;
Packit 5f0dbf
    }
Packit 5f0dbf
  if (elf_kind (elf) != ELF_K_ELF)
Packit 5f0dbf
    {
Packit 5f0dbf
      puts ("not a valid ELF file");
Packit 5f0dbf
      result = 1;
Packit 5f0dbf
      goto out_close2;
Packit 5f0dbf
    }
Packit 5f0dbf
Packit 5f0dbf
  for (cnt = 1; 1; ++cnt)
Packit 5f0dbf
    {
Packit 5f0dbf
      Elf_Scn *scn;
Packit 5f0dbf
      GElf_Shdr shdr_mem;
Packit 5f0dbf
      GElf_Shdr *shdr;
Packit 5f0dbf
Packit 5f0dbf
      scn = elf_getscn (elf, cnt);
Packit 5f0dbf
      if (scn == NULL)
Packit 5f0dbf
	{
Packit 5f0dbf
	  printf ("cannot get section %zd: %s\n", cnt, elf_errmsg (-1));
Packit 5f0dbf
	  result = 1;
Packit 5f0dbf
	  continue;
Packit 5f0dbf
	}
Packit 5f0dbf
Packit 5f0dbf
      shdr = gelf_getshdr (scn, &shdr_mem);
Packit 5f0dbf
      if (shdr == NULL)
Packit 5f0dbf
	{
Packit 5f0dbf
	  printf ("cannot get section header for section %zd: %s\n",
Packit 5f0dbf
		  cnt, elf_errmsg (-1));
Packit 5f0dbf
	  result = 1;
Packit 5f0dbf
	  continue;
Packit 5f0dbf
	}
Packit 5f0dbf
      /* We are looking for the symbol table.  */
Packit 5f0dbf
      if (shdr->sh_type != SHT_SYMTAB)
Packit 5f0dbf
	continue;
Packit 5f0dbf
Packit 5f0dbf
      for (cnt = 1; cnt< (shdr->sh_size
Packit 5f0dbf
			  / gelf_fsize (elf, ELF_T_SYM, 1, EV_CURRENT));
Packit 5f0dbf
	   ++cnt)
Packit 5f0dbf
	{
Packit 5f0dbf
	  GElf_Sym sym_mem;
Packit 5f0dbf
	  GElf_Sym *sym;
Packit 5f0dbf
Packit 5f0dbf
	  if (cnt > 1)
Packit 5f0dbf
	    {
Packit 5f0dbf
	      puts ("too many symbol");
Packit 5f0dbf
	      result = 1;
Packit 5f0dbf
	      break;
Packit 5f0dbf
	    }
Packit 5f0dbf
Packit 5f0dbf
	  sym = gelf_getsym (elf_getdata (scn, NULL), cnt, &sym_mem);
Packit 5f0dbf
	  if (sym == NULL)
Packit 5f0dbf
	    {
Packit 5f0dbf
	      printf ("cannot get symbol %zu: %s\n", cnt, elf_errmsg (-1));
Packit 5f0dbf
	      result = 1;
Packit 5f0dbf
	    }
Packit 5f0dbf
	  else
Packit 5f0dbf
	    {
Packit 5f0dbf
	      if (sym->st_shndx != SHN_COMMON)
Packit 5f0dbf
		{
Packit 5f0dbf
		  printf ("expected common symbol, got section %u\n",
Packit 5f0dbf
			  (unsigned int) sym->st_shndx);
Packit 5f0dbf
		  result = 1;
Packit 5f0dbf
		}
Packit 5f0dbf
Packit 5f0dbf
	      if (sym->st_value != 16)
Packit 5f0dbf
		{
Packit 5f0dbf
		  printf ("requested alignment 16, is %" PRIuMAX "\n",
Packit 5f0dbf
			  (uintmax_t) sym->st_value);
Packit 5f0dbf
		  result = 1;
Packit 5f0dbf
		}
Packit 5f0dbf
Packit 5f0dbf
	      if (sym->st_size != 4)
Packit 5f0dbf
		{
Packit 5f0dbf
		  printf ("requested size 4, is %" PRIuMAX "\n",
Packit 5f0dbf
			  (uintmax_t) sym->st_value);
Packit 5f0dbf
		  result = 1;
Packit 5f0dbf
		}
Packit 5f0dbf
	    }
Packit 5f0dbf
	}
Packit 5f0dbf
Packit 5f0dbf
      break;
Packit 5f0dbf
    }
Packit 5f0dbf
Packit 5f0dbf
 out_close2:
Packit 5f0dbf
  elf_end (elf);
Packit 5f0dbf
 out_close:
Packit 5f0dbf
  close (fd);
Packit 5f0dbf
 out:
Packit 5f0dbf
  /* We don't need the file anymore.  */
Packit 5f0dbf
  unlink (fname);
Packit 5f0dbf
Packit 5f0dbf
  ebl_closebackend (ebl);
Packit 5f0dbf
Packit 5f0dbf
  return result;
Packit 5f0dbf
}