ExternalFunctionCallback.st
author Claus Gittinger <cg@exept.de>
Wed, 13 Jun 2007 18:43:27 +0200
changeset 10607 9f42b83e653a
child 10609 fa629d528330
permissions -rw-r--r--
*** empty log message ***
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
10607
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     1
'From Smalltalk/X, Version:5.3.5 on 12-06-2007 at 16:40:04'                     !
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     2
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     3
ExternalBytes subclass:#ExternalFunctionCallback
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     4
	instanceVariableNames:'returnType argumentTypes action'
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     5
	classVariableNames:'CallBackRegistry'
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     6
	poolDictionaries:''
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     7
	category:'System-Support'
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     8
!
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
     9
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    10
!ExternalFunctionCallback primitiveDefinitions!
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    11
%{
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    12
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    13
#ifdef HAVE_FFI
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    14
# include <ffi.h>
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    15
# define MAX_ARGS    128
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    16
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    17
extern ffi_type *__get_ffi_type_sint();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    18
extern ffi_type *__get_ffi_type_sint8();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    19
extern ffi_type *__get_ffi_type_sint16();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    20
extern ffi_type *__get_ffi_type_sint32();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    21
extern ffi_type *__get_ffi_type_sint64();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    22
extern ffi_type *__get_ffi_type_uint();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    23
extern ffi_type *__get_ffi_type_uint8();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    24
extern ffi_type *__get_ffi_type_uint16();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    25
extern ffi_type *__get_ffi_type_uint32();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    26
extern ffi_type *__get_ffi_type_uint64();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    27
extern ffi_type *__get_ffi_type_float();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    28
extern ffi_type *__get_ffi_type_double();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    29
extern ffi_type *__get_ffi_type_void();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    30
extern ffi_type *__get_ffi_type_pointer();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    31
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    32
#endif
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    33
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    34
%}
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    35
! !
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    36
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    37
!ExternalFunctionCallback primitiveFunctions!
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    38
%{
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    39
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    40
#define VERBOSE
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    41
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    42
void
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    43
ExternalFunctionCallback__closure_test_fn(ffi_cif* cif, void* resp, void** args, void* userdata)
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    44
{
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    45
    int actionIndex = userdata;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    46
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    47
    printf("closure_test_fn(userdata=%d resp*=%x)\n", userdata, resp);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    48
    printf("closure_test_fn(arg[0]=%d)\n", *(int *)(args[0]));
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    49
    *(ffi_arg *)resp = 1;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    50
}
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    51
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    52
void
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    53
ExternalFunctionCallback__doCall_closure(INTFUNC f)
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    54
{
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    55
    int result = 0;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    56
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    57
    printf("doCall_closure: calling closure %x(123)...\n", f);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    58
    result = (*f)(123);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    59
    printf("doCall_closure: back; result is %x...\n", result);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    60
}
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    61
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    62
%}
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    63
! !
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    64
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    65
!ExternalFunctionCallback class methodsFor:'examples'!
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    66
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    67
examples
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    68
"
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    69
    |cb|
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    70
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    71
    cb := ExternalFunctionCallback new.
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    72
    cb returnType:#bool argumentTypes:#(uint).
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    73
    cb generateClosure.
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    74
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    75
    cb action:[:arg | Transcript showCR:arg].
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    76
    cb address.
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    77
"
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    78
! !
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    79
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    80
!ExternalFunctionCallback methodsFor:'accessing'!
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    81
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    82
action:something
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    83
    action := something.
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    84
! !
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    85
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    86
!ExternalFunctionCallback methodsFor:'generation'!
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    87
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    88
address
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    89
    self isValid ifFalse:[
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    90
	self generate
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    91
    ].
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    92
    ^ super address
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    93
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    94
    "Created: / 11-06-2007 / 15:53:00 / cg"
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    95
!
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    96
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    97
generate
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    98
    |code|
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
    99
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   100
    code := nil
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   101
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   102
    "Created: / 11-06-2007 / 14:50:57 / cg"
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   103
!
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   104
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   105
generate0
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   106
    |code|
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   107
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   108
    code := #[
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   109
		"/ mov ecx, closureIndex
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   110
		16rB9
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   111
		    16r00  16r00  16r00  16r01
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   112
		"/ mov eax, doClosureC
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   113
		16rB8
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   114
		    16r00  16r00  16r00  16r02
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   115
		"/ call *eax
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   116
		16rFF  16rD0
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   117
		"/ ret
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   118
		16rC3
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   119
	    ].
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   120
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   121
    self allocateBytes:(code size).
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   122
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   123
    "Created: / 11-06-2007 / 15:29:33 / cg"
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   124
! !
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   125
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   126
!ExternalFunctionCallback methodsFor:'private-accessing'!
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   127
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   128
returnType:aReturnType argumentTypes:argTypes
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   129
    returnType := aReturnType.
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   130
    argumentTypes := argTypes.
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   131
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   132
    "Created: / 11-06-2007 / 15:52:01 / cg"
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   133
! !
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   134
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   135
!ExternalFunctionCallback methodsFor:'private-generation'!
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   136
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   137
generateClosure
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   138
    |argTypeSymbols returnTypeSymbol failureCode failureInfo returnValue stClass vtOffset
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   139
     virtual async unlimitedStack callTypeNumber returnValueClass argValueClass|
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   140
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   141
    argTypeSymbols := argumentTypes.
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   142
    returnTypeSymbol := returnType.
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   143
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   144
%{  /* STACK: 100000 */
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   145
#if 1
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   146
#ifdef HAVE_FFI
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   147
    ffi_cif __cif;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   148
    ffi_type *__argTypesIncludingThis[MAX_ARGS+1];
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   149
    ffi_type **__argTypes = __argTypesIncludingThis;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   150
    ffi_type *__returnType = NULL;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   151
    void *__returnValuePointer;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   152
    static int null = 0;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   153
    int i;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   154
    ffi_abi __callType = FFI_DEFAULT_ABI;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   155
    int __numArgsWanted;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   156
    ffi_closure *pcl;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   157
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   158
#define __FAIL__(fcode) \
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   159
    { \
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   160
	failureCode = fcode; goto getOutOfHere; \
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   161
    }
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   162
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   163
    if (argTypeSymbols == nil) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   164
	__numArgsWanted = 0;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   165
    } else if (__isArray(argTypeSymbols)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   166
	__numArgsWanted = __arraySize(argTypeSymbols);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   167
    } else {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   168
	__FAIL__(@symbol(BadArgumentTypeVector))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   169
    }
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   170
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   171
    if (__numArgsWanted > MAX_ARGS) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   172
	__FAIL__(@symbol(TooManyArguments))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   173
    }
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   174
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   175
    /*
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   176
     * validate the return type
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   177
     */
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   178
    if (returnTypeSymbol == @symbol(voidPointer)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   179
	returnTypeSymbol = @symbol(handle);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   180
    }
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   181
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   182
    if (returnTypeSymbol == @symbol(int)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   183
	__returnType = __get_ffi_type_sint();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   184
    } else if (returnTypeSymbol == @symbol(uint)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   185
	__returnType = __get_ffi_type_uint();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   186
    } else if (returnTypeSymbol == @symbol(uint8)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   187
	__returnType = __get_ffi_type_uint8();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   188
    } else if (returnTypeSymbol == @symbol(uint16)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   189
	__returnType = __get_ffi_type_uint16();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   190
    } else if (returnTypeSymbol == @symbol(uint32)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   191
	__returnType = __get_ffi_type_uint32();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   192
    } else if (returnTypeSymbol == @symbol(uint64)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   193
	__returnType = __get_ffi_type_uint64();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   194
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   195
    } else if (returnTypeSymbol == @symbol(sint)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   196
	__returnType = __get_ffi_type_sint();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   197
    } else if (returnTypeSymbol == @symbol(sint8)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   198
	__returnType = __get_ffi_type_sint8();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   199
    } else if (returnTypeSymbol == @symbol(sint16)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   200
	__returnType = __get_ffi_type_sint16();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   201
    } else if (returnTypeSymbol == @symbol(sint32)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   202
	__returnType = __get_ffi_type_sint32();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   203
    } else if (returnTypeSymbol == @symbol(sint64)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   204
	__returnType = __get_ffi_type_sint64();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   205
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   206
    } else if (returnTypeSymbol == @symbol(long)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   207
	if (sizeof(long) == 4) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   208
	   returnTypeSymbol = @symbol(sint32);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   209
	   __returnType = __get_ffi_type_sint32();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   210
	} else if (sizeof(long) == 8) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   211
	   returnTypeSymbol = @symbol(sint64);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   212
	   __returnType = __get_ffi_type_sint64();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   213
	} else {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   214
	    __FAIL__(@symbol(UnknownReturnType))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   215
	}
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   216
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   217
    } else if (returnTypeSymbol == @symbol(ulong)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   218
	if (sizeof(long) == 4) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   219
	   returnTypeSymbol = @symbol(uint32);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   220
	   __returnType = __get_ffi_type_uint32();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   221
	}else if (sizeof(long) == 8) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   222
	   returnTypeSymbol = @symbol(uint64);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   223
	   __returnType = __get_ffi_type_uint64();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   224
	} else {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   225
	    __FAIL__(@symbol(UnknownReturnType))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   226
	}
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   227
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   228
    } else if (returnTypeSymbol == @symbol(bool)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   229
	__returnType = __get_ffi_type_uint();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   230
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   231
    } else if (returnTypeSymbol == @symbol(float)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   232
	__returnType = __get_ffi_type_float();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   233
    } else if (returnTypeSymbol == @symbol(double)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   234
	__returnType = __get_ffi_type_double();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   235
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   236
    } else if (returnTypeSymbol == @symbol(void)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   237
	__returnType = __get_ffi_type_void();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   238
    } else if ((returnTypeSymbol == @symbol(pointer))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   239
	       || (returnTypeSymbol == @symbol(handle))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   240
	       || (returnTypeSymbol == @symbol(charPointer))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   241
	       || (returnTypeSymbol == @symbol(bytePointer))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   242
	       || (returnTypeSymbol == @symbol(floatPointer))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   243
	       || (returnTypeSymbol == @symbol(doublePointer))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   244
	       || (returnTypeSymbol == @symbol(intPointer))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   245
	       || (returnTypeSymbol == @symbol(shortPointer))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   246
	       || (returnTypeSymbol == @symbol(wcharPointer))) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   247
	__returnType = __get_ffi_type_pointer();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   248
    } else {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   249
	if (__isSymbol(returnTypeSymbol)
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   250
	 && ((returnValueClass = __GLOBAL_GET(returnTypeSymbol)) != nil)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   251
	    if (! __isBehaviorLike(returnValueClass)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   252
		__FAIL__(@symbol(NonBehaviorReturnType))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   253
	    }
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   254
	    if (! __qIsSubclassOfExternalAddress(returnValueClass)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   255
		__FAIL__(@symbol(NonExternalAddressReturnType))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   256
	    }
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   257
	    __returnType = __get_ffi_type_pointer();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   258
	    returnTypeSymbol = @symbol(pointer);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   259
	} else {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   260
	    __FAIL__(@symbol(UnknownReturnType))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   261
	}
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   262
    }
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   263
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   264
    /*
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   265
     * setup arg-buffers
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   266
     */
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   267
    for (i=0; i<__numArgsWanted; i++) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   268
	ffi_type *thisType;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   269
	void *argValuePtr;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   270
	OBJ typeSymbol;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   271
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   272
	failureInfo = __mkSmallInteger(i+1);   /* in case there is one */
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   273
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   274
	typeSymbol = __ArrayInstPtr(argTypeSymbols)->a_element[i];
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   275
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   276
	if (typeSymbol == @symbol(handle)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   277
	    typeSymbol = @symbol(pointer);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   278
	} else if (typeSymbol == @symbol(voidPointer)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   279
	    typeSymbol = @symbol(pointer);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   280
	}
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   281
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   282
	if (typeSymbol == @symbol(long)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   283
	    if (sizeof(long) == sizeof(int)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   284
		typeSymbol = @symbol(sint);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   285
	    } else {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   286
		if (sizeof(long) == 4) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   287
		    typeSymbol = @symbol(sint32);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   288
		} else if (sizeof(long) == 8) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   289
		    typeSymbol = @symbol(sint64);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   290
		}
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   291
	    }
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   292
	}
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   293
	if (typeSymbol == @symbol(ulong)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   294
	    if (sizeof(unsigned long) == sizeof(unsigned int)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   295
		typeSymbol = @symbol(uint);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   296
	    } else {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   297
		if (sizeof(long) == 4) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   298
		    typeSymbol = @symbol(uint32);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   299
		} else if (sizeof(long) == 8) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   300
		    typeSymbol = @symbol(uint64);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   301
		}
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   302
	    }
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   303
	}
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   304
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   305
	if (typeSymbol == @symbol(int)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   306
	    thisType = __get_ffi_type_sint();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   307
	} else if (typeSymbol == @symbol(uint)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   308
	    thisType = __get_ffi_type_uint();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   309
	} else if (typeSymbol == @symbol(uint8)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   310
	    thisType = __get_ffi_type_uint8();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   311
	} else if (typeSymbol == @symbol(sint8)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   312
	    thisType = __get_ffi_type_sint8();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   313
	} else if (typeSymbol == @symbol(uint16)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   314
	    thisType = __get_ffi_type_uint16();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   315
	} else if (typeSymbol == @symbol(sint16)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   316
	    thisType = __get_ffi_type_sint16();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   317
	} else if ((typeSymbol == @symbol(uint32)) || (typeSymbol == @symbol(sint32))) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   318
	    thisType = __get_ffi_type_uint32();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   319
	} else if (typeSymbol == @symbol(float)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   320
	    thisType = __get_ffi_type_float();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   321
	} else if (typeSymbol == @symbol(double)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   322
	    thisType = __get_ffi_type_double();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   323
	} else if (typeSymbol == @symbol(void)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   324
	    thisType = __get_ffi_type_void();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   325
	} else if (typeSymbol == @symbol(charPointer)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   326
	    thisType = __get_ffi_type_pointer();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   327
	} else if (typeSymbol == @symbol(floatPointer)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   328
	    thisType = __get_ffi_type_pointer();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   329
	} else if (typeSymbol == @symbol(doublePointer)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   330
	    thisType = __get_ffi_type_pointer();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   331
	} else if (typeSymbol == @symbol(pointer)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   332
commonPointerTypeArg: ;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   333
	    thisType = __get_ffi_type_pointer();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   334
	} else if (typeSymbol == @symbol(bool)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   335
	    thisType = __get_ffi_type_uint();
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   336
	} else if (__isSymbol(typeSymbol)
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   337
	     && ((argValueClass = __GLOBAL_GET(typeSymbol)) != nil)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   338
	    if (! __isBehaviorLike(argValueClass)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   339
		__FAIL__(@symbol(NonBehaviorArgumentType))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   340
	    }
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   341
	    if (! __qIsSubclassOfExternalAddress(argValueClass)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   342
		__FAIL__(@symbol(NonExternalAddressArgumentType))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   343
	    }
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   344
	    goto commonPointerTypeArg; /* sorry */
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   345
	} else {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   346
	    __FAIL__(@symbol(UnknownArgumentType))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   347
	}
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   348
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   349
	__argTypes[i] = thisType;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   350
    }
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   351
    failureInfo = nil;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   352
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   353
    __callType = FFI_DEFAULT_ABI;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   354
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   355
    if (callTypeNumber != nil) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   356
#ifdef CALLTYPE_FFI_STDCALL
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   357
	if (callTypeNumber == @global(ExternalLibraryFunction:CALLTYPE_API)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   358
	    __callType = CALLTYPE_FFI_STDCALL;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   359
	}
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   360
#endif
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   361
#ifdef CALLTYPE_FFI_V8
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   362
	if (callTypeNumber == @global(ExternalLibraryFunction:CALLTYPE_V8)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   363
	    __callType = CALLTYPE_FFI_V8;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   364
	}
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   365
#endif
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   366
#ifdef CALLTYPE_FFI_V9
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   367
	if (callTypeNumber == @global(ExternalLibraryFunction:CALLTYPE_V9)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   368
	    __callType = CALLTYPE_FFI_V9;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   369
	}
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   370
#endif
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   371
#ifdef CALLTYPE_FFI_UNIX64
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   372
	if (callTypeNumber == @global(ExternalLibraryFunction:CALLTYPE_UNIX64)) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   373
	    __callType = CALLTYPE_FFI_UNIX64;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   374
	}
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   375
#endif
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   376
    }
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   377
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   378
# ifdef VERBOSE
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   379
    printf("prep_cif cif-ptr=%x\n", &__cif);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   380
# endif
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   381
    if (ffi_prep_cif(&__cif, __callType, __numArgsWanted, __returnType, __argTypesIncludingThis) != FFI_OK) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   382
	__FAIL__(@symbol(FFIPrepareFailed))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   383
    }
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   384
    pcl = (ffi_closure *) malloc(sizeof(ffi_closure));
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   385
# ifdef VERBOSE
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   386
    printf("closure is 0x%x (%d bytes)\n", pcl, sizeof(ffi_closure));
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   387
# endif
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   388
    if (ffi_prep_closure(pcl, &__cif, ExternalFunctionCallback__closure_test_fn, (void *) 3 /* userdata */) != FFI_OK) {
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   389
	__FAIL__(@symbol(FFIPrepareClosureFailed))
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   390
    }
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   391
# ifdef VERBOSE
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   392
    printf("pcl->cif is 0x%x\n", pcl->cif);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   393
    printf("pcl->fun is 0x%x\n", pcl->fun);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   394
    printf("pcl code is %02x %02x %02x %02x\n", ((char *)pcl)[0],((char *)pcl)[1],((char *)pcl)[2],((char *)pcl)[3]);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   395
    printf("            %02x %02x %02x %02x\n", ((char *)pcl)[4],((char *)pcl)[5],((char *)pcl)[6],((char *)pcl)[7]);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   396
    printf("            %02x %02x %02x %02x\n", ((char *)pcl)[8],((char *)pcl)[9],((char *)pcl)[10],((char *)pcl)[11]);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   397
    printf("            %02x %02x %02x %02x\n", ((char *)pcl)[12],((char *)pcl)[13],((char *)pcl)[14],((char *)pcl)[15]);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   398
#endif
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   399
    ExternalFunctionCallback__doCall_closure((INTFUNC)pcl);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   400
    free(pcl);
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   401
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   402
#else /* no FFI support */
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   403
    __FAIL__(@symbol(FFINotSupported));
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   404
#endif /* HAVE_FFI */
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   405
#endif /* 0 */
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   406
getOutOfHere: ;
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   407
%}.
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   408
    failureCode notNil ifTrue:[
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   409
	self primitiveFailed:(failureCode->failureInfo).   "see failureCode and failureInfo for details"
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   410
	^ nil
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   411
    ].
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   412
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   413
    "Created: / 11-06-2007 / 21:53:02 / cg"
9f42b83e653a *** empty log message ***
Claus Gittinger <cg@exept.de>
parents:
diff changeset
   414
! !