gesamt: bugfix bei mehreren methodenaufrufen in einer Expr
[uebersetzerbau-ss10.git] / gesamt / chelper.c
1 #include <stdio.h>
2 #include <string.h>
3 #include <stdlib.h>
4 #include "chelper.h"
5 #include "tree.h"
6
7 #if 0
8 #define DDCHELP
9 #endif
10
11 #define REGLEN 4
12 static char *regs64[] = {"rax", "r10", "r11", "r9"};
13 static char *regs8l[] = {"al", "r10b", "r11b", "r9b"};
14
15 /* ja, dirty.. */
16 static char *akt_func_name = (char*) NULL;
17 static char need_stack = 0;
18
19 void func_header(char *s, int vars, int parms, int call)
20 {
21         printf("\t.globl %1$s\n\t.type %1$s, @function\n%1$s:\n", s);
22         printf("\t//vars: %i, parms: %i, call(bool): %i\n", vars, parms, call);
23         akt_func_name = s;
24
25         need_stack = (vars || parms) && call;
26         if(need_stack) {
27                 printf("\tpushq %%rbp\n"
28                                 "\tmovq %%rsp, %%rbp\n"
29                                 "\tsubq $%d, %%rsp\n", 8*(vars+parms+2 /* fuer rax und r10*/));
30         }
31 }
32
33 char *get_func_name(void)
34 {
35         return akt_func_name;
36 }
37
38 void func_footer(void)
39 {
40         if(need_stack)
41                 printf("\tleave\n");
42         printf("\tret\n\n\n");
43 }
44
45 void move(char *src, char *dst)
46 {
47         if(src == (char*) NULL) return;
48         if(strcmp(src,dst) != 0) {
49                 printf("\tmovq %%%s, %%%s\n", src, dst);
50         }
51 }
52
53 void moveimm(long imm, char *dst)
54 {
55         char buf[100];
56         sprintf(buf, "$%d", imm);
57         printf("\tmovq %s, %%%s\n", buf, dst);
58 }
59
60 char *next_reg(char *s, int params)
61 {
62         int i = 0;
63         if (s != (char*) NULL) {
64                 while(strcmp(s, regs64[i]) != 0) {
65                         i = (i+1) % REGLEN;
66                 }
67                 i = (i+1) % REGLEN;
68         }
69 #ifdef DDCHELP
70         fprintf(stderr, "next_reg(): %s (bei %i parameter)\n", regs64[i], params);
71 #endif
72         return regs64[i];
73 }
74
75 char *reg_64to8l(char *s)
76 {
77         int i = 0;
78         if (s != (char*) NULL) {
79                 while(strcmp(s, regs64[i]) != 0) {
80                         i = (i+1) % REGLEN;
81                 }
82                 return regs8l[i];
83         }
84         fprintf(stderr, "reg_64to8l(): sollte nicht passieren\n");
85         exit(4);
86 }
87
88 char *param_reg(int num)
89 {
90         char *regs[] = {"rdi", "rsi", "rdx", "rcx", "r8", "r9", "r11"};
91         return regs[num];
92 }
93