From: pbrook Date: Thu, 15 Mar 2007 21:56:07 +0000 (+0000) Subject: Align stack when loading bFLT binaries. X-Git-Tag: TizenStudio_2.0_p2.3~13743 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=b35d7448b1d27a77bc6f59acc697710d5bd3823c;p=sdk%2Femulator%2Fqemu.git Align stack when loading bFLT binaries. git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@2478 c046a42c-6fe2-441c-8c8c-71466251a162 --- diff --git a/linux-user/flatload.c b/linux-user/flatload.c index 7e3296e..c9f1acd 100644 --- a/linux-user/flatload.c +++ b/linux-user/flatload.c @@ -756,6 +756,13 @@ int load_flt_binary(struct linux_binprm * bprm, struct target_pt_regs * regs, p = copy_strings(p, bprm->argc, bprm->argv); /* Align stack. */ sp = p & ~(target_ulong)(sizeof(target_ulong) - 1); + /* Enforce final stack alignment of 16 bytes. This is sufficient + for all current targets, and excess alignment is harmless. */ + stack_len = bprm->envc + bprm->argc + 2; + stack_len += 3; /* argc, arvg, argp */ + stack_len *= sizeof(target_ulong); + if ((sp + stack_len) & 15) + sp -= 16 - ((sp + stack_len) & 15); sp = loader_build_argptr(bprm->envc, bprm->argc, sp, p, 1); /* Fake some return addresses to ensure the call chain will