/* See ../README for copyright */ /* * First six arguments are passed in registers with small (< sizeof(void*)) * values occupying the space of a pointer. * If the method returns a structure, it's address is passed as an invisible * first argument. */ #define MFRAME_STRUCT_BYREF 0 #define MFRAME_SMALL_STRUCT 0 #define MFRAME_ARGS_SIZE 104 #define MFRAME_RESULT_SIZE 16 #define MFRAME_FLT_IN_FRAME_AS_DBL 0 /* * Structures are passed by reference as an invisible first argument, so * they go in the first space on the stack. */ #define MFRAME_GET_STRUCT_ADDR(ARGS, TYPES) \ ((*(TYPES)==_C_STRUCT_B || *(TYPES)==_C_UNION_B || *(TYPES)==_C_ARY_B) ? \ ((void**)(ARGS))[1] : (void*)0) #define MFRAME_SET_STRUCT_ADDR(ARGS, TYPES, ADDR) \ ({if (*(TYPES)==_C_STRUCT_B || *(TYPES)==_C_UNION_B || *(TYPES)==_C_ARY_B) \ ((void**)(ARGS))[1] = (ADDR);}) /* * Declare a type for keeping track of the arguments processed. */ typedef struct alpha_args { int reg_pos; int stk_pos; } MFRAME_ARGS; /* * Initialize a variable to keep track of argument info while processing a * method. Keeps count of the offset of arguments on the stack. * This offset is adjusted to take account of an invisible first argument * used to return structures. */ #define MFRAME_INIT_ARGS(CUM, RTYPE) \ ({ \ (CUM).reg_pos = (*(RTYPE)==_C_STRUCT_B || *(RTYPE)==_C_UNION_B || \ *(RTYPE)==_C_ARY_B) ? 16 : 8; \ (CUM).stk_pos = 0; \ }) /* * Define maximum register offset - after this, stuff goes on the stack. */ #define ALPHAMAXR 56 #define MFRAME_ARG_ENCODING(CUM, TYPE, STACK, DEST) \ ({ \ const char* type = (TYPE); \ int align, size; \ \ (TYPE) = objc_skip_typespec(type); \ align = objc_alignof_type (type); \ size = objc_sizeof_type (type); \ size = ROUND(size, sizeof(void*)); \ \ if ((CUM).reg_pos + size > ALPHAMAXR) (CUM).reg_pos = ALPHAMAXR; \ if ((CUM).reg_pos == ALPHAMAXR) \ { \ sprintf((DEST), "%.*s%d", (TYPE)-type, type, (CUM).stk_pos); \ (CUM).stk_pos += size; \ (STACK) = (CUM).stk_pos; \ } \ else \ { \ sprintf((DEST), "%.*s+%d", (TYPE)-type, type, (CUM).reg_pos); \ (CUM).reg_pos += size; \ } \ (DEST)=&(DEST)[strlen(DEST)]; \ if (*(TYPE) == '+') \ { \ (TYPE)++; \ } \ if (*(TYPE) == '-') \ { \ (TYPE)++; \ } \ while (isdigit(*(TYPE))) \ { \ (TYPE)++; \ } \ })