aboutsummaryrefslogtreecommitdiff
path: root/pk/pk.c
diff options
context:
space:
mode:
authorAndrew Waterman <andrew@sifive.com>2020-11-12 16:11:32 -0800
committerGitHub <noreply@github.com>2020-11-12 16:11:32 -0800
commit33ae46f1cb7eb36a6eb28cd25cfb7f066d22618a (patch)
tree8dac4e1174298eaf6dcf1865e2bc6aeefa2f705d /pk/pk.c
parenta4d4298ca10527a51fad86c53a93c48e6f510092 (diff)
parent5752f0a173b84a76b772ee0abc8b4a1ad99d301d (diff)
downloadpk-33ae46f1cb7eb36a6eb28cd25cfb7f066d22618a.zip
pk-33ae46f1cb7eb36a6eb28cd25cfb7f066d22618a.tar.gz
pk-33ae46f1cb7eb36a6eb28cd25cfb7f066d22618a.tar.bz2
Merge pull request #220 from zeldin/big-endian
Big endian
Diffstat (limited to 'pk/pk.c')
-rw-r--r--pk/pk.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/pk/pk.c b/pk/pk.c
index bce11a5..87dfc78 100644
--- a/pk/pk.c
+++ b/pk/pk.c
@@ -129,15 +129,15 @@ static void run_loaded_program(size_t argc, char** argv, uintptr_t kstack_top)
// place argc, argv, envp, auxp on stack
#define PUSH_ARG(type, value) do { \
*((type*)sp) = (type)value; \
- sp += sizeof(type); \
+ sp ++; \
} while (0)
#define STACK_INIT(type) do { \
unsigned naux = sizeof(aux)/sizeof(aux[0]); \
stack_top -= (1 + argc + 1 + envc + 1 + 2*naux) * sizeof(type); \
stack_top &= -16; \
- long sp = stack_top; \
- PUSH_ARG(type, argc); \
+ type *sp = (void*)stack_top; \
+ PUSH_ARG(int, argc); \
for (unsigned i = 0; i < argc; i++) \
PUSH_ARG(type, argv[i]); \
PUSH_ARG(type, 0); /* argv[argc] = NULL */ \