Sha256: 2569c5c7475bac92c7dc1553f8e22a65e72f0a3f0e8c252dd15a78ce68cdbdff

Contents?: true

Size: 1.37 KB

Versions: 286

Compression:

Stored size: 1.37 KB

Contents

/* Area:	ffi_call
   Purpose:	Check structures.
   Limitations:	none.
   PR:		none.
   Originator:	From the original ffitest.c  */

/* { dg-do run } */
#include "ffitest.h"
typedef struct
{
  char c1;
  char c2;
} test_structure_5;

static test_structure_5 struct5(test_structure_5 ts1, test_structure_5 ts2)
{
  ts1.c1 += ts2.c1;
  ts1.c2 -= ts2.c2;
  
  return ts1;
}

int main (void)
{
  ffi_cif cif;
  ffi_type *args[MAX_ARGS];
  void *values[MAX_ARGS];
  ffi_type ts5_type;
  ffi_type *ts5_type_elements[3];
  ts5_type.size = 0;
  ts5_type.alignment = 0;
  ts5_type.type = FFI_TYPE_STRUCT;
  ts5_type.elements = ts5_type_elements;
  ts5_type_elements[0] = &ffi_type_schar;
  ts5_type_elements[1] = &ffi_type_schar;
  ts5_type_elements[2] = NULL;

  test_structure_5 ts5_arg1, ts5_arg2;
  
  /* This is a hack to get a properly aligned result buffer */
  test_structure_5 *ts5_result = 
    (test_structure_5 *) malloc (sizeof(test_structure_5));
  
  args[0] = &ts5_type;
  args[1] = &ts5_type;
  values[0] = &ts5_arg1;
  values[1] = &ts5_arg2;
  
  /* Initialize the cif */
  CHECK(ffi_prep_cif(&cif, FFI_DEFAULT_ABI, 2, &ts5_type, args) == FFI_OK);
  
  ts5_arg1.c1 = 2;
  ts5_arg1.c2 = 6;
  ts5_arg2.c1 = 5;
  ts5_arg2.c2 = 3;
  
  ffi_call (&cif, FFI_FN(struct5), ts5_result, values);
  
  CHECK(ts5_result->c1 == 7); 
  CHECK(ts5_result->c2 == 3);
  
  
  free (ts5_result);
  exit(0);
}

Version data entries

286 entries across 282 versions & 31 rubygems

Version Path
ffi-0.2.0 ext/libffi/testsuite/libffi.call/struct5.c
ffi-0.3.0 ext/ffi_c/libffi/testsuite/libffi.call/struct5.c
ffi-0.3.3 ext/ffi_c/libffi/testsuite/libffi.call/struct5.c
ffi-0.3.2 ext/ffi_c/libffi/testsuite/libffi.call/struct5.c
ffi-0.3.4 ext/ffi_c/libffi/testsuite/libffi.call/struct5.c
ffi-0.3.5 ext/ffi_c/libffi/testsuite/libffi.call/struct5.c