Skip WIN64/EFI64 support for x32

Since x32 doesn't support WIN64/EFI64, skip it if __ILP32__ is defined.
This commit is contained in:
H.J. Lu
2017-10-25 04:59:31 -07:00
parent b2a343ffc6
commit 9d9d92b47f

View File

@@ -389,8 +389,10 @@ examine_argument (ffi_type *type, enum x86_64_reg_class classes[MAX_CLASSES],
/* Perform machine dependent cif processing. */ /* Perform machine dependent cif processing. */
#ifndef __ILP32__
extern ffi_status extern ffi_status
ffi_prep_cif_machdep_efi64(ffi_cif *cif); ffi_prep_cif_machdep_efi64(ffi_cif *cif);
#endif
ffi_status ffi_status
ffi_prep_cif_machdep (ffi_cif *cif) ffi_prep_cif_machdep (ffi_cif *cif)
@@ -400,8 +402,10 @@ ffi_prep_cif_machdep (ffi_cif *cif)
size_t bytes, n, rtype_size; size_t bytes, n, rtype_size;
ffi_type *rtype; ffi_type *rtype;
#ifndef __ILP32__
if (cif->abi == FFI_EFI64) if (cif->abi == FFI_EFI64)
return ffi_prep_cif_machdep_efi64(cif); return ffi_prep_cif_machdep_efi64(cif);
#endif
if (cif->abi != FFI_UNIX64) if (cif->abi != FFI_UNIX64)
return FFI_BAD_ABI; return FFI_BAD_ABI;
@@ -663,27 +667,35 @@ ffi_call_int (ffi_cif *cif, void (*fn)(void), void *rvalue,
flags, rvalue, fn); flags, rvalue, fn);
} }
#ifndef __ILP32__
extern void extern void
ffi_call_efi64(ffi_cif *cif, void (*fn)(void), void *rvalue, void **avalue); ffi_call_efi64(ffi_cif *cif, void (*fn)(void), void *rvalue, void **avalue);
#endif
void void
ffi_call (ffi_cif *cif, void (*fn)(void), void *rvalue, void **avalue) ffi_call (ffi_cif *cif, void (*fn)(void), void *rvalue, void **avalue)
{ {
#ifndef __ILP32__
if (cif->abi == FFI_EFI64) if (cif->abi == FFI_EFI64)
return ffi_call_efi64(cif, fn, rvalue, avalue); return ffi_call_efi64(cif, fn, rvalue, avalue);
#endif
ffi_call_int (cif, fn, rvalue, avalue, NULL); ffi_call_int (cif, fn, rvalue, avalue, NULL);
} }
#ifndef __ILP32__
extern void extern void
ffi_call_go_efi64(ffi_cif *cif, void (*fn)(void), void *rvalue, ffi_call_go_efi64(ffi_cif *cif, void (*fn)(void), void *rvalue,
void **avalue, void *closure); void **avalue, void *closure);
#endif
void void
ffi_call_go (ffi_cif *cif, void (*fn)(void), void *rvalue, ffi_call_go (ffi_cif *cif, void (*fn)(void), void *rvalue,
void **avalue, void *closure) void **avalue, void *closure)
{ {
#ifndef __ILP32__
if (cif->abi == FFI_EFI64) if (cif->abi == FFI_EFI64)
ffi_call_go_efi64(cif, fn, rvalue, avalue, closure); ffi_call_go_efi64(cif, fn, rvalue, avalue, closure);
#endif
ffi_call_int (cif, fn, rvalue, avalue, closure); ffi_call_int (cif, fn, rvalue, avalue, closure);
} }
@@ -691,12 +703,14 @@ ffi_call_go (ffi_cif *cif, void (*fn)(void), void *rvalue,
extern void ffi_closure_unix64(void) FFI_HIDDEN; extern void ffi_closure_unix64(void) FFI_HIDDEN;
extern void ffi_closure_unix64_sse(void) FFI_HIDDEN; extern void ffi_closure_unix64_sse(void) FFI_HIDDEN;
#ifndef __ILP32__
extern ffi_status extern ffi_status
ffi_prep_closure_loc_efi64(ffi_closure* closure, ffi_prep_closure_loc_efi64(ffi_closure* closure,
ffi_cif* cif, ffi_cif* cif,
void (*fun)(ffi_cif*, void*, void**, void*), void (*fun)(ffi_cif*, void*, void**, void*),
void *user_data, void *user_data,
void *codeloc); void *codeloc);
#endif
ffi_status ffi_status
ffi_prep_closure_loc (ffi_closure* closure, ffi_prep_closure_loc (ffi_closure* closure,
@@ -716,8 +730,10 @@ ffi_prep_closure_loc (ffi_closure* closure,
void (*dest)(void); void (*dest)(void);
char *tramp = closure->tramp; char *tramp = closure->tramp;
#ifndef __ILP32__
if (cif->abi == FFI_EFI64) if (cif->abi == FFI_EFI64)
return ffi_prep_closure_loc_efi64(closure, cif, fun, user_data, codeloc); return ffi_prep_closure_loc_efi64(closure, cif, fun, user_data, codeloc);
#endif
if (cif->abi != FFI_UNIX64) if (cif->abi != FFI_UNIX64)
return FFI_BAD_ABI; return FFI_BAD_ABI;
@@ -832,16 +848,20 @@ ffi_closure_unix64_inner(ffi_cif *cif,
extern void ffi_go_closure_unix64(void) FFI_HIDDEN; extern void ffi_go_closure_unix64(void) FFI_HIDDEN;
extern void ffi_go_closure_unix64_sse(void) FFI_HIDDEN; extern void ffi_go_closure_unix64_sse(void) FFI_HIDDEN;
#ifndef __ILP32__
extern ffi_status extern ffi_status
ffi_prep_go_closure_efi64(ffi_go_closure* closure, ffi_cif* cif, ffi_prep_go_closure_efi64(ffi_go_closure* closure, ffi_cif* cif,
void (*fun)(ffi_cif*, void*, void**, void*)); void (*fun)(ffi_cif*, void*, void**, void*));
#endif
ffi_status ffi_status
ffi_prep_go_closure (ffi_go_closure* closure, ffi_cif* cif, ffi_prep_go_closure (ffi_go_closure* closure, ffi_cif* cif,
void (*fun)(ffi_cif*, void*, void**, void*)) void (*fun)(ffi_cif*, void*, void**, void*))
{ {
#ifndef __ILP32__
if (cif->abi == FFI_EFI64) if (cif->abi == FFI_EFI64)
return ffi_prep_go_closure_efi64(closure, cif, fun); return ffi_prep_go_closure_efi64(closure, cif, fun);
#endif
if (cif->abi != FFI_UNIX64) if (cif->abi != FFI_UNIX64)
return FFI_BAD_ABI; return FFI_BAD_ABI;