-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathInstrucao.h
44 lines (41 loc) · 1.56 KB
/
Instrucao.h
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
#ifndef INSTRUCAO_H
#define INSTRUCAO_H
#include "Dado.h"
class Instrucao: public Dado{
private:
int origem1;
int origem2;
int destino;
int imediato;
int funcao;
Instrucao(int valor, int origem1, int origem2, int destino, int imediato, int funcao);
public:
static const int LW = 35;
static const int SW = 43;
static const int J = 2;
static const int BNE = 5;
static const int BEQ = 4;
static const int TIPO_R = 0;
static const int FUNCAO_ADD = 32;
static const int FUNCAO_SUB = 34;
static const int FUNCAO_MULT = 24;
static const int FUNCAO_DIV = 26;
static Instrucao* criarLW(int destino, int imediato);
static Instrucao* criarSW(int destino, int imediato);
static Instrucao* criarJ(int imediato);
static Instrucao* criarBNE(int origem1, int origem2, int imediato);
static Instrucao* criarBEQ(int origem1, int origem2, int imediato);
static Instrucao* criarADD(int destino, int origem1, int origem2);
static Instrucao* criarSUB(int destino, int origem1, int origem2);
static Instrucao* criarMULT(int origem1, int origem2);
static Instrucao* criarDIV(int origem1, int origem2);
virtual ~Instrucao();
virtual int getOpcode();
virtual int getOrigem1();
virtual int getOrigem2();
virtual int getDestino();
virtual int getImediato();
virtual int getFuncao();
void imprimir();
};
#endif