-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcpu.c
More file actions
executable file
·78 lines (75 loc) · 2.29 KB
/
cpu.c
File metadata and controls
executable file
·78 lines (75 loc) · 2.29 KB
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
74
75
76
77
78
/*******************************
** GRANDE SWITCH D'O QUE FAZER *
*******************************/
#include <stdio.h>
#include "globals.h"
#include "defines.h"
#include "cpu.h"
line mem[256]; /* Nosso bloco de memoria */
char acc; /* Registrador acc (acumulador) */
unsigned char pc; /* Registrador pc (Program Counter) */
unsigned char ds; /* Registrador ds (Data Section) */
unsigned char cs; /* Registrador cs (Code Section) */
process running;
int run_line()
{
switch(mem[running->pc + running->cs].inst)
{
case 0:
/* running->acc = running->acc + op */
running->acc = running->acc + mem[mem[running->pc + running->cs].op + running->ds].inst;
break;
case 1:
/* running->acc = running->acc - op */
running->acc = running->acc - mem[mem[running->pc + running->cs].op + running->ds].inst;
break;
case 2:
/* running->acc = running->acc * op */
running->acc = running->acc * mem[mem[running->pc + running->cs].op + running->ds].inst;
break;
case 3:
/* running->acc = running->acc / op */
running->acc = running->acc / mem[mem[running->pc + running->cs].op + running->ds].inst;
break;
case 4:
/* running->acc = op */
running->acc = mem[mem[running->pc + running->cs].op + running->ds].inst;
break;
case 5:
/* op = running->acc */
mem[mem[running->pc + running->cs].op + running->ds].inst = running->acc;
break;
case 6:
//NOP
break;
case 7:
//Se running->acc > 0 salta para [op]
if(running->acc > 0) running->pc = mem[running->pc + running->cs].op + running->cs;
break;
case 8:
//Se running->acc < 0 salta para [op]
if(running->acc < 0) running->pc = mem[running->pc + running->cs].op + running->cs;
break;
case 9:
//Se running->acc == 0 salta para [op]
if(running->acc == 0) running->pc = mem[running->pc + running->cs].op + running->cs;
break;
case 10:
//In para [op]
fprintf(running->tty, "$< ");
fscanf(running->tty, "%d", &mem[mem[running->pc + running->cs].op + running->ds].inst);
break;
case 11:
//Out de [op]
fprintf(running->tty, "$> %d\n", mem[mem[running->pc + running->cs].op + running->ds].inst);
break;
case 12:
fprintf(running->tty, "Fim de execução\n");
return PROG_END;
break;
default:
printf("INSTRUCAO INVALIDA!\n");
return INVINST_FAIL;
}
return 0;
}