aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/generator.c135
-rw-r--r--src/generator.h4
-rw-r--r--src/tpc.y20
3 files changed, 90 insertions, 69 deletions
diff --git a/src/generator.c b/src/generator.c
index b8a0b8f..33fade9 100644
--- a/src/generator.c
+++ b/src/generator.c
@@ -10,71 +10,74 @@
10void gen_prologue() { 10void gen_prologue() {
11 fprintf(output, "extern printf\nextern scanf\n"); 11 fprintf(output, "extern printf\nextern scanf\n");
12 fprintf(output, "section .data\n"); 12 fprintf(output, "section .data\n");
13}
14
15void gen_prologue_continue(int *bss_done) {
16 if (*bss_done != 0) return;
17
13 fprintf(output, "format_int db \"%%d\",10,0\n"); 18 fprintf(output, "format_int db \"%%d\",10,0\n");
14 fprintf(output, "format_char db \"%%c\",10,0\n"); 19 fprintf(output, "format_char db \"%%c\",10,0\n");
15 fprintf(output, "format_int_in: db \"%%d\", 0\n"); 20 fprintf(output, "format_int_in: db \"%%d\", 0\n");
16 fprintf(output, "format_char_in: db \"%%c\", 0\n\n"); 21 fprintf(output, "format_char_in: db \"%%c\", 0\n\n");
17 fprintf(output, "section .bss\n"); 22 fprintf(output, "section .bss\n");
23
24 fprintf(output, "globals: resq %d\n", nb_globals);
25 fprintf(output, "section .text\n\nglobal _start\n");
26 fprintf(output, "\nprinte: ;print needs an argument in rax\n");
27 fprintf(output, "push rbp\n");
28 fprintf(output, "mov rbp, rsp\n");
29 fprintf(output, "push rsi\n");
30 fprintf(output, "push rdi\n");
31 fprintf(output, "mov rsi, rax\n");
32 fprintf(output, "mov rdi, format_int\n");
33 fprintf(output, "mov rax, 0\n");
34 fprintf(output, "call printf WRT ..plt\n");
35 fprintf(output, "pop rdi\n");
36 fprintf(output, "pop rsi\n");
37 fprintf(output, "pop rbp\n");
38 fprintf(output, "ret\n");
39 fprintf(output, "\nprintc: ;print needs an argument in rax\n");
40 fprintf(output, "push rbp\n");
41 fprintf(output, "mov rbp, rsp\n");
42 fprintf(output, "push rsi\n");
43 fprintf(output, "push rdi\n");
44 fprintf(output, "mov rsi, rax\n");
45 fprintf(output, "mov rdi, format_char\n");
46 fprintf(output, "mov rax, 0\n");
47 fprintf(output, "call printf WRT ..plt\n");
48 fprintf(output, "pop rdi\n");
49 fprintf(output, "pop rsi\n");
50 fprintf(output, "pop rbp\n");
51 fprintf(output, "ret\n");
52 fprintf(output, "\nreade: ;read needs an adress in rax\n");
53 fprintf(output, "push rbp\n");
54 fprintf(output, "mov rbp, rsp\n");
55 fprintf(output, "push rsi\n");
56 fprintf(output, "push rdi\n");
57 fprintf(output, "mov rsi, rax\n");
58 fprintf(output, "mov rdi, format_int_in\n");
59 fprintf(output, "mov rax, 0\n");
60 fprintf(output, "call scanf\n");
61 fprintf(output, "pop rdi\n");
62 fprintf(output, "pop rsi\n");
63 fprintf(output, "pop rbp\n");
64 fprintf(output, "ret\n");
65 fprintf(output, "\nreadc: ;read needs an adress in rax\n");
66 fprintf(output, "push rbp\n");
67 fprintf(output, "mov rbp, rsp\n");
68 fprintf(output, "push rsi\n");
69 fprintf(output, "push rdi\n");
70 fprintf(output, "mov rsi, rax\n");
71 fprintf(output, "mov rdi, format_char_in\n");
72 fprintf(output, "mov rax, 0\n");
73 fprintf(output, "call scanf\n");
74 fprintf(output, "pop rdi\n");
75 fprintf(output, "pop rsi\n");
76 fprintf(output, "pop rbp\n");
77 fprintf(output, "ret\n");
78 *bss_done = 1;
18} 79}
19void gen_prologue_continue(int *bss_done) { 80
20 if (*bss_done == 0) {
21 fprintf(output, "globals: resq %d\n", nb_globals);
22 fprintf(output, "section .text\n\nglobal _start\n");
23 fprintf(output, "\nprinte: ;print needs an argument in rax\n");
24 fprintf(output, "push rbp\n");
25 fprintf(output, "mov rbp, rsp\n");
26 fprintf(output, "push rsi\n");
27 fprintf(output, "push rdi\n");
28 fprintf(output, "mov rsi, rax\n");
29 fprintf(output, "mov rdi, format_int\n");
30 fprintf(output, "mov rax, 0\n");
31 fprintf(output, "call printf WRT ..plt\n");
32 fprintf(output, "pop rdi\n");
33 fprintf(output, "pop rsi\n");
34 fprintf(output, "pop rbp\n");
35 fprintf(output, "ret\n");
36 fprintf(output, "\nprintc: ;print needs an argument in rax\n");
37 fprintf(output, "push rbp\n");
38 fprintf(output, "mov rbp, rsp\n");
39 fprintf(output, "push rsi\n");
40 fprintf(output, "push rdi\n");
41 fprintf(output, "mov rsi, rax\n");
42 fprintf(output, "mov rdi, format_char\n");
43 fprintf(output, "mov rax, 0\n");
44 fprintf(output, "call printf WRT ..plt\n");
45 fprintf(output, "pop rdi\n");
46 fprintf(output, "pop rsi\n");
47 fprintf(output, "pop rbp\n");
48 fprintf(output, "ret\n");
49 fprintf(output, "\nreade: ;read needs an adress in rax\n");
50 fprintf(output, "push rbp\n");
51 fprintf(output, "mov rbp, rsp\n");
52 fprintf(output, "push rsi\n");
53 fprintf(output, "push rdi\n");
54 fprintf(output, "mov rsi, rax\n");
55 fprintf(output, "mov rdi, format_int_in\n");
56 fprintf(output, "mov rax, 0\n");
57 fprintf(output, "call scanf\n");
58 fprintf(output, "pop rdi\n");
59 fprintf(output, "pop rsi\n");
60 fprintf(output, "pop rbp\n");
61 fprintf(output, "ret\n");
62 fprintf(output, "\nreadc: ;read needs an adress in rax\n");
63 fprintf(output, "push rbp\n");
64 fprintf(output, "mov rbp, rsp\n");
65 fprintf(output, "push rsi\n");
66 fprintf(output, "push rdi\n");
67 fprintf(output, "mov rsi, rax\n");
68 fprintf(output, "mov rdi, format_char_in\n");
69 fprintf(output, "mov rax, 0\n");
70 fprintf(output, "call scanf\n");
71 fprintf(output, "pop rdi\n");
72 fprintf(output, "pop rsi\n");
73 fprintf(output, "pop rbp\n");
74 fprintf(output, "ret\n");
75 *bss_done = 1;
76 }
77}
78void gen_const_declaration() { 81void gen_const_declaration() {
79 fprintf(output, "\n_start:\n"); 82 fprintf(output, "\n_start:\n");
80 fprintf(output, "push rbp\nmov rbp, rsp\n\n"); 83 fprintf(output, "push rbp\nmov rbp, rsp\n\n");
@@ -90,6 +93,20 @@ void gen_const_declaration() {
90 fun_display_table(); 93 fun_display_table();
91} 94}
92 95
96void gen_const(const char name[], int value, Scope scope) {
97 switch (scope) {
98 case LOCAL:
99 loc_addVar(name, INT); // TODO: make read only
100 fprintf(output, "push %d\n", value);
101 return;
102
103 case GLOBAL:
104 glo_addVar(name, INT); // TODO: make read only
105 fprintf(output, "%s: db QWORD %d\n", name, value);
106 return;
107 }
108}
109
93Type gen_function_declaration(const char name[], int return_type) { 110Type gen_function_declaration(const char name[], int return_type) {
94 fprintf(output, "\n%s:\npush rbp\nmov rbp,rsp\n", name); 111 fprintf(output, "\n%s:\npush rbp\nmov rbp,rsp\n", name);
95 return return_type; 112 return return_type;
diff --git a/src/generator.h b/src/generator.h
index 41a769a..6c132fd 100644
--- a/src/generator.h
+++ b/src/generator.h
@@ -7,6 +7,7 @@
7#define __GENERATOR_H__ 7#define __GENERATOR_H__
8 8
9#include <stdio.h> 9#include <stdio.h>
10#include <stdbool.h>
10#include "symbol_table.h" 11#include "symbol_table.h"
11 12
12typedef enum scope { 13typedef enum scope {
@@ -21,10 +22,13 @@ FILE *output;
21void gen_prologue(); 22void gen_prologue();
22void gen_prologue_continue(int *bss_done); 23void gen_prologue_continue(int *bss_done);
23void gen_const_declaration(); 24void gen_const_declaration();
25void gen_const(const char name[], int value, Scope scope);
26
24Type gen_function_declaration(const char name[], int return_type); 27Type gen_function_declaration(const char name[], int return_type);
25void gen_function_end_declaration(const char name[], int return_type, int nb_param); 28void gen_function_end_declaration(const char name[], int return_type, int nb_param);
26void gen_function_return(Type expect, Type actual); 29void gen_function_return(Type expect, Type actual);
27Type gen_function_call(const char name[], int nb_param); 30Type gen_function_call(const char name[], int nb_param);
31
28void gen_declaration(const char name[], int type, Scope scope); 32void gen_declaration(const char name[], int type, Scope scope);
29void gen_check(const char name[], Scope scope); 33void gen_check(const char name[], Scope scope);
30 34
diff --git a/src/tpc.y b/src/tpc.y
index 9878ce7..b5d0d35 100644
--- a/src/tpc.y
+++ b/src/tpc.y
@@ -54,32 +54,32 @@ static char fname[64];
54%precedence ELSE 54%precedence ELSE
55 55
56%% 56%%
57Prog: { gen_prologue(); } 57Prog: { gen_prologue(); }
58 DeclConsts DeclVars DeclFoncts { gen_const_declaration(); } 58 DeclConsts DeclVars DeclFoncts { gen_const_declaration(); }
59; 59;
60DeclConsts: 60DeclConsts:
61 DeclConsts CONST ListConst ';' 61 DeclConsts CONST ListConst ';'
62| 62|
63; 63;
64ListConst: 64ListConst:
65 ListConst ',' IDENT '=' Litteral 65 ListConst ',' IDENT '=' Litteral { gen_const($<ident>1, $<num>3, scope); }
66| IDENT '=' Litteral 66| IDENT '=' Litteral { gen_const($<ident>1, $<num>3, scope); }
67; 67;
68Litteral: 68Litteral:
69 NombreSigne 69 NombreSigne { $<num>$ = $<num>1; }
70| CARACTERE 70| CARACTERE { $<num>$ = $<num>1; }
71; 71;
72NombreSigne: 72NombreSigne:
73 NUM 73 NUM { $<num>$ = $<num>1; }
74| ADDSUB NUM 74| ADDSUB NUM { $<num>$ = $<addsub>1 == '-' ? - $<num>2 : $<num>2; }
75; 75;
76DeclVars: 76DeclVars:
77 DeclVars TYPE Declarateurs ';' 77 DeclVars TYPE Declarateurs ';'
78| 78|
79; 79;
80Declarateurs: 80Declarateurs:
81 Declarateurs ',' Declarateur { gen_declaration($<ident>3, $<type>0, scope); } 81 Declarateurs ',' Declarateur { gen_declaration($<ident>3, $<type>0, scope); }
82| Declarateur { gen_declaration($<ident>1, $<type>0, scope); } 82| Declarateur { gen_declaration($<ident>1, $<type>0, scope); }
83; 83;
84Declarateur: 84Declarateur:
85 IDENT 85 IDENT