1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
#include <stdio.h>
#include <caml/mlvalues.h>
#include <caml/memory.h>
#include <caml/callback.h>
value caml_to_c_native (value a1, value a2, value a3, value a4, value a5,
value a6, value a7, value a8, value a9, value a10,
value a11)
{
CAMLparam0 ();
long l;
printf ("[C] Enter caml_to_c\n");
static const value* c_to_caml_closure = NULL;
if (!c_to_caml_closure)
c_to_caml_closure = caml_named_value("c_to_caml");
l = Long_val (a1) + Long_val (a2) + Long_val (a3) + Long_val (a4)
+ Long_val (a5) + Long_val (a6) + Long_val (a7) + Long_val (a8)
+ Long_val (a9) + Long_val (a10) + Long_val (a11);
printf ("[C] Call c_to_caml\n");
fflush(stdout);
caml_callback(*c_to_caml_closure, Val_long(l));
printf ("[C] Return from c_to_caml\n");
printf ("[C] Leave caml_to_c\n");
fflush(stdout);
CAMLreturn (Val_unit);
}
value caml_to_c_bytecode (value * argv, int argn) {
return caml_to_c_native (argv[0], argv[1], argv[2], argv[3], argv[4],
argv[5], argv[6], argv[7], argv[8], argv[9],
argv[10]);
}
|