blob: ccc6ed9be6d5b3e49f90f3747a4bfe73220f6e91 (
plain)
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
|
// Simulator for the RISC-V[ECTOR] mini-ISA
// Copyright (C) 2025 Siddarth Suresh
// Copyright (C) 2025 bdunahu
// This program is free software: you can redistribute it and/or modify
// it under the terms of the GNU General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
// You should have received a copy of the GNU General Public License
// along with this program. If not, see <https://www.gnu.org/licenses/>.
#ifndef INSTRDTO_H
#define INSTRDTO_H
#include "instr.h"
#include "pipe_spec.h"
#include <array>
struct U_INT_TYPE {
signed int slot_one;
signed int slot_two;
signed int slot_three;
};
struct V_TYPE {
std::array<signed int, V_R_LIMIT> slot_one;
std::array<signed int, V_R_LIMIT> slot_two;
std::array<signed int, V_R_LIMIT> slot_three;
};
struct VI_TYPE {
signed int slot_one;
signed int slot_two;
std::array<signed int, V_R_LIMIT> slot_three;
};
struct InstrDTO {
/**
* If this instruction is squashed or not.
*/
unsigned int is_squashed : 1;
/**
* Optional slot for holding the Instruction Bits
*/
signed int slot_A;
/**
* Optional slot for holding PC
*/
signed int slot_B;
/**
* The mnemonic of the instruction.
*/
Mnemonic mnemonic;
/**
* The register this instruction checks out.
*/
signed int checked_out;
/**
* The currently active union member.
*/
FieldType type;
union {
struct U_INT_TYPE integer;
struct V_TYPE vector;
struct VI_TYPE i_vector;
} operands;
};
#endif /* INSTRDTO_H_INCLUDED */
|