generated from cc3-ug/proj01-2022
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtypes.h
111 lines (92 loc) · 2.49 KB
/
types.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
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
#ifndef TYPES_H
#define TYPES_H
#include <stdint.h>
/* WARNING: DO NOT CHANGE THIS FILE.
YOU SHOULD DEFINITELY CONSULT IT THOUGH... */
/* convenient(?) data definitions */
typedef uint8_t Byte; /* unsigned, 8-bit */
typedef uint16_t Half; /* unsigned, 16-bit */
typedef uint32_t Word; /* unsigned, 32-bit */
typedef uint64_t Double; /* unsigned, 64-bit */
typedef int8_t sByte; /* signed, 8-bit */
typedef int16_t sHalf; /* signed, 16-bit */
typedef int32_t sWord; /* signed, 32-bit */
typedef int64_t sDouble; /* signed, 64-bit */
/* A memory address */
typedef Word Address; /* unsigned, 32-bit */
/* A register value */
typedef Word Register; /* unsigned 32-bit*/
/* The processor data:
32 registers
PC program counter */
typedef struct {
Register R[32];
Register PC;
} Processor;
/* Possible lengths of data, and their lengths in bytes.
These are used to align memory*/
typedef enum {
LENGTH_BYTE = 1,
LENGTH_HALF_WORD = 2,
LENGTH_WORD = 4,
} Alignment;
/* This is the length of the memory space */
#define MEMORY_SPACE (1024 * 1024) /* 1 MByte of Memory */
/* If you haven't seen a union before, go look it up.
Seriously. They're fun. */
typedef union {
/* access opcode with: instruction.opcode */
struct {
unsigned int opcode : 7;
unsigned int : 25;
};
/* access rtype with: instruction.rtype.(opcode|rd|funct3|rs1|rs2|funct7) */
struct {
unsigned int opcode : 7;
unsigned int rd : 5;
unsigned int funct3 : 3;
unsigned int rs1 : 5;
unsigned int rs2 : 5;
unsigned int funct7 : 7;
} rtype;
/* access itype with: instruction.itype.(oppcode|rs|rt|imm) */
struct {
unsigned int opcode : 7;
unsigned int rd : 5;
unsigned int funct3 : 3;
unsigned int rs1 : 5;
unsigned int imm : 12;
} itype;
/* access jtype with: instruction.jtype.(opcode|addr) */
struct {
unsigned int opcode : 7;
unsigned int rd : 5;
unsigned int imm : 20;
} utype;
/* and so on... */
struct {
unsigned int opcode : 7;
unsigned int rd : 5;
unsigned int imm : 20;
} jtype;
struct {
unsigned int opcode : 7;
unsigned int imm5: 5;
unsigned int funct3: 3;
unsigned int rs1 : 5;
unsigned int rs2 : 5;
unsigned int imm7 : 7;
} stype;
struct {
unsigned int opcode : 7;
unsigned int imm5: 5;
unsigned int funct3: 3;
unsigned int rs1 : 5;
unsigned int rs2 : 5;
unsigned int imm7 : 7;
} btype;
/* basically ignore this stuff*/
int16_t chunks16[2];
uint32_t bits;
} Instruction;
#endif