Use greg_t and uintptr_t in x86-64 __makecontext

This commit is contained in:
H.J. Lu 2012-03-16 15:06:43 -07:00
parent f1a77b01f4
commit 6b6cd74bab
2 changed files with 24 additions and 16 deletions

View File

@ -1,3 +1,10 @@
2012-03-16 H.J. Lu <hongjiu.lu@intel.com>
* sysdeps/unix/sysv/linux/x86_64/makecontext.c (__makecontext):
Use greg_t on sp. Use unsigned int on idx_uc_link. Cast
adresses to uintptr_t. Replace "long int" and "unsigned long
int" with "greg_t" on va_arg.
2012-03-16 H.J. Lu <hongjiu.lu@intel.com> 2012-03-16 H.J. Lu <hongjiu.lu@intel.com>
* sysdeps/generic/ldconfig.h (FLAG_X8664_LIBX32): New macro. * sysdeps/generic/ldconfig.h (FLAG_X8664_LIBX32): New macro.

View File

@ -52,29 +52,30 @@ void
__makecontext (ucontext_t *ucp, void (*func) (void), int argc, ...) __makecontext (ucontext_t *ucp, void (*func) (void), int argc, ...)
{ {
extern void __start_context (void); extern void __start_context (void);
unsigned long int *sp, idx_uc_link; greg_t *sp;
unsigned int idx_uc_link;
va_list ap; va_list ap;
int i; int i;
/* Generate room on stack for parameter if needed and uc_link. */ /* Generate room on stack for parameter if needed and uc_link. */
sp = (unsigned long int *) ((uintptr_t) ucp->uc_stack.ss_sp sp = (greg_t *) ((uintptr_t) ucp->uc_stack.ss_sp
+ ucp->uc_stack.ss_size); + ucp->uc_stack.ss_size);
sp -= (argc > 6 ? argc - 6 : 0) + 1; sp -= (argc > 6 ? argc - 6 : 0) + 1;
/* Align stack and make space for trampoline address. */ /* Align stack and make space for trampoline address. */
sp = (unsigned long int *) ((((uintptr_t) sp) & -16L) - 8); sp = (greg_t *) ((((uintptr_t) sp) & -16L) - 8);
idx_uc_link = (argc > 6 ? argc - 6 : 0) + 1; idx_uc_link = (argc > 6 ? argc - 6 : 0) + 1;
/* Setup context ucp. */ /* Setup context ucp. */
/* Address to jump to. */ /* Address to jump to. */
ucp->uc_mcontext.gregs[REG_RIP] = (long int) func; ucp->uc_mcontext.gregs[REG_RIP] = (uintptr_t) func;
/* Setup rbx.*/ /* Setup rbx.*/
ucp->uc_mcontext.gregs[REG_RBX] = (long int) &sp[idx_uc_link]; ucp->uc_mcontext.gregs[REG_RBX] = (uintptr_t) &sp[idx_uc_link];
ucp->uc_mcontext.gregs[REG_RSP] = (long int) sp; ucp->uc_mcontext.gregs[REG_RSP] = (uintptr_t) sp;
/* Setup stack. */ /* Setup stack. */
sp[0] = (unsigned long int) &__start_context; sp[0] = (uintptr_t) &__start_context;
sp[idx_uc_link] = (unsigned long int) ucp->uc_link; sp[idx_uc_link] = (uintptr_t) ucp->uc_link;
va_start (ap, argc); va_start (ap, argc);
/* Handle arguments. /* Handle arguments.
@ -90,26 +91,26 @@ __makecontext (ucontext_t *ucp, void (*func) (void), int argc, ...)
switch (i) switch (i)
{ {
case 0: case 0:
ucp->uc_mcontext.gregs[REG_RDI] = va_arg (ap, long int); ucp->uc_mcontext.gregs[REG_RDI] = va_arg (ap, greg_t);
break; break;
case 1: case 1:
ucp->uc_mcontext.gregs[REG_RSI] = va_arg (ap, long int); ucp->uc_mcontext.gregs[REG_RSI] = va_arg (ap, greg_t);
break; break;
case 2: case 2:
ucp->uc_mcontext.gregs[REG_RDX] = va_arg (ap, long int); ucp->uc_mcontext.gregs[REG_RDX] = va_arg (ap, greg_t);
break; break;
case 3: case 3:
ucp->uc_mcontext.gregs[REG_RCX] = va_arg (ap, long int); ucp->uc_mcontext.gregs[REG_RCX] = va_arg (ap, greg_t);
break; break;
case 4: case 4:
ucp->uc_mcontext.gregs[REG_R8] = va_arg (ap, long int); ucp->uc_mcontext.gregs[REG_R8] = va_arg (ap, greg_t);
break; break;
case 5: case 5:
ucp->uc_mcontext.gregs[REG_R9] = va_arg (ap, long int); ucp->uc_mcontext.gregs[REG_R9] = va_arg (ap, greg_t);
break; break;
default: default:
/* Put value on stack. */ /* Put value on stack. */
sp[i - 5] = va_arg (ap, unsigned long int); sp[i - 5] = va_arg (ap, greg_t);
break; break;
} }
va_end (ap); va_end (ap);