diff options
author | bellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162> | 2003-02-18 23:32:15 +0000 |
---|---|---|
committer | bellard <bellard@c046a42c-6fe2-441c-8c8c-71466251a162> | 2003-02-18 23:32:15 +0000 |
commit | b17780d52186c8bd94c722f6fc00d6d6b9fdcc5f (patch) | |
tree | cca0bc22d09a158da136c18d81fe0062b0c50b4f | |
parent | 3431395696562c63d7bcec10e1307ef6feac31aa (diff) | |
download | qemu-b17780d52186c8bd94c722f6fc00d6d6b9fdcc5f.zip qemu-b17780d52186c8bd94c722f6fc00d6d6b9fdcc5f.tar.gz qemu-b17780d52186c8bd94c722f6fc00d6d6b9fdcc5f.tar.bz2 |
endianness fixes
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@7 c046a42c-6fe2-441c-8c8c-71466251a162
-rw-r--r-- | linux-user/elfload.c | 36 |
1 files changed, 18 insertions, 18 deletions
diff --git a/linux-user/elfload.c b/linux-user/elfload.c index 0ee4f13..43d989e 100644 --- a/linux-user/elfload.c +++ b/linux-user/elfload.c @@ -335,9 +335,8 @@ static unsigned int * create_elf_tables(char *p, int argc, int envc, unsigned long interp_load_addr, int ibcs, struct image_info *info) { - unsigned int *argv, *envp, *dlinfo; - unsigned int *sp; - char **alpha_envp; + target_ulong *argv, *envp, *dlinfo; + target_ulong *sp; /* * Force 16 byte alignment here for generality. @@ -350,14 +349,13 @@ static unsigned int * create_elf_tables(char *p, int argc, int envc, sp -= argc+1; argv = sp; if (!ibcs) { - put_user(envp,--sp); - put_user(argv,--sp); + put_user(tswapl((target_ulong)envp),--sp); + put_user(tswapl((target_ulong)argv),--sp); } - alpha_envp = (char **)malloc((envc+1) * sizeof(char *)); #define NEW_AUX_ENT(id, val) \ - put_user ((id), dlinfo++); \ - put_user ((val), dlinfo++) + put_user (tswapl(id), dlinfo++); \ + put_user (tswapl(val), dlinfo++) if (exec) { /* Put this here for an ELF program interpreter */ struct elf_phdr * eppnt; @@ -377,22 +375,19 @@ static unsigned int * create_elf_tables(char *p, int argc, int envc, } NEW_AUX_ENT (AT_NULL, 0); #undef NEW_AUX_ENT - put_user((unsigned int)argc,--sp); + put_user(tswapl(argc),--sp); info->arg_start = (unsigned int)((unsigned long)p & 0xffffffff); while (argc-->0) { - put_user(p,argv++); + put_user(tswapl((target_ulong)p),argv++); while (get_user(p++)) /* nothing */ ; } put_user(0,argv); info->arg_end = info->env_start = (unsigned int)((unsigned long)p & 0xffffffff); - __environ = alpha_envp; while (envc-->0) { - *alpha_envp++ = (char *)p; - put_user(p,envp++); + put_user(tswapl((target_ulong)p),envp++); while (get_user(p++)) /* nothing */ ; } put_user(0,envp); - *alpha_envp = 0; info->env_end = (unsigned int)((unsigned long)p & 0xffffffff); return sp; } @@ -544,8 +539,8 @@ static unsigned long load_elf_interp(struct elfhdr * interp_elf_ex, -static int load_elf_binary(struct linux_binprm * bprm, struct pt_regs * regs, - struct image_info * info) +static int load_elf_binary(struct linux_binprm * bprm, struct target_pt_regs * regs, + struct image_info * info) { struct elfhdr elf_ex; struct elfhdr interp_elf_ex; @@ -581,7 +576,6 @@ static int load_elf_binary(struct linux_binprm * bprm, struct pt_regs * regs, return -ENOEXEC; } - /* First of all, some simple consistency checks */ if ((elf_ex.e_type != ET_EXEC && elf_ex.e_type != ET_DYN) || (! elf_check_arch(elf_ex.e_machine))) { @@ -608,6 +602,12 @@ static int load_elf_binary(struct linux_binprm * bprm, struct pt_regs * regs, return -errno; } +#ifdef BSWAP_NEEDED + elf_ppnt = elf_phdata; + for (i=0; i<elf_ex.e_phnum; i++, elf_ppnt++) { + bswap_phdr(elf_ppnt); + } +#endif elf_ppnt = elf_phdata; elf_bss = 0; @@ -909,7 +909,7 @@ static int load_elf_binary(struct linux_binprm * bprm, struct pt_regs * regs, int elf_exec(const char * filename, char ** argv, char ** envp, - struct pt_regs * regs, struct image_info *infop) + struct target_pt_regs * regs, struct image_info *infop) { struct linux_binprm bprm; int retval; |