-fix input descriptors
-implement savestates
-implement sram interface
This commit is contained in:
radius 2017-10-09 12:03:51 -05:00
parent dd30b63426
commit 18b376ac5f
3 changed files with 66 additions and 19 deletions

View File

@ -1398,7 +1398,9 @@ void GB_cpu_run(GB_gameboy_t *gb)
gb->pc = 0; gb->pc = 0;
} }
gb->ime = false; gb->ime = false;
#ifdef HAVE_DEBUGGER
GB_debugger_call_hook(gb, call_addr); GB_debugger_call_hook(gb, call_addr);
#endif
} }
else if(!gb->halted && !gb->stopped) { else if(!gb->halted && !gb->stopped) {
uint8_t opcode = GB_read_memory(gb, gb->pc++); uint8_t opcode = GB_read_memory(gb, gb->pc++);

View File

@ -11,6 +11,7 @@ SOURCES_C := $(CORE_DIR)/Core/gb.c \
$(CORE_DIR)/Core/camera.c \ $(CORE_DIR)/Core/camera.c \
$(CORE_DIR)/Core/z80_cpu.c \ $(CORE_DIR)/Core/z80_cpu.c \
$(CORE_DIR)/Core/joypad.c \ $(CORE_DIR)/Core/joypad.c \
$(CORE_DIR)/Core/save_state.c \
$(CORE_DIR)/libretro/libretro.c $(CORE_DIR)/libretro/libretro.c
ifeq ($(HAVE_DEBUGGER), 1) ifeq ($(HAVE_DEBUGGER), 1)

View File

@ -6,7 +6,6 @@
#include <signal.h> #include <signal.h>
#include <stdarg.h> #include <stdarg.h>
#define AUDIO_FREQUENCY 44100 #define AUDIO_FREQUENCY 44100
#ifdef _WIN32 #ifdef _WIN32
@ -15,6 +14,8 @@
#define snprintf _snprintf #define snprintf _snprintf
#endif #endif
#define GB_INTERNAL
#include "gb.h" #include "gb.h"
#include "libretro.h" #include "libretro.h"
@ -187,7 +188,7 @@ void retro_set_environment(retro_environment_t cb)
log_cb = fallback_log; log_cb = fallback_log;
static const struct retro_controller_description controllers[] = { static const struct retro_controller_description controllers[] = {
{ "Nintendo DS", RETRO_DEVICE_SUBCLASS(RETRO_DEVICE_JOYPAD, 0) }, { "Nintendo Gameboy", RETRO_DEVICE_SUBCLASS(RETRO_DEVICE_JOYPAD, 0) },
}; };
static const struct retro_controller_info ports[] = { static const struct retro_controller_info ports[] = {
@ -250,6 +251,10 @@ bool retro_load_game(const struct retro_game_info *info)
{ 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_UP, "Up" }, { 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_UP, "Up" },
{ 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_DOWN, "Down" }, { 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_DOWN, "Down" },
{ 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_RIGHT, "Right" }, { 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_RIGHT, "Right" },
{ 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_B, "B" },
{ 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_A, "A" },
{ 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_SELECT, "Select" },
{ 0, RETRO_DEVICE_JOYPAD, 0, RETRO_DEVICE_ID_JOYPAD_START, "Start" },
{ 0 }, { 0 },
}; };
@ -305,12 +310,6 @@ bool retro_load_game(const struct retro_game_info *info)
size_t path_length = strlen(retro_game_path); size_t path_length = strlen(retro_game_path);
/* Configure battery */
replace_extension(retro_game_path, path_length, battery_save_path, ".sav");
GB_load_battery(&gb, battery_save_path);
printf("(%s)\n",battery_save_path);
/* Configure symbols */
#ifdef HAVE_DEBUGGER #ifdef HAVE_DEBUGGER
{ {
char TMPC[512]; char TMPC[512];
@ -346,29 +345,74 @@ bool retro_load_game_special(unsigned type, const struct retro_game_info *info,
size_t retro_serialize_size(void) size_t retro_serialize_size(void)
{ {
return GB_get_save_state_size(&gb);
}
bool retro_serialize(void *data, size_t size)
{
GB_save_state_to_buffer(&gb, (uint8_t*) data);
if (data)
return true;
else
return false; return false;
} }
bool retro_serialize(void *data_, size_t size) bool retro_unserialize(const void *data, size_t size)
{ {
if (GB_load_state_from_buffer(&gb, (uint8_t*) data, size) == 0)
return true;
else
return false; return false;
} }
bool retro_unserialize(const void *data_, size_t size) void *retro_get_memory_data(unsigned type)
{ {
return false; void* data;
switch(type)
{
case RETRO_MEMORY_SAVE_RAM:
if (gb.cartridge_type->has_battery && gb.mbc_ram_size != 0)
data = gb.mbc_ram;
else
data = NULL;
break;
case RETRO_MEMORY_RTC:
if(gb.cartridge_type->has_battery)
data = &gb.rtc_real;
else
data = NULL;
break;
default:
data = NULL;
break;
}
return data;
} }
void *retro_get_memory_data(unsigned id) size_t retro_get_memory_size(unsigned type)
{ {
(void)id; size_t size;
return NULL; switch(type)
} {
case RETRO_MEMORY_SAVE_RAM:
if (gb.cartridge_type->has_battery && gb.mbc_ram_size != 0)
size = gb.mbc_ram_size;
else
size = 0;
break;
case RETRO_MEMORY_RTC:
if(gb.cartridge_type->has_battery)
size = sizeof (gb.rtc_real);
else
size = 0;
break;
default:
size = 0;
break;
}
size_t retro_get_memory_size(unsigned id) return size;
{
(void)id;
return 0;
} }
void retro_cheat_reset(void) void retro_cheat_reset(void)