/* Copyright (C) 1999, 2000, 2001, 2002 Red Hat, Inc. Written by Ulrich Drepper <drepper@redhat.com>, 1999. 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 <config.h> #include <libelf.h> #include <stdio.h> #include <stdlib.h> #include <unistd.h> static void print_ehdr (Elf32_Ehdr *ehdr) { int n; for (n = 0; n < EI_NIDENT; ++n) printf (" %02x", ehdr->e_ident[n]); printf ("\ntype = %d\nmachine = %d\nversion = %d\nentry = %d\n" "phoff = %d\nshoff = %d\nflags = %d\nehsize = %d\n" "phentsize = %d\nphnum = %d\nshentsize = %d\nshnum = %d\n" "shstrndx = %d\n", ehdr->e_type, ehdr->e_machine, ehdr->e_version, ehdr->e_entry, ehdr->e_phoff, ehdr->e_shoff, ehdr->e_flags, ehdr->e_ehsize, ehdr->e_phentsize, ehdr->e_phnum, ehdr->e_shentsize, ehdr->e_shnum, ehdr->e_shstrndx); } int main (int argc, char *argv[]) { Elf *elf; int result = 0; int fd; char fname[] = "newfile-XXXXXX"; fd = mkstemp (fname); if (fd == -1) { printf ("cannot create temporary file: %m\n"); exit (1); } /* Remove the file when we exit. */ unlink (fname); elf_version (EV_CURRENT); elf = elf_begin (fd, ELF_C_WRITE, NULL); if (elf == NULL) { printf ("elf_begin: %s\n", elf_errmsg (-1)); result = 1; } else { if (elf32_newehdr (elf) == NULL) { printf ("elf32_newehdr: %s\n", elf_errmsg (-1)); result = 1; } else { Elf32_Ehdr *ehdr = elf32_getehdr (elf); if (ehdr == NULL) { printf ("elf32_getehdr: %s\n", elf_errmsg (-1)); result = 1; } else { int i; if (argc > 1) /* Use argc as a debugging flag. */ print_ehdr (ehdr); /* Some tests. */ for (i = 0; i < EI_NIDENT; ++i) if (ehdr->e_ident[i] != 0) { printf ("ehdr->e_ident[%d] != 0\n", i); result = 1; break; } #define VALUE_TEST(name, val) \ if (ehdr->name != val) \ { \ printf ("ehdr->%s != %d\n", #name, val); \ result = 1; \ } #define ZERO_TEST(name) VALUE_TEST (name, 0) ZERO_TEST (e_type); ZERO_TEST (e_machine); ZERO_TEST (e_version); ZERO_TEST (e_entry); ZERO_TEST (e_phoff); ZERO_TEST (e_shoff); ZERO_TEST (e_flags); ZERO_TEST (e_ehsize); ZERO_TEST (e_phentsize); ZERO_TEST (e_phnum); ZERO_TEST (e_shentsize); ZERO_TEST (e_shnum); ZERO_TEST (e_shstrndx); if (elf32_newphdr (elf, 10) == NULL) { printf ("elf32_newphdr: %s\n", elf_errmsg (-1)); result = 1; } else { if (argc > 1) print_ehdr (ehdr); ehdr = elf32_getehdr (elf); if (ehdr == NULL) { printf ("elf32_getehdr (#2): %s\n", elf_errmsg (-1)); result = 1; } else { ZERO_TEST (e_type); ZERO_TEST (e_machine); ZERO_TEST (e_version); ZERO_TEST (e_entry); ZERO_TEST (e_phoff); ZERO_TEST (e_shoff); ZERO_TEST (e_flags); ZERO_TEST (e_ehsize); VALUE_TEST (e_phentsize, (int) sizeof (Elf32_Phdr)); VALUE_TEST (e_phnum, 10); ZERO_TEST (e_shentsize); ZERO_TEST (e_shnum); ZERO_TEST (e_shstrndx); } } } } (void) elf_end (elf); } return result; }