summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorGravatar bunnei2014-04-26 14:21:40 -0400
committerGravatar bunnei2014-04-26 14:21:40 -0400
commitf78794961e2bdcb0314516a3c2409afbfcd6d470 (patch)
treec1dffc4ea73a3adf530dcde922c8d83229345599 /src
parentadded simple GSP GPU ReadHWRegs function to support returning the framebuffe... (diff)
downloadyuzu-f78794961e2bdcb0314516a3c2409afbfcd6d470.tar.gz
yuzu-f78794961e2bdcb0314516a3c2409afbfcd6d470.tar.xz
yuzu-f78794961e2bdcb0314516a3c2409afbfcd6d470.zip
- changed HW IO map to use virtual addresses
- added hooks to catch LCD IO read/writes
Diffstat (limited to 'src')
-rw-r--r--src/core/hw/hw.cpp76
-rw-r--r--src/core/hw/lcd.cpp14
-rw-r--r--src/core/mem_map.h4
-rw-r--r--src/core/mem_map_funcs.cpp12
4 files changed, 64 insertions, 42 deletions
diff --git a/src/core/hw/hw.cpp b/src/core/hw/hw.cpp
index 16bd70125..85669ae7f 100644
--- a/src/core/hw/hw.cpp
+++ b/src/core/hw/hw.cpp
@@ -12,49 +12,42 @@
12namespace HW { 12namespace HW {
13 13
14enum { 14enum {
15 ADDRESS_CONFIG = 0x10000000, 15 VADDR_HASH = 0x1EC01000,
16 ADDRESS_IRQ = 0x10001000, 16 VADDR_CSND = 0x1EC03000,
17 ADDRESS_NDMA = 0x10002000, 17 VADDR_DSP = 0x1EC40000,
18 ADDRESS_TIMER = 0x10003000, 18 VADDR_PDN = 0x1EC41000,
19 ADDRESS_CTRCARD = 0x10004000, 19 VADDR_CODEC = 0x1EC41000,
20 ADDRESS_CTRCARD_2 = 0x10005000, 20 VADDR_SPI = 0x1EC42000,
21 ADDRESS_SDMC_NAND = 0x10006000, 21 VADDR_SPI_2 = 0x1EC43000, // Only used under TWL_FIRM?
22 ADDRESS_SDMC_NAND_2 = 0x10007000, // Apparently not used on retail 22 VADDR_I2C = 0x1EC44000,
23 ADDRESS_PXI = 0x10008000, 23 VADDR_CODEC_2 = 0x1EC45000,
24 ADDRESS_AES = 0x10009000, 24 VADDR_HID = 0x1EC46000,
25 ADDRESS_SHA = 0x1000A000, 25 VADDR_PAD = 0x1EC46000,
26 ADDRESS_RSA = 0x1000B000, 26 VADDR_PTM = 0x1EC46000,
27 ADDRESS_XDMA = 0x1000C000, 27 VADDR_GPIO = 0x1EC47000,
28 ADDRESS_SPICARD = 0x1000D800, 28 VADDR_I2C_2 = 0x1EC48000,
29 ADDRESS_CONFIG_2 = 0x10010000, 29 VADDR_SPI_3 = 0x1EC60000,
30 ADDRESS_HASH = 0x10101000, 30 VADDR_I2C_3 = 0x1EC61000,
31 ADDRESS_CSND = 0x10103000, 31 VADDR_MIC = 0x1EC62000,
32 ADDRESS_DSP = 0x10140000, 32 VADDR_PXI = 0x1EC63000, // 0xFFFD2000
33 ADDRESS_PDN = 0x10141000, 33 //VADDR_NTRCARD
34 ADDRESS_CODEC = 0x10141000, 34 VADDR_CDMA = 0xFFFDA000, // CoreLink DMA-330? Info
35 ADDRESS_SPI = 0x10142000, 35 VADDR_DSP_2 = 0x1ED03000,
36 ADDRESS_SPI_2 = 0x10143000, 36 VADDR_HASH_2 = 0x1EE01000,
37 ADDRESS_I2C = 0x10144000, 37 VADDR_LCD = 0x1EF00000,
38 ADDRESS_CODEC_2 = 0x10145000,
39 ADDRESS_HID = 0x10146000,
40 ADDRESS_PAD = 0x10146000,
41 ADDRESS_PTM = 0x10146000,
42 ADDRESS_I2C_2 = 0x10148000,
43 ADDRESS_SPI_3 = 0x10160000,
44 ADDRESS_I2C_3 = 0x10161000,
45 ADDRESS_MIC = 0x10162000,
46 ADDRESS_PXI_2 = 0x10163000,
47 ADDRESS_NTRCARD = 0x10164000,
48 ADDRESS_DSP_2 = 0x10203000,
49 ADDRESS_HASH_2 = 0x10301000,
50}; 38};
51 39
52template <typename T> 40template <typename T>
53inline void Read(T &var, const u32 addr) { 41inline void Read(T &var, const u32 addr) {
54 switch (addr & 0xFFFFF000) { 42 switch (addr & 0xFFFFF000) {
55 43
56 case ADDRESS_NDMA: 44 // TODO(bunnei): What is the virtual address of NDMA?
57 NDMA::Read(var, addr); 45 // case VADDR_NDMA:
46 // NDMA::Read(var, addr);
47 // break;
48
49 case VADDR_LCD:
50 LCD::Read(var, addr);
58 break; 51 break;
59 52
60 default: 53 default:
@@ -66,8 +59,13 @@ template <typename T>
66inline void Write(u32 addr, const T data) { 59inline void Write(u32 addr, const T data) {
67 switch (addr & 0xFFFFF000) { 60 switch (addr & 0xFFFFF000) {
68 61
69 case ADDRESS_NDMA: 62 // TODO(bunnei): What is the virtual address of NDMA?
70 NDMA::Write(addr, data); 63 // case VADDR_NDMA
64 // NDMA::Write(addr, data);
65 // break;
66
67 case VADDR_LCD:
68 LCD::Write(addr, data);
71 break; 69 break;
72 70
73 default: 71 default:
diff --git a/src/core/hw/lcd.cpp b/src/core/hw/lcd.cpp
index 3013673f8..822cd1647 100644
--- a/src/core/hw/lcd.cpp
+++ b/src/core/hw/lcd.cpp
@@ -18,12 +18,26 @@ u64 g_last_ticks = 0; ///< Last CPU ticks
18 18
19template <typename T> 19template <typename T>
20inline void Read(T &var, const u32 addr) { 20inline void Read(T &var, const u32 addr) {
21 ERROR_LOG(LCD, "unknown Read%d @ 0x%08X", sizeof(var) * 8, addr);
21} 22}
22 23
23template <typename T> 24template <typename T>
24inline void Write(u32 addr, const T data) { 25inline void Write(u32 addr, const T data) {
26 ERROR_LOG(LCD, "unknown Write%d 0x%08X @ 0x%08X", sizeof(data) * 8, data, addr);
25} 27}
26 28
29// Explicitly instantiate template functions because we aren't defining this in the header:
30
31template void Read<u64>(u64 &var, const u32 addr);
32template void Read<u32>(u32 &var, const u32 addr);
33template void Read<u16>(u16 &var, const u32 addr);
34template void Read<u8>(u8 &var, const u32 addr);
35
36template void Write<u64>(u32 addr, const u64 data);
37template void Write<u32>(u32 addr, const u32 data);
38template void Write<u16>(u32 addr, const u16 data);
39template void Write<u8>(u32 addr, const u8 data);
40
27/// Update hardware 41/// Update hardware
28void Update() { 42void Update() {
29 u64 current_ticks = Core::g_app_core->GetTicks(); 43 u64 current_ticks = Core::g_app_core->GetTicks();
diff --git a/src/core/mem_map.h b/src/core/mem_map.h
index 087e8d3bc..1a49cc98d 100644
--- a/src/core/mem_map.h
+++ b/src/core/mem_map.h
@@ -48,7 +48,9 @@ enum {
48 FCRAM_VADDR = 0x08000000, ///< FCRAM virtual address 48 FCRAM_VADDR = 0x08000000, ///< FCRAM virtual address
49 FCRAM_VADDR_END = (FCRAM_VADDR + FCRAM_SIZE), ///< FCRAM end of virtual space 49 FCRAM_VADDR_END = (FCRAM_VADDR + FCRAM_SIZE), ///< FCRAM end of virtual space
50 50
51 HARDWARE_IO_VADDR = 0x1EC00000, 51 HARDWARE_IO_PADDR = 0x10000000, ///< IO physical address start
52 HARDWARE_IO_VADDR = 0x1EC00000, ///< IO virtual address start
53 HARDWARE_IO_PADDR_END = (HARDWARE_IO_PADDR + HARDWARE_IO_SIZE),
52 HARDWARE_IO_VADDR_END = (HARDWARE_IO_VADDR + HARDWARE_IO_SIZE), 54 HARDWARE_IO_VADDR_END = (HARDWARE_IO_VADDR + HARDWARE_IO_SIZE),
53 55
54 VRAM_VADDR = 0x1F000000, 56 VRAM_VADDR = 0x1F000000,
diff --git a/src/core/mem_map_funcs.cpp b/src/core/mem_map_funcs.cpp
index 875821adb..d0bec31c6 100644
--- a/src/core/mem_map_funcs.cpp
+++ b/src/core/mem_map_funcs.cpp
@@ -21,8 +21,16 @@ u32 _AddressPhysicalToVirtual(const u32 addr) {
21 // Our memory interface read/write functions assume virtual addresses. Put any physical address 21 // Our memory interface read/write functions assume virtual addresses. Put any physical address
22 // to virtual address translations here. This is obviously quite hacky... But we're not doing 22 // to virtual address translations here. This is obviously quite hacky... But we're not doing
23 // any MMU emulation yet or anything 23 // any MMU emulation yet or anything
24 if ((addr >= FCRAM_PADDR) && (addr < (FCRAM_PADDR_END))) { 24 if ((addr >= FCRAM_PADDR) && (addr < FCRAM_PADDR_END)) {
25 return (addr & FCRAM_MASK) | FCRAM_VADDR; 25 return (addr & FCRAM_MASK) | FCRAM_VADDR;
26
27 // Hardware IO
28 // TODO(bunnei): FixMe
29 // This isn't going to work... The physical address of HARDWARE_IO conflicts with the virtual
30 // address of shared memory.
31 //} else if ((addr >= HARDWARE_IO_PADDR) && (addr < HARDWARE_IO_PADDR_END)) {
32 // return (addr + 0x0EB00000);
33
26 } 34 }
27 return addr; 35 return addr;
28} 36}
@@ -132,7 +140,7 @@ u8 *GetPointer(const u32 addr) {
132 return g_vram + (vaddr & VRAM_MASK); 140 return g_vram + (vaddr & VRAM_MASK);
133 141
134 } else { 142 } else {
135 ERROR_LOG(MEMMAP, "Unknown GetPointer @ 0x%08x", vaddr); 143 ERROR_LOG(MEMMAP, "unknown GetPointer @ 0x%08x", vaddr);
136 return 0; 144 return 0;
137 } 145 }
138} 146}