drc: lots of new debug code
[picodrive.git] / pico / memory.h
CommitLineData
af37bca8 1// memory map related stuff
2
3typedef unsigned char u8;
4typedef unsigned short u16;
5typedef unsigned int u32;
bcf65fd6 6typedef unsigned long uptr; // unsigned pointer-sized int
af37bca8 7
8#define M68K_MEM_SHIFT 16
45f2f245 9// minimum size we can map
10#define M68K_BANK_SIZE (1 << M68K_MEM_SHIFT)
11#define M68K_BANK_MASK (M68K_BANK_SIZE - 1)
af37bca8 12
bcf65fd6 13extern uptr m68k_read8_map [0x1000000 >> M68K_MEM_SHIFT];
14extern uptr m68k_read16_map [0x1000000 >> M68K_MEM_SHIFT];
15extern uptr m68k_write8_map [0x1000000 >> M68K_MEM_SHIFT];
16extern uptr m68k_write16_map[0x1000000 >> M68K_MEM_SHIFT];
af37bca8 17
bcf65fd6 18extern uptr s68k_read8_map [0x1000000 >> M68K_MEM_SHIFT];
19extern uptr s68k_read16_map [0x1000000 >> M68K_MEM_SHIFT];
20extern uptr s68k_write8_map [0x1000000 >> M68K_MEM_SHIFT];
21extern uptr s68k_write16_map[0x1000000 >> M68K_MEM_SHIFT];
af37bca8 22
b8a1c09a 23// top-level handlers that cores can use
24// (or alternatively build them into themselves)
25// XXX: unhandled: *16 and *32 might cross the bank boundaries
26typedef u32 (cpu68k_read_f)(u32 a);
27typedef void (cpu68k_write_f)(u32 a, u32 d);
28
29// z80
30#define Z80_MEM_SHIFT 13
31extern uptr z80_read_map [0x10000 >> Z80_MEM_SHIFT];
32extern uptr z80_write_map[0x10000 >> Z80_MEM_SHIFT];
33typedef unsigned char (z80_read_f)(unsigned short a);
34typedef void (z80_write_f)(unsigned int a, unsigned char data);
35
bcf65fd6 36void z80_map_set(uptr *map, int start_addr, int end_addr,
0ace9b9a 37 const void *func_or_mh, int is_func);
bcf65fd6 38void cpu68k_map_set(uptr *map, int start_addr, int end_addr,
0ace9b9a 39 const void *func_or_mh, int is_func);
af37bca8 40void cpu68k_map_all_ram(int start_addr, int end_addr, void *ptr, int is_sub);
41void m68k_map_unmap(int start_addr, int end_addr);
42
b8a1c09a 43#define map_flag_set(x) ((x) & ((uptr)1 << (sizeof(uptr) * 8 - 1)))
af37bca8 44
45#define MAKE_68K_READ8(name, map) \
46u32 name(u32 a) \
47{ \
bcf65fd6 48 uptr v; \
af37bca8 49 a &= 0x00ffffff; \
50 v = map[a >> M68K_MEM_SHIFT]; \
b8a1c09a 51 if (map_flag_set(v)) \
af37bca8 52 return ((cpu68k_read_f *)(v << 1))(a); \
53 else \
54 return *(u8 *)((v << 1) + (a ^ 1)); \
55}
56
57#define MAKE_68K_READ16(name, map) \
58u32 name(u32 a) \
59{ \
bcf65fd6 60 uptr v; \
af37bca8 61 a &= 0x00fffffe; \
62 v = map[a >> M68K_MEM_SHIFT]; \
b8a1c09a 63 if (map_flag_set(v)) \
af37bca8 64 return ((cpu68k_read_f *)(v << 1))(a); \
65 else \
66 return *(u16 *)((v << 1) + a); \
67}
68
69#define MAKE_68K_READ32(name, map) \
70u32 name(u32 a) \
71{ \
bcf65fd6 72 uptr v, vs; \
af37bca8 73 u32 d; \
74 a &= 0x00fffffe; \
75 v = map[a >> M68K_MEM_SHIFT]; \
76 vs = v << 1; \
b8a1c09a 77 if (map_flag_set(v)) { \
af37bca8 78 d = ((cpu68k_read_f *)vs)(a) << 16; \
79 d |= ((cpu68k_read_f *)vs)(a + 2); \
80 } \
81 else { \
82 u16 *m = (u16 *)(vs + a); \
83 d = (m[0] << 16) | m[1]; \
84 } \
85 return d; \
86}
87
88#define MAKE_68K_WRITE8(name, map) \
89void name(u32 a, u8 d) \
90{ \
bcf65fd6 91 uptr v; \
af37bca8 92 a &= 0x00ffffff; \
93 v = map[a >> M68K_MEM_SHIFT]; \
b8a1c09a 94 if (map_flag_set(v)) \
af37bca8 95 ((cpu68k_write_f *)(v << 1))(a, d); \
96 else \
97 *(u8 *)((v << 1) + (a ^ 1)) = d; \
98}
99
100#define MAKE_68K_WRITE16(name, map) \
101void name(u32 a, u16 d) \
102{ \
bcf65fd6 103 uptr v; \
af37bca8 104 a &= 0x00fffffe; \
105 v = map[a >> M68K_MEM_SHIFT]; \
b8a1c09a 106 if (map_flag_set(v)) \
af37bca8 107 ((cpu68k_write_f *)(v << 1))(a, d); \
108 else \
109 *(u16 *)((v << 1) + a) = d; \
110}
111
112#define MAKE_68K_WRITE32(name, map) \
113void name(u32 a, u32 d) \
114{ \
bcf65fd6 115 uptr v, vs; \
af37bca8 116 a &= 0x00fffffe; \
117 v = map[a >> M68K_MEM_SHIFT]; \
118 vs = v << 1; \
b8a1c09a 119 if (map_flag_set(v)) { \
af37bca8 120 ((cpu68k_write_f *)vs)(a, d >> 16); \
121 ((cpu68k_write_f *)vs)(a + 2, d); \
122 } \
123 else { \
124 u16 *m = (u16 *)(vs + a); \
125 m[0] = d >> 16; \
126 m[1] = d; \
127 } \
128}
129
00faec9c 130// 32x
131typedef struct {
132 uptr addr; // stores (membase >> 1) or ((handler >> 1) | (1<<31))
133 u32 mask;
134} sh2_memmap;