|
@@ -37,6 +37,7 @@ typedef enum argtype {
|
|
|
TYPE_PTR,
|
|
|
TYPE_ARRAY,
|
|
|
TYPE_STRUCT,
|
|
|
+ TYPE_OLDDEVT,
|
|
|
} argtype;
|
|
|
|
|
|
#define MK_PTR(type) TYPE_PTR, type
|
|
@@ -104,6 +105,31 @@ static inline int thunk_type_size(const argtype *type_ptr, int is_host)
|
|
|
return TARGET_ABI_BITS / 8;
|
|
|
}
|
|
|
break;
|
|
|
+ case TYPE_OLDDEVT:
|
|
|
+ if (is_host) {
|
|
|
+#if defined(HOST_X86_64)
|
|
|
+ return 8;
|
|
|
+#elif defined(HOST_ALPHA) || defined(HOST_IA64) || defined(HOST_MIPS) || \
|
|
|
+ defined(HOST_PARISC) || defined(HOST_SPARC64)
|
|
|
+ return 4;
|
|
|
+#elif defined(HOST_PPC)
|
|
|
+ return HOST_LONG_SIZE;
|
|
|
+#else
|
|
|
+ return 2;
|
|
|
+#endif
|
|
|
+ } else {
|
|
|
+#if defined(TARGET_X86_64)
|
|
|
+ return 8;
|
|
|
+#elif defined(TARGET_ALPHA) || defined(TARGET_IA64) || defined(TARGET_MIPS) || \
|
|
|
+ defined(TARGET_PARISC) || defined(TARGET_SPARC64)
|
|
|
+ return 4;
|
|
|
+#elif defined(TARGET_PPC)
|
|
|
+ return TARGET_ABI_BITS / 8;
|
|
|
+#else
|
|
|
+ return 2;
|
|
|
+#endif
|
|
|
+ }
|
|
|
+ break;
|
|
|
case TYPE_ARRAY:
|
|
|
size = type_ptr[1];
|
|
|
return size * thunk_type_size_array(type_ptr + 2, is_host);
|
|
@@ -141,6 +167,8 @@ static inline int thunk_type_align(const argtype *type_ptr, int is_host)
|
|
|
return TARGET_ABI_BITS / 8;
|
|
|
}
|
|
|
break;
|
|
|
+ case TYPE_OLDDEVT:
|
|
|
+ return thunk_type_size(type_ptr, is_host);
|
|
|
case TYPE_ARRAY:
|
|
|
return thunk_type_align_array(type_ptr + 2, is_host);
|
|
|
case TYPE_STRUCT:
|