/* Copyright (C) 2002 Red Hat, Inc.
Written by Ulrich Drepper <drepper@redhat.com>, 2002.
This program is Open Source software; you can redistribute it and/or
modify it under the terms of the Open Software License version 1.0 as
published by the Open Source Initiative.
You should have received a copy of the Open Software License along
with this program; if not, you may obtain a copy of the Open Software
License version 1.0 from http://www.opensource.org/licenses/osl.php or
by writing the Open Source Initiative c/o Lawrence Rosen, Esq.,
3001 King Ranch Road, Ukiah, CA 95482. */
#include <fcntl.h>
#include <libelf.h>
#include <libdw.h>
#include <stdio.h>
#include <unistd.h>
static int globcnt;
static int
callback (Dwarf *dbg, Dwarf_Global *gl, void *arg)
{
int result = DWARF_CB_OK;
printf (" [%2d] \"%s\", die: %llu, cu: %llu\n",
globcnt++, gl->name, (unsigned long long int) gl->die_offset,
(unsigned long long int) gl->cu_offset);
Dwarf_Die cu_die;
const char *cuname;
if (dwarf_offdie (dbg, gl->cu_offset, &cu_die) == NULL
|| (cuname = dwarf_diename (&cu_die)) == NULL)
{
puts ("failed to get CU die");
result = DWARF_CB_ABORT;
}
else
printf ("CU name: \"%s\"\n", cuname);
const char *diename;
Dwarf_Die die;
if (dwarf_offdie (dbg, gl->die_offset, &die) == NULL
|| (diename = dwarf_diename (&die)) == NULL)
{
puts ("failed to get object die");
result = DWARF_CB_ABORT;
}
else
printf ("object name: \"%s\"\n", diename);
return result;
}
int
main (int argc, char *argv[])
{
int result = 0;
int cnt;
for (cnt = 1; cnt < argc; ++cnt)
{
int fd = open (argv[cnt], O_RDONLY);
Dwarf *dbg = dwarf_begin (fd, DWARF_C_READ);
if (dbg == NULL)
{
printf ("%s not usable: %s\n", argv[cnt], dwarf_errmsg (-1));
result = 1;
close (fd);
continue;
}
globcnt = 0;
if (dwarf_getpubnames (dbg, callback, NULL, 0) != 0)
{
printf ("dwarf_get_pubnames didn't return zero: %s\n",
dwarf_errmsg (-1));
result = 1;
}
dwarf_end (dbg);
close (fd);
}
return result;
}