-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdmac.h
159 lines (137 loc) · 3.9 KB
/
dmac.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
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
/* Headers for DMAC class
Copyright (c) 2021 Amano laboratory, Keio University.
Author: Takuya Kojima
This file is part of CubeSim, a cycle accurate simulator for 3-D stacked system.
CubeSim 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 2 of the License, or
(at your option) any later version.
CubeSim 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 CubeSim. If not, see <https://www.gnu.org/licenses/>.
*/
#ifndef _DMAC_H_
#define _DMAC_H_
#include "deviceexc.h"
#include "mapper.h"
#include "range.h"
#include "deviceint.h"
//Address map
#define DMAC_ADDR_BASE 0xBD030000
#define DMAC_CONF_SIZE 0x20
#define DMAC_ENABLE_OFFSET 0x00000000
#define DMAC_INTEN_OFFSET 0x00000004
#define DMAC_CTRL_OFFSET 0x00000008
#define DMAC_STATUS_OFFSET 0x0000000C
#define DMAC_ATTR_OFFSET 0x00000010
#define DMAC_LEN_OFFSET 0x00000014
#define DMAC_SRC_OFFSET 0x00000018
#define DMAC_DST_OFFSET 0x0000001C
#define DMAC_DONELEN_OFFSET 0x00000020
//BITMAP
#define DMAC_ENABLED_BIT 0x1
#define DMAC_INTEN_BIT 0x1
#define DMAC_START_BIT 0x1
#define DMAC_ABORT_BIT 0x2
#define DMAC_BUSY_BIT 0x1
#define DMAC_DONE_BIT 0x2
#define DMAC_BUSERR_BIT 0x4
#define DMAC_ADRERR_BIT 0x8
#define DMAC_ESTATE_BIT 0x10
#define DMAC_BURST_BIT 0x1
#define DMAC_ZERO_BIT 0x2
//State machine
#define DMAC_STAT_IDLE 0x0
#define DMAC_STAT_READING 0x1
#define DMAC_STAT_READ_REQ 0x2
#define DMAC_STAT_WRITING 0x3
#define DMAC_STAT_WRITE_REQ 0x4
#define DMAC_STAT_READ_DONE 0x5
#define DMAC_STAT_WRITE_DONE 0x6
#define DMAC_STAT_EXIT 0x7
class Mapper;
struct DMA_query_t {
uint32 src;
uint32 dst;
uint32 len;
bool zero_write;
bool burst;
};
class DMACConfig : public Range {
private:
bool byteswapped;
bool kicked;
//activate
bool enabled;
//interrupt enabled
bool irq_en;
//ctrl
bool abort;
//status
bool busy;
bool done;
bool addr_err;
bool bus_err;
bool end_stat;
//attr
bool zero_write;
bool burst;
//query
uint32 dma_len, dma_src, dma_dst;
uint32 success_len;
public:
DMACConfig();
void reset();
uint32 fetch_word(uint32 offset, int mode,
DeviceExc *client);
uint16 fetch_halfword(uint32 offset, DeviceExc *client);
uint8 fetch_byte(uint32 offset, DeviceExc *client);
void store_word(uint32 offset, uint32 data,
DeviceExc *client);
void store_halfword(uint32 offset, uint16 data,
DeviceExc *client);
void store_byte(uint32 offset, uint8 data,
DeviceExc *client);
bool isKicked() { return kicked; }
bool isEnabled() { return enabled; }
bool isAbort() { return abort; }
bool isDone() { return done; }
bool isIRQEn() { return irq_en; }
void negateKicked() { kicked = false; }
void assertBusy() { busy = true; }
void negateBusy() { busy = false; }
void assertDone() { done = true; }
void assertAddrErr() { addr_err = true; }
void assertBusErr() { bus_err = true; }
void set_success_len(uint32 len) { success_len = len; }
void setIsLastWrite(bool flag) { end_stat = flag; }
DMA_query_t getQuery();
};
class DMAC : public DeviceExc, public DeviceInt {
private:
Mapper *bus;
DMACConfig *config;
uint32 *buffer;
int status;
int next_status;
int block_words;
DMA_query_t query;
int counter;
int word_counter;
int mem_bandwidth;
bool address_valid(uint32 addr);
public:
//Constructor
DMAC(Mapper &m);
void exception(uint16 excCode, int mode = ANY,
int coprocno = -1);
// Control-flow methods.
void step ();
void reset ();
//for device int
const char *descriptor_str() const;
};
#endif /* _DMAC_H_ */