mirror of
https://github.com/RaySollium99/picodrive.git
synced 2025-09-05 07:17:45 -04:00
port to 64bit. Some gcc 4.4 warning fixes
git-svn-id: file:///home/notaz/opt/svn/PicoDrive@835 be3aeb3a-fb24-0410-a615-afba39da0efa
This commit is contained in:
parent
71f68165b6
commit
b8a1c09ad1
19 changed files with 102 additions and 80 deletions
|
@ -20,6 +20,19 @@ extern uptr s68k_read16_map [0x1000000 >> M68K_MEM_SHIFT];
|
|||
extern uptr s68k_write8_map [0x1000000 >> M68K_MEM_SHIFT];
|
||||
extern uptr s68k_write16_map[0x1000000 >> M68K_MEM_SHIFT];
|
||||
|
||||
// top-level handlers that cores can use
|
||||
// (or alternatively build them into themselves)
|
||||
// XXX: unhandled: *16 and *32 might cross the bank boundaries
|
||||
typedef u32 (cpu68k_read_f)(u32 a);
|
||||
typedef void (cpu68k_write_f)(u32 a, u32 d);
|
||||
|
||||
// z80
|
||||
#define Z80_MEM_SHIFT 13
|
||||
extern uptr z80_read_map [0x10000 >> Z80_MEM_SHIFT];
|
||||
extern uptr z80_write_map[0x10000 >> Z80_MEM_SHIFT];
|
||||
typedef unsigned char (z80_read_f)(unsigned short a);
|
||||
typedef void (z80_write_f)(unsigned int a, unsigned char data);
|
||||
|
||||
void z80_map_set(uptr *map, int start_addr, int end_addr,
|
||||
const void *func_or_mh, int is_func);
|
||||
void cpu68k_map_set(uptr *map, int start_addr, int end_addr,
|
||||
|
@ -27,11 +40,7 @@ void cpu68k_map_set(uptr *map, int start_addr, int end_addr,
|
|||
void cpu68k_map_all_ram(int start_addr, int end_addr, void *ptr, int is_sub);
|
||||
void m68k_map_unmap(int start_addr, int end_addr);
|
||||
|
||||
// top-level handlers that cores can use
|
||||
// (or alternatively build them into themselves)
|
||||
// XXX: unhandled: *16 and *32 might cross the bank boundaries
|
||||
typedef u32 (cpu68k_read_f)(u32 a);
|
||||
typedef void (cpu68k_write_f)(u32 a, u32 d);
|
||||
#define map_flag_set(x) ((x) & ((uptr)1 << (sizeof(uptr) * 8 - 1)))
|
||||
|
||||
#define MAKE_68K_READ8(name, map) \
|
||||
u32 name(u32 a) \
|
||||
|
@ -39,7 +48,7 @@ u32 name(u32 a) \
|
|||
uptr v; \
|
||||
a &= 0x00ffffff; \
|
||||
v = map[a >> M68K_MEM_SHIFT]; \
|
||||
if (v & 0x80000000) \
|
||||
if (map_flag_set(v)) \
|
||||
return ((cpu68k_read_f *)(v << 1))(a); \
|
||||
else \
|
||||
return *(u8 *)((v << 1) + (a ^ 1)); \
|
||||
|
@ -51,7 +60,7 @@ u32 name(u32 a) \
|
|||
uptr v; \
|
||||
a &= 0x00fffffe; \
|
||||
v = map[a >> M68K_MEM_SHIFT]; \
|
||||
if (v & 0x80000000) \
|
||||
if (map_flag_set(v)) \
|
||||
return ((cpu68k_read_f *)(v << 1))(a); \
|
||||
else \
|
||||
return *(u16 *)((v << 1) + a); \
|
||||
|
@ -65,7 +74,7 @@ u32 name(u32 a) \
|
|||
a &= 0x00fffffe; \
|
||||
v = map[a >> M68K_MEM_SHIFT]; \
|
||||
vs = v << 1; \
|
||||
if (v & 0x80000000) { \
|
||||
if (map_flag_set(v)) { \
|
||||
d = ((cpu68k_read_f *)vs)(a) << 16; \
|
||||
d |= ((cpu68k_read_f *)vs)(a + 2); \
|
||||
} \
|
||||
|
@ -82,7 +91,7 @@ void name(u32 a, u8 d) \
|
|||
uptr v; \
|
||||
a &= 0x00ffffff; \
|
||||
v = map[a >> M68K_MEM_SHIFT]; \
|
||||
if (v & 0x80000000) \
|
||||
if (map_flag_set(v)) \
|
||||
((cpu68k_write_f *)(v << 1))(a, d); \
|
||||
else \
|
||||
*(u8 *)((v << 1) + (a ^ 1)) = d; \
|
||||
|
@ -94,7 +103,7 @@ void name(u32 a, u16 d) \
|
|||
uptr v; \
|
||||
a &= 0x00fffffe; \
|
||||
v = map[a >> M68K_MEM_SHIFT]; \
|
||||
if (v & 0x80000000) \
|
||||
if (map_flag_set(v)) \
|
||||
((cpu68k_write_f *)(v << 1))(a, d); \
|
||||
else \
|
||||
*(u16 *)((v << 1) + a) = d; \
|
||||
|
@ -107,7 +116,7 @@ void name(u32 a, u32 d) \
|
|||
a &= 0x00fffffe; \
|
||||
v = map[a >> M68K_MEM_SHIFT]; \
|
||||
vs = v << 1; \
|
||||
if (v & 0x80000000) { \
|
||||
if (map_flag_set(v)) { \
|
||||
((cpu68k_write_f *)vs)(a, d >> 16); \
|
||||
((cpu68k_write_f *)vs)(a + 2, d); \
|
||||
} \
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue