1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
%{
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<ctype.h>
void apply(char);
void load_num(char);
void load_var(char);
void store_var(char);
int yyerror(char *);
int yylex();
int reg_count=0;
struct instruction {
char op1;
char op2;
char opr;
};
%}
%token IDENT NUM
%type expr
%left '+'
%left '*''/'
%left '-'
%%
statement: IDENT '=' expr ';' { store_var((char)$1); }
;
expr: expr '+' expr {apply('+');}
| expr '-' expr {apply('-');}
| expr '*' expr {apply('*');}
| NUM {load_num((char)$1); $$=(char)$1;}
| IDENT {load_var((char)$1); $$=(char)$1;}
;
%%
void apply(char opr) {
switch(opr) {
case '+':
printf("ADD ");
break;
case '-':
printf("SUB ");
break;
case '*': printf("MUL ");
}
printf("R%d, R%d, R%d\n", reg_count-2, reg_count-2, reg_count-1);
}
void load_num(char num) {
printf("LD R%d, #%c\n", reg_count++, num);
}
void load_var(char var) {
printf("LD R%d, %c\n", reg_count++, var);
}
void store_var(char var) {
printf("ST %c, R%d\n", var, reg_count-1);
}
int yyerror(char *s) {
printf("ERROR: %s",s);
exit(0);
}
int main() {
yyparse();
}
|