Blame tests/dwarf-getmacros.c

Packit Service 97d2fb
/* Test program for dwarf_getmacros and related
Packit Service 97d2fb
   Copyright (C) 2009, 2014 Red Hat, Inc.
Packit Service 97d2fb
   This file is part of elfutils.
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 the GNU General Public License as published by
Packit Service 97d2fb
   the Free Software Foundation; either version 3 of the License, or
Packit Service 97d2fb
   (at your option) any later version.
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
Packit Service 97d2fb
   GNU General Public License for more details.
Packit Service 97d2fb
Packit Service 97d2fb
   You should have received a copy of the GNU General Public License
Packit Service 97d2fb
   along with this program.  If not, see <http://www.gnu.org/licenses/>.  */
Packit Service 97d2fb
Packit Service 97d2fb
#include <config.h>
Packit Service 97d2fb
#include ELFUTILS_HEADER(dw)
Packit Service 97d2fb
#include <dwarf.h>
Packit Service 97d2fb
#include <sys/types.h>
Packit Service 97d2fb
#include <sys/stat.h>
Packit Service 97d2fb
#include <fcntl.h>
Packit Service 97d2fb
#include <stdio.h>
Packit Service 97d2fb
#include <stdint.h>
Packit Service 97d2fb
#include <stdlib.h>
Packit Service 97d2fb
#include <assert.h>
Packit Service 97d2fb
#include <inttypes.h>
Packit Service 97d2fb
Packit Service 97d2fb
static void include (Dwarf *dbg, Dwarf_Off macoff, ptrdiff_t token);
Packit Service 97d2fb
Packit Service 97d2fb
static int
Packit Service 97d2fb
mac (Dwarf_Macro *macro, void *dbg)
Packit Service 97d2fb
{
Packit Service 97d2fb
  static int level = 0;
Packit Service 97d2fb
Packit Service 97d2fb
  unsigned int opcode;
Packit Service 97d2fb
  dwarf_macro_opcode (macro, &opcode);
Packit Service 97d2fb
  switch (opcode)
Packit Service 97d2fb
    {
Packit Service 97d2fb
    case DW_MACRO_import:
Packit Service 97d2fb
      {
Packit Service 97d2fb
	Dwarf_Attribute at;
Packit Service 97d2fb
	int r = dwarf_macro_param (macro, 0, &at);
Packit Service 97d2fb
	assert (r == 0);
Packit Service 97d2fb
Packit Service 97d2fb
	Dwarf_Word w;
Packit Service 97d2fb
	r = dwarf_formudata (&at, &w);
Packit Service 97d2fb
	assert (r == 0);
Packit Service 97d2fb
Packit Service 97d2fb
	printf ("%*sinclude %#" PRIx64 "\n", level, "", w);
Packit Service 97d2fb
	++level;
Packit Service 97d2fb
	include (dbg, w, DWARF_GETMACROS_START);
Packit Service 97d2fb
	--level;
Packit Service 97d2fb
	printf ("%*s/include\n", level, "");
Packit Service 97d2fb
	break;
Packit Service 97d2fb
      }
Packit Service 97d2fb
Packit Service 97d2fb
    case DW_MACRO_start_file:
Packit Service 97d2fb
      {
Packit Service 97d2fb
	Dwarf_Files *files;
Packit Service 97d2fb
	size_t nfiles;
Packit Service 97d2fb
	if (dwarf_macro_getsrcfiles (dbg, macro, &files, &nfiles) < 0)
Packit Service 97d2fb
	  printf ("dwarf_macro_getsrcfiles: %s\n",
Packit Service 97d2fb
		  dwarf_errmsg (dwarf_errno ()));
Packit Service 97d2fb
Packit Service 97d2fb
	Dwarf_Word w = 0;
Packit Service 97d2fb
	dwarf_macro_param2 (macro, &w, NULL);
Packit Service 97d2fb
Packit Service 97d2fb
	const char *name = dwarf_filesrc (files, (size_t) w, NULL, NULL);
Packit Service 97d2fb
	printf ("%*sfile %s\n", level, "", name);
Packit Service 97d2fb
	++level;
Packit Service 97d2fb
	break;
Packit Service 97d2fb
      }
Packit Service 97d2fb
Packit Service 97d2fb
    case DW_MACRO_end_file:
Packit Service 97d2fb
      {
Packit Service 97d2fb
	--level;
Packit Service 97d2fb
	printf ("%*s/file\n", level, "");
Packit Service 97d2fb
	break;
Packit Service 97d2fb
      }
Packit Service 97d2fb
Packit Service 97d2fb
    case DW_MACINFO_define:
Packit Service 97d2fb
    case DW_MACRO_define_strp:
Packit Service 97d2fb
      {
Packit Service 97d2fb
	const char *value;
Packit Service 97d2fb
	dwarf_macro_param2 (macro, NULL, &value);
Packit Service 97d2fb
	printf ("%*s%s\n", level, "", value);
Packit Service 97d2fb
	break;
Packit Service 97d2fb
      }
Packit Service 97d2fb
Packit Service 97d2fb
    case DW_MACINFO_undef:
Packit Service 97d2fb
    case DW_MACRO_undef_strp:
Packit Service 97d2fb
      break;
Packit Service 97d2fb
Packit Service 97d2fb
    default:
Packit Service 97d2fb
      {
Packit Service 97d2fb
	size_t paramcnt;
Packit Service 97d2fb
	dwarf_macro_getparamcnt (macro, &paramcnt);
Packit Service 97d2fb
	printf ("%*sopcode %u with %zd arguments\n",
Packit Service 97d2fb
		level, "", opcode, paramcnt);
Packit Service 97d2fb
	break;
Packit Service 97d2fb
      }
Packit Service 97d2fb
    }
Packit Service 97d2fb
Packit Service 97d2fb
  return DWARF_CB_ABORT;
Packit Service 97d2fb
}
Packit Service 97d2fb
Packit Service 97d2fb
static void
Packit Service 97d2fb
include (Dwarf *dbg, Dwarf_Off macoff, ptrdiff_t token)
Packit Service 97d2fb
{
Packit Service 97d2fb
  while ((token = dwarf_getmacros_off (dbg, macoff, mac, dbg, token)) != 0)
Packit Service 97d2fb
    if (token == -1)
Packit Service 97d2fb
      {
Packit Service 97d2fb
	puts (dwarf_errmsg (dwarf_errno ()));
Packit Service 97d2fb
	break;
Packit Service 97d2fb
      }
Packit Service 97d2fb
}
Packit Service 97d2fb
Packit Service 97d2fb
int
Packit Service 97d2fb
main (int argc, char *argv[])
Packit Service 97d2fb
{
Packit Service 97d2fb
  assert (argc >= 3);
Packit Service 97d2fb
  const char *name = argv[1];
Packit Service 97d2fb
  ptrdiff_t cuoff = strtol (argv[2], NULL, 0);
Packit Service 97d2fb
  bool new_style = argc > 3;
Packit Service 97d2fb
Packit Service 97d2fb
  int fd = open (name, O_RDONLY);
Packit Service 97d2fb
  Dwarf *dbg = dwarf_begin (fd, DWARF_C_READ);
Packit Service 97d2fb
Packit Service 97d2fb
  Dwarf_Die cudie_mem, *cudie = dwarf_offdie (dbg, cuoff, &cudie_mem);
Packit Service 97d2fb
Packit Service 97d2fb
  for (ptrdiff_t off = new_style ? DWARF_GETMACROS_START : 0;
Packit Service 97d2fb
       (off = dwarf_getmacros (cudie, mac, dbg, off)); )
Packit Service 97d2fb
    if (off == -1)
Packit Service 97d2fb
      {
Packit Service 97d2fb
	puts (dwarf_errmsg (dwarf_errno ()));
Packit Service 97d2fb
	break;
Packit Service 97d2fb
      }
Packit Service 97d2fb
Packit Service 97d2fb
  dwarf_end (dbg);
Packit Service 97d2fb
Packit Service 97d2fb
  return 0;
Packit Service 97d2fb
}