aboutsummaryrefslogtreecommitdiff
path: root/ld/emultempl
diff options
context:
space:
mode:
authorNick Clifton <nickc@redhat.com>2011-12-01 11:38:32 +0000
committerNick Clifton <nickc@redhat.com>2011-12-01 11:38:32 +0000
commit87f1617a4f71347db8f9bd7f257f729bc08f2d31 (patch)
tree69bdfebda250a06aff3ef24f98049e41ad05a6b3 /ld/emultempl
parentfc0ae648aa229713c8c2f104dc413db8019ec899 (diff)
downloadfsf-binutils-gdb-87f1617a4f71347db8f9bd7f257f729bc08f2d31.zip
fsf-binutils-gdb-87f1617a4f71347db8f9bd7f257f729bc08f2d31.tar.gz
fsf-binutils-gdb-87f1617a4f71347db8f9bd7f257f729bc08f2d31.tar.bz2
* emultempl/spuelf.em (spu_elf_relink): Use pex_one in place
of execvp.
Diffstat (limited to 'ld/emultempl')
-rw-r--r--ld/emultempl/spuelf.em17
1 files changed, 14 insertions, 3 deletions
diff --git a/ld/emultempl/spuelf.em b/ld/emultempl/spuelf.em
index 92f2d16..714d33d 100644
--- a/ld/emultempl/spuelf.em
+++ b/ld/emultempl/spuelf.em
@@ -384,9 +384,13 @@ spu_elf_open_overlay_script (void)
return script;
}
+#include <errno.h>
+
static void
spu_elf_relink (void)
{
+ const char *pex_return;
+ int status;
char **argv = xmalloc ((my_argc + 4) * sizeof (*argv));
memcpy (argv, my_argv, my_argc * sizeof (*argv));
@@ -397,9 +401,16 @@ spu_elf_relink (void)
argv[my_argc++] = "-T";
argv[my_argc++] = auto_overlay_file;
argv[my_argc] = 0;
- execvp (argv[0], (char *const *) argv);
- perror (argv[0]);
- _exit (127);
+
+ pex_return = pex_one (PEX_SEARCH | PEX_LAST, (const char *) argv[0],
+ (char * const *) argv, (const char *) argv[0],
+ NULL, NULL, & status, & errno);
+ if (pex_return != NULL)
+ {
+ perror (pex_return);
+ _exit (127);
+ }
+ exit (status);
}
/* Final emulation specific call. */