aboutsummaryrefslogtreecommitdiffhomepage
path: root/src/core/src/mem_map.cpp
blob: 975a0cf08f11c97bdd482dc69e25ff56610bbeb1 (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
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
/**
 * Copyright (C) 2014 Citra Emulator
 *
 * @file    mem_map.cpp
 * @author  ShizZy <shizzy247@gmail.com>
 * @date    2013-09-05
 * @brief   Memory map - handles virtual to physical memory access
 *
 * @section LICENSE
 * 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 2 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 at
 * http://www.gnu.org/copyleft/gpl.html
 *
 * Official project repository can be found at:
 * http://code.google.com/p/gekko-gc-emu/
 */

#include "common.h"
#include "mem_arena.h"

#include "mem_map.h"
#include "core.h"

////////////////////////////////////////////////////////////////////////////////////////////////////

namespace Memory {

	
u8*	g_base			= NULL;		///< The base pointer to the auto-mirrored arena.

MemArena g_arena;				///< The MemArena class

u8* g_bootrom			    = NULL;     ///< Bootrom memory (super secret code/data @ 0x8000) pointer
u8* g_fcram				    = NULL;	    ///< Main memory (FCRAM) pointer
u8* g_vram				    = NULL;	    ///< Video memory (VRAM) pointer
u8* g_scratchpad            = NULL;     ///< [Hack] Seperate mem for stack space because I don't know where this goes

u8* g_physical_bootrom	    = NULL;	    ///< Bootrom physical memory (super secret code/data @ 0x8000)
u8* g_uncached_bootrom	    = NULL;

u8* g_physical_fcram	    = NULL;	    ///< Main physical memory (FCRAM)
u8* g_physical_vram		    = NULL;	    ///< Video physical memory (VRAM)
u8* g_physical_scratchpad   = NULL;     ///< Scratchpad memory used for main thread stack


// We don't declare the IO region in here since its handled by other means.
static MemoryView g_views[] =
{
    {&g_scratchpad, &g_physical_scratchpad, 0x00000000,             MEM_SCRATCHPAD_SIZE,    0 },
//  {&g_bootrom,	&g_physical_bootrom,	0x00000000,             MEM_BOOTROM_SIZE,		0},
//  {NULL,			&g_uncached_bootrom,	0x00010000,             MEM_BOOTROM_SIZE,		MV_MIRROR_PREVIOUS},
//	{NULL,				NULL,					0x17E00000, MEM_MPCORE_PRIV_SIZE,	0},
	{&g_vram,		&g_physical_vram,		MEM_VRAM_VADDR,          MEM_VRAM_SIZE,			MV_IS_PRIMARY_RAM},
//	{NULL,				NULL,					0x1FF00000, MEM_DSP_SIZE,			0},
//	{NULL,				NULL,					0x1FF80000, MEM_AXI_WRAM_SIZE,		0},
   
	{&g_fcram,		&g_physical_fcram,		MEM_FCRAM_VADDR,        MEM_FCRAM_SIZE,			MV_IS_PRIMARY_RAM},
    
};

/*static MemoryView views[] =
{
	{&m_pScratchPad, &m_pPhysicalScratchPad,  0x00010000, SCRATCHPAD_SIZE, 0},
	{NULL,           &m_pUncachedScratchPad,  0x40010000, SCRATCHPAD_SIZE, MV_MIRROR_PREVIOUS},
	{&m_pVRAM,       &m_pPhysicalVRAM,        0x04000000, 0x00800000, 0},
	{NULL,           &m_pUncachedVRAM,        0x44000000, 0x00800000, MV_MIRROR_PREVIOUS},
	{&m_pRAM,        &m_pPhysicalRAM,         0x08000000, g_MemorySize, MV_IS_PRIMARY_RAM},	// only from 0x08800000 is it usable (last 24 megs)
	{NULL,           &m_pUncachedRAM,         0x48000000, g_MemorySize, MV_MIRROR_PREVIOUS | MV_IS_PRIMARY_RAM},
	{NULL,           &m_pKernelRAM,           0x88000000, g_MemorySize, MV_MIRROR_PREVIOUS | MV_IS_PRIMARY_RAM},

	// TODO: There are a few swizzled mirrors of VRAM, not sure about the best way to
	// implement those.
};*/

static const int kNumMemViews = sizeof(g_views) / sizeof(MemoryView);	///< Number of mem views

void Init() {
	int flags = 0;

	for (size_t i = 0; i < ARRAY_SIZE(g_views); i++) {
		if (g_views[i].flags & MV_IS_PRIMARY_RAM)
			g_views[i].size = MEM_FCRAM_SIZE;
	}

	g_base = MemoryMap_Setup(g_views, kNumMemViews, flags, &g_arena);

	NOTICE_LOG(MEMMAP, "Memory system initialized. RAM at %p (mirror at 0 @ %p)", g_fcram, 
		g_physical_fcram);
}

void Shutdown() {
	u32 flags = 0;
	MemoryMap_Shutdown(g_views, kNumMemViews, flags, &g_arena);
	g_arena.ReleaseSpace();
	g_base = NULL;
	NOTICE_LOG(MEMMAP, "Memory system shut down.");
}



} // namespace