#include #include #include #include "chelper.h" #include "tree.h" #if 0 #define DDCHELP #endif #define REGLEN 5 static char *regsppc[] = {"14", "15", "16", "17", "18"}; /* ja, dirty.. */ static char *akt_func_name = (char*) NULL; static char need_stack = 0; void func_header(char *s, int vars, int parms, int call) { printf("\t.globl %1$s\n\t.type %1$s, @function\n%1$s:\n", s); printf("\t#vars: %i, parms: %i, call(bool): %i\n", vars, parms, call); akt_func_name = s; need_stack = (vars || parms) && call; if(need_stack) { printf("\tenter $%d, $0\n", 8*(vars + parms + 2 /* fuer rax und r10 */)); } } char *get_func_name(void) { return akt_func_name; } void func_footer(void) { if(need_stack) printf("\tleave\n"); printf("\tblr\n\n\n"); } void move(char *src, char *dst) { if(src == (char*) NULL) return; if(strcmp(src,dst) != 0) { printf("\tmr %s, %s\n", dst, src); } } void moveimm(long imm, char *dst) { /* TODO: 32 bits... */ printf("\taddi %s,0,%d\n", dst, imm); } char *next_reg(char *s, int params) { int i = 0; if (s != (char*) NULL) { while(strcmp(s, regsppc[i]) != 0) { i = (i+1) % REGLEN; } i = (i+1) % REGLEN; } #ifdef DDCHELP fprintf(stderr, "next_reg(): %s (bei %i parameter)\n", regsppc[i], params); #endif return regsppc[i]; } char *reg_64to8l(char *s) { fprintf(stderr, "reg_64to8l(): sollte nicht passieren\n"); exit(4); return ""; } char *param_reg(int num) { char *regs[] = {"3", "4", "5", "6", "7", "8", "9"}; return regs[num]; }