From: Michael Brown Date: Tue, 31 Mar 2009 06:07:44 +0000 (+0100) Subject: [efi] Use POSIX version of basename() in elf2efi.c X-Git-Tag: v0.9.8~176 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=bbd274a1d65947ae28607b94bb2eebbfa6b8e811;p=thirdparty%2Fipxe.git [efi] Use POSIX version of basename() in elf2efi.c This is required in order to build on Mac OS X. Suggested-by: Joshua Oreman --- diff --git a/src/util/elf2efi.c b/src/util/elf2efi.c index 886777d96..bb766bd37 100644 --- a/src/util/elf2efi.c +++ b/src/util/elf2efi.c @@ -29,6 +29,7 @@ #include #include #include +#include #define eprintf(...) fprintf ( stderr, __VA_ARGS__ ) @@ -658,6 +659,7 @@ static void write_pe_file ( struct pe_header *pe_header, */ static void elf2pe ( const char *elf_name, const char *pe_name, struct options *opts ) { + char pe_name_tmp[ strlen ( pe_name ) + 1 ]; bfd *bfd; asymbol **symtab; asection *section; @@ -669,6 +671,9 @@ static void elf2pe ( const char *elf_name, const char *pe_name, struct pe_header pe_header; FILE *pe; + /* Create a modifiable copy of the PE name */ + memcpy ( pe_name_tmp, pe_name, sizeof ( pe_name_tmp ) ); + /* Open the file */ bfd = open_input_bfd ( elf_name ); symtab = read_symtab ( bfd ); @@ -703,7 +708,7 @@ static void elf2pe ( const char *elf_name, const char *pe_name, /* Create the .reloc section */ *(next_pe_section) = create_debug_section ( &pe_header, - basename ( pe_name ) ); + basename ( pe_name_tmp ) ); next_pe_section = &(*next_pe_section)->next; /* Write out PE file */