summaryrefslogtreecommitdiffstats
path: root/src/util/elf2efi.c
diff options
context:
space:
mode:
authorMichael Brown2009-03-31 08:07:44 +0200
committerMichael Brown2009-03-31 08:07:44 +0200
commitbbd274a1d65947ae28607b94bb2eebbfa6b8e811 (patch)
treea55d88f27487e68a967206e987ce4bf7a0e9a70d /src/util/elf2efi.c
parent[build] Add --divide to ASFLAGS if supported by the assembler (diff)
downloadipxe-bbd274a1d65947ae28607b94bb2eebbfa6b8e811.tar.gz
ipxe-bbd274a1d65947ae28607b94bb2eebbfa6b8e811.tar.xz
ipxe-bbd274a1d65947ae28607b94bb2eebbfa6b8e811.zip
[efi] Use POSIX version of basename() in elf2efi.c
This is required in order to build on Mac OS X. Suggested-by: Joshua Oreman <oremanj@rwcr.net>
Diffstat (limited to 'src/util/elf2efi.c')
-rw-r--r--src/util/elf2efi.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/src/util/elf2efi.c b/src/util/elf2efi.c
index 886777d9..bb766bd3 100644
--- a/src/util/elf2efi.c
+++ b/src/util/elf2efi.c
@@ -29,6 +29,7 @@
#include <bfd.h>
#include <gpxe/efi/efi.h>
#include <gpxe/efi/IndustryStandard/PeImage.h>
+#include <libgen.h>
#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 */