diff options
Diffstat (limited to 'libffi/testsuite/libffi.call/cls_ulonglong.c')
-rw-r--r-- | libffi/testsuite/libffi.call/cls_ulonglong.c | 20 |
1 files changed, 17 insertions, 3 deletions
diff --git a/libffi/testsuite/libffi.call/cls_ulonglong.c b/libffi/testsuite/libffi.call/cls_ulonglong.c index 7c98d757fd0..072da8c1e50 100644 --- a/libffi/testsuite/libffi.call/cls_ulonglong.c +++ b/libffi/testsuite/libffi.call/cls_ulonglong.c @@ -20,9 +20,18 @@ typedef unsigned long long (*cls_ret_ulonglong)(unsigned long long); int main (void) { ffi_cif cif; +#ifndef USING_MMAP static ffi_closure cl; - ffi_closure *pcl = &cl; +#endif + ffi_closure *pcl; ffi_type * cl_arg_types[2]; + unsigned long long res; + +#ifdef USING_MMAP + pcl = allocate_mmap (sizeof(ffi_closure)); +#else + pcl = &cl; +#endif cl_arg_types[0] = &ffi_type_uint64; cl_arg_types[1] = NULL; @@ -31,10 +40,15 @@ int main (void) CHECK(ffi_prep_cif(&cif, FFI_DEFAULT_ABI, 1, &ffi_type_uint64, cl_arg_types) == FFI_OK); CHECK(ffi_prep_closure(pcl, &cif, cls_ret_ulonglong_fn, NULL) == FFI_OK); - (*((cls_ret_ulonglong)pcl))(214LL); + res = (*((cls_ret_ulonglong)pcl))(214LL); /* { dg-output "214: 214" } */ - (*((cls_ret_ulonglong)pcl))(9223372035854775808LL); + printf("res: %lld\n", res); + /* { dg-output "\nres: 214" } */ + + res = (*((cls_ret_ulonglong)pcl))(9223372035854775808LL); /* { dg-output "\n9223372035854775808: 9223372035854775808" } */ + printf("res: %lld\n", res); + /* { dg-output "\nres: 9223372035854775808" } */ exit(0); } |