Finish migrating to new mem handling. Make carthw db external.
[picodrive.git] / pico / pico / memory.c
CommitLineData
efcba75f 1#include "../pico_int.h"
45f2f245 2#include "../memory.h"
d49b10c2 3#include "../sound/sn76496.h"
9037e45d 4
45f2f245 5/*
6void dump(u16 w)
9037e45d 7{
45f2f245 8 static FILE *f[0x10] = { NULL, };
9 char fname[32];
10 int num = PicoPicohw.r12 & 0xf;
9037e45d 11
45f2f245 12 w = (w << 8) | (w >> 8);
13 sprintf(fname, "ldump%i.bin", num);
14 if (f[num] == NULL)
15 f[num] = fopen(fname, "wb");
16 fwrite(&w, 1, 2, f[num]);
17 //fclose(f);
18}
19*/
9037e45d 20
45f2f245 21static u32 PicoRead8_pico(u32 a)
22{
23 u32 d = 0;
9037e45d 24
45f2f245 25 if ((a & 0xffffe0) == 0x800000) // Pico I/O
406c96c5 26 {
27 switch (a & 0x1f)
28 {
1e6b5e39 29 case 0x01: d = PicoPicohw.r1; break;
406c96c5 30 case 0x03:
d49b10c2 31 d = PicoPad[0]&0x1f; // d-pad
42989e7d 32 d |= (PicoPad[0]&0x20) << 2; // pen push -> C
406c96c5 33 d = ~d;
34 break;
35
213c16ad 36 case 0x05: d = (PicoPicohw.pen_pos[0] >> 8); break; // what is MS bit for? Games read it..
37 case 0x07: d = PicoPicohw.pen_pos[0] & 0xff; break;
38 case 0x09: d = (PicoPicohw.pen_pos[1] >> 8); break;
39 case 0x0b: d = PicoPicohw.pen_pos[1] & 0xff; break;
d49b10c2 40 case 0x0d: d = (1 << (PicoPicohw.page & 7)) - 1; break;
213c16ad 41 case 0x12: d = PicoPicohw.fifo_bytes == 0 ? 0x80 : 0; break; // guess
406c96c5 42 default:
45f2f245 43 goto unhandled;
406c96c5 44 }
45f2f245 45 return d;
406c96c5 46 }
47
45f2f245 48unhandled:
49 elprintf(EL_UIO, "m68k unmapped r8 [%06x] @%06x", a, SekPc);
9037e45d 50 return d;
51}
52
45f2f245 53static u32 PicoRead16_pico(u32 a)
9037e45d 54{
45f2f245 55 u32 d = 0;
9037e45d 56
213c16ad 57 if (a == 0x800010)
d49b10c2 58 d = (PicoPicohw.fifo_bytes > 0x3f) ? 0 : (0x3f - PicoPicohw.fifo_bytes);
213c16ad 59 else if (a == 0x800012)
60 d = PicoPicohw.fifo_bytes == 0 ? 0x8000 : 0; // guess
fa22af4c 61 else
45f2f245 62 elprintf(EL_UIO, "m68k unmapped r16 [%06x] @%06x", a, SekPc);
9037e45d 63
9037e45d 64 return d;
65}
66
45f2f245 67static void PicoWrite8_pico(u32 a, u32 d)
9037e45d 68{
45f2f245 69 switch (a & ~0x800000) {
fa22af4c 70 case 0x19: case 0x1b: case 0x1d: case 0x1f: break; // 'S' 'E' 'G' 'A'
71 default:
45f2f245 72 elprintf(EL_UIO, "m68k unmapped w8 [%06x] %02x @%06x", a, d & 0xff, SekPc);
fa22af4c 73 break;
74 }
9037e45d 75}
76
45f2f245 77static void PicoWrite16_pico(u32 a, u32 d)
9037e45d 78{
582890c0 79 //if (a == 0x800010) dump(d);
ef4eb506 80 if (a == 0x800010)
81 {
82 PicoPicohw.fifo_bytes += 2;
83
84 if (PicoPicohw.xpcm_ptr < PicoPicohw.xpcm_buffer + XPCM_BUFFER_SIZE) {
85 *PicoPicohw.xpcm_ptr++ = d >> 8;
86 *PicoPicohw.xpcm_ptr++ = d;
87 }
88 else if (PicoPicohw.xpcm_ptr == PicoPicohw.xpcm_buffer + XPCM_BUFFER_SIZE) {
fa22af4c 89 elprintf(EL_ANOMALY|EL_PICOHW, "xpcm_buffer overflow!");
ef4eb506 90 PicoPicohw.xpcm_ptr++;
91 }
92 }
213c16ad 93 else if (a == 0x800012) {
94 int r12_old = PicoPicohw.r12;
95 PicoPicohw.r12 = d;
96 if (r12_old != d)
97 PicoReratePico();
98 }
fa22af4c 99 else
45f2f245 100 elprintf(EL_UIO, "m68k unmapped w16 [%06x] %04x @%06x", a, d & 0xffff, SekPc);
9037e45d 101}
102
9037e45d 103
104PICO_INTERNAL void PicoMemSetupPico(void)
105{
67c81ee2 106 PicoMemSetup();
45f2f245 107
108 // no MD IO or Z80 on Pico
109 m68k_map_unmap(0x400000, 0xbfffff);
110
111 // map Pico I/O
112 cpu68k_map_set(m68k_read8_map, 0x800000, 0x80ffff, PicoRead8_pico, 1);
113 cpu68k_map_set(m68k_read16_map, 0x800000, 0x80ffff, PicoRead16_pico, 1);
114 cpu68k_map_set(m68k_write8_map, 0x800000, 0x80ffff, PicoWrite8_pico, 1);
115 cpu68k_map_set(m68k_write16_map, 0x800000, 0x80ffff, PicoWrite16_pico, 1);
9037e45d 116}
117