can compile
This commit is contained in:
parent
365077772d
commit
8f9b841f72
4
Makefile
4
Makefile
|
@ -4,7 +4,7 @@ CC = gcc
|
||||||
AR = psp-ar
|
AR = psp-ar
|
||||||
STATIC_LINKING = 0
|
STATIC_LINKING = 0
|
||||||
|
|
||||||
CFLAGS += -fPIC
|
CFLAGS += -fPIC -Werror-implicit-function-declaration
|
||||||
CFLAGS += -DPC_BUILD -Wall -m32
|
CFLAGS += -DPC_BUILD -Wall -m32
|
||||||
CFLAGS += -D__LIBRETRO__
|
CFLAGS += -D__LIBRETRO__
|
||||||
|
|
||||||
|
@ -26,7 +26,7 @@ OBJS += input.o
|
||||||
OBJS += sound.o
|
OBJS += sound.o
|
||||||
OBJS += cpu_threaded.o
|
OBJS += cpu_threaded.o
|
||||||
|
|
||||||
OBJS += x86_stub.o
|
OBJS += x86/x86_stub.o
|
||||||
OBJS += cheats.o
|
OBJS += cheats.o
|
||||||
OBJS += zip.o
|
OBJS += zip.o
|
||||||
|
|
||||||
|
|
10
common.h
10
common.h
|
@ -103,8 +103,16 @@
|
||||||
|
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
#else
|
||||||
|
#ifdef __LIBRETRO__
|
||||||
|
|
||||||
|
#define GBA_SCREEN_WIDTH (240)
|
||||||
|
#define GBA_SCREEN_HEIGHT (160)
|
||||||
|
#define GBA_SCREEN_PITCH (240)
|
||||||
|
|
||||||
#else
|
#else
|
||||||
#include "SDL.h"
|
#include "SDL.h"
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef ARM_ARCH
|
#ifdef ARM_ARCH
|
||||||
#define function_cc
|
#define function_cc
|
||||||
|
@ -210,7 +218,9 @@ typedef u32 fixed8_24;
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
#ifndef __LIBRETRO__
|
||||||
#include "SDL.h"
|
#include "SDL.h"
|
||||||
|
#endif
|
||||||
#include "cpu.h"
|
#include "cpu.h"
|
||||||
#include "memory.h"
|
#include "memory.h"
|
||||||
#include "video.h"
|
#include "video.h"
|
||||||
|
|
4
cpu.c
4
cpu.c
|
@ -4146,8 +4146,10 @@ void function_cc step_debug(u32 pc, u32 cycles)
|
||||||
{
|
{
|
||||||
u32 key = 0;
|
u32 key = 0;
|
||||||
|
|
||||||
|
#ifndef __LIBRETRO__
|
||||||
SDL_LockMutex(sound_mutex);
|
SDL_LockMutex(sound_mutex);
|
||||||
SDL_PauseAudio(1);
|
SDL_PauseAudio(1);
|
||||||
|
#endif
|
||||||
|
|
||||||
if(output_field >= num_output_fields)
|
if(output_field >= num_output_fields)
|
||||||
{
|
{
|
||||||
|
@ -4281,8 +4283,10 @@ void function_cc step_debug(u32 pc, u32 cycles)
|
||||||
quit();
|
quit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifndef __LIBRETRO__
|
||||||
SDL_PauseAudio(0);
|
SDL_PauseAudio(0);
|
||||||
SDL_UnlockMutex(sound_mutex);
|
SDL_UnlockMutex(sound_mutex);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
last_instruction = reg[REG_PC];
|
last_instruction = reg[REG_PC];
|
||||||
|
|
5
input.c
5
input.c
|
@ -343,10 +343,11 @@ void init_input()
|
||||||
sceCtrlSetSamplingMode(PSP_CTRL_MODE_ANALOG);
|
sceCtrlSetSamplingMode(PSP_CTRL_MODE_ANALOG);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif
|
#elif defined(__LIBRETRO__)
|
||||||
|
|
||||||
|
/* todo */
|
||||||
|
|
||||||
#if defined(PC_BUILD)
|
#elif defined(PC_BUILD)
|
||||||
|
|
||||||
u32 key_map(SDLKey key_sym)
|
u32 key_map(SDLKey key_sym)
|
||||||
{
|
{
|
||||||
|
|
62
libretro.c
62
libretro.c
|
@ -5,6 +5,11 @@
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
#include "libco.h"
|
#include "libco.h"
|
||||||
|
#include "libretro.h"
|
||||||
|
|
||||||
|
#ifndef MAX_PATH
|
||||||
|
#define MAX_PATH (512)
|
||||||
|
#endif
|
||||||
|
|
||||||
static retro_log_printf_t log_cb;
|
static retro_log_printf_t log_cb;
|
||||||
static retro_video_refresh_t video_cb;
|
static retro_video_refresh_t video_cb;
|
||||||
|
@ -28,7 +33,7 @@ static inline void switch_to_cpu_thread(void)
|
||||||
|
|
||||||
static void cpu_thread_entry(void)
|
static void cpu_thread_entry(void)
|
||||||
{
|
{
|
||||||
execute_arm_translate(reg[EXECUTE_CYCLES]);
|
execute_arm_translate(execute_cycles);
|
||||||
}
|
}
|
||||||
|
|
||||||
static inline void init_context_switch(void)
|
static inline void init_context_switch(void)
|
||||||
|
@ -42,6 +47,26 @@ static inline void deinit_context_switch(void)
|
||||||
co_delete(cpu_thread);
|
co_delete(cpu_thread);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef PERF_TEST
|
||||||
|
|
||||||
|
extern struct retro_perf_callback perf_cb;
|
||||||
|
|
||||||
|
#define RETRO_PERFORMANCE_INIT(X) \
|
||||||
|
static struct retro_perf_counter X = {#X}; \
|
||||||
|
do { \
|
||||||
|
if (!(X).registered) \
|
||||||
|
perf_cb.perf_register(&(X)); \
|
||||||
|
} while(0)
|
||||||
|
|
||||||
|
#define RETRO_PERFORMANCE_START(X) perf_cb.perf_start(&(X))
|
||||||
|
#define RETRO_PERFORMANCE_STOP(X) perf_cb.perf_stop(&(X))
|
||||||
|
#else
|
||||||
|
#define RETRO_PERFORMANCE_INIT(X)
|
||||||
|
#define RETRO_PERFORMANCE_START(X)
|
||||||
|
#define RETRO_PERFORMANCE_STOP(X)
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
void retro_get_system_info(struct retro_system_info *info)
|
void retro_get_system_info(struct retro_system_info *info)
|
||||||
{
|
{
|
||||||
info->library_name = "TempGBA";
|
info->library_name = "TempGBA";
|
||||||
|
@ -59,8 +84,8 @@ void retro_get_system_av_info(struct retro_system_av_info *info)
|
||||||
info->geometry.max_width = GBA_SCREEN_WIDTH;
|
info->geometry.max_width = GBA_SCREEN_WIDTH;
|
||||||
info->geometry.max_height = GBA_SCREEN_HEIGHT;
|
info->geometry.max_height = GBA_SCREEN_HEIGHT;
|
||||||
info->geometry.aspect_ratio = 0;
|
info->geometry.aspect_ratio = 0;
|
||||||
info->timing.fps = ((float) CPU_FREQUENCY) / (308 * 228 * 4); // 59.72750057 hz
|
info->timing.fps = ((float) (16* 1024 * 1024)) / (308 * 228 * 4); // 59.72750057 hz
|
||||||
info->timing.sample_rate = SOUND_FREQUENCY;
|
info->timing.sample_rate = 44100;
|
||||||
// info->timing.sample_rate = 32 * 1024;
|
// info->timing.sample_rate = 32 * 1024;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -68,13 +93,13 @@ void retro_get_system_av_info(struct retro_system_av_info *info)
|
||||||
void retro_init()
|
void retro_init()
|
||||||
{
|
{
|
||||||
init_gamepak_buffer();
|
init_gamepak_buffer();
|
||||||
init_sound();
|
init_sound(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void retro_deinit()
|
void retro_deinit()
|
||||||
{
|
{
|
||||||
perf_cb.perf_log();
|
perf_cb.perf_log();
|
||||||
quit_gba();
|
memory_term();
|
||||||
}
|
}
|
||||||
|
|
||||||
void retro_set_environment(retro_environment_t cb)
|
void retro_set_environment(retro_environment_t cb)
|
||||||
|
@ -110,27 +135,28 @@ void retro_reset()
|
||||||
|
|
||||||
size_t retro_serialize_size()
|
size_t retro_serialize_size()
|
||||||
{
|
{
|
||||||
return SAVESTATE_SIZE;
|
// return SAVESTATE_SIZE;
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool retro_serialize(void *data, size_t size)
|
bool retro_serialize(void *data, size_t size)
|
||||||
{
|
{
|
||||||
if (size < SAVESTATE_SIZE)
|
// if (size < SAVESTATE_SIZE)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
gba_save_state(data);
|
// gba_save_state(data);
|
||||||
|
|
||||||
return true;
|
// return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool retro_unserialize(const void *data, size_t size)
|
bool retro_unserialize(const void *data, size_t size)
|
||||||
{
|
{
|
||||||
if (size < SAVESTATE_SIZE)
|
// if (size < SAVESTATE_SIZE)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
gba_load_state(data);
|
// gba_load_state(data);
|
||||||
|
|
||||||
return true;
|
// return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void retro_cheat_reset() {}
|
void retro_cheat_reset() {}
|
||||||
|
@ -184,12 +210,12 @@ bool retro_load_game(const struct retro_game_info *info)
|
||||||
strncat(filename_bios, "/gba_bios.bin",sizeof(filename_bios));
|
strncat(filename_bios, "/gba_bios.bin",sizeof(filename_bios));
|
||||||
|
|
||||||
|
|
||||||
if (environ_cb(RETRO_ENVIRONMENT_GET_SAVE_DIRECTORY, &dir) && dir)
|
// if (environ_cb(RETRO_ENVIRONMENT_GET_SAVE_DIRECTORY, &dir) && dir)
|
||||||
strncpy(dir_save, dir, sizeof(dir_save));
|
// strncpy(dir_save, dir, sizeof(dir_save));
|
||||||
else
|
// else
|
||||||
strncpy(dir_save, main_path, sizeof(dir_save));
|
// strncpy(dir_save, main_path, sizeof(dir_save));
|
||||||
|
|
||||||
strncat(dir_save, "/",sizeof(dir_save));
|
// strncat(dir_save, "/",sizeof(dir_save));
|
||||||
|
|
||||||
strncat(main_path, "/",sizeof(main_path));
|
strncat(main_path, "/",sizeof(main_path));
|
||||||
|
|
||||||
|
@ -281,7 +307,7 @@ void retro_run()
|
||||||
|
|
||||||
render_audio();
|
render_audio();
|
||||||
|
|
||||||
video_cb(GBA_FRAME_TEXTURE, GBA_SCREEN_WIDTH, GBA_SCREEN_HEIGHT, 512);
|
video_cb(gba_screen_pixels, GBA_SCREEN_WIDTH, GBA_SCREEN_HEIGHT, GBA_SCREEN_PITCH * 2);
|
||||||
|
|
||||||
if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE_UPDATE, &updated) && updated)
|
if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE_UPDATE, &updated) && updated)
|
||||||
check_variables();
|
check_variables();
|
||||||
|
|
13
main.c
13
main.c
|
@ -18,6 +18,7 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
|
#include <ctype.h>
|
||||||
|
|
||||||
#ifdef PSP_BUILD
|
#ifdef PSP_BUILD
|
||||||
|
|
||||||
|
@ -773,6 +774,8 @@ void synchronize()
|
||||||
*/
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#elif defined(__LIBRETRO__)
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
u32 real_frame_count = 0;
|
u32 real_frame_count = 0;
|
||||||
|
@ -870,6 +873,8 @@ void quit()
|
||||||
|
|
||||||
sound_exit();
|
sound_exit();
|
||||||
|
|
||||||
|
#ifndef __LIBRETRO__
|
||||||
|
|
||||||
#ifdef REGISTER_USAGE_ANALYZE
|
#ifdef REGISTER_USAGE_ANALYZE
|
||||||
print_register_usage();
|
print_register_usage();
|
||||||
#endif
|
#endif
|
||||||
|
@ -885,6 +890,8 @@ void quit()
|
||||||
|
|
||||||
exit(0);
|
exit(0);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void reset_gba()
|
void reset_gba()
|
||||||
|
@ -919,7 +926,7 @@ void get_ticks_us(u64 *tick_return)
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
u32 file_length(char *dummy, FILE *fp)
|
u32 file_length(const char *dummy, FILE *fp)
|
||||||
{
|
{
|
||||||
u32 length;
|
u32 length;
|
||||||
|
|
||||||
|
@ -930,7 +937,9 @@ u32 file_length(char *dummy, FILE *fp)
|
||||||
return length;
|
return length;
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef PC_BUILD
|
#ifdef __LIBRETRO__
|
||||||
|
|
||||||
|
#elif defined(PC_BUILD)
|
||||||
|
|
||||||
void delay_us(u32 us_count)
|
void delay_us(u32 us_count)
|
||||||
{
|
{
|
||||||
|
|
6
main.h
6
main.h
|
@ -90,7 +90,11 @@ extern u32 clock_speed;
|
||||||
|
|
||||||
u32 update_gba();
|
u32 update_gba();
|
||||||
void reset_gba();
|
void reset_gba();
|
||||||
|
#ifdef __LIBRETRO__
|
||||||
|
#define synchronize()
|
||||||
|
#else
|
||||||
void synchronize();
|
void synchronize();
|
||||||
|
#endif
|
||||||
void quit();
|
void quit();
|
||||||
void delay_us(u32 us_count);
|
void delay_us(u32 us_count);
|
||||||
void get_ticks_us(u64 *tick_return);
|
void get_ticks_us(u64 *tick_return);
|
||||||
|
@ -105,7 +109,7 @@ u32 file_length(char *filename, s32 dummy);
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
u32 file_length(char *dummy, FILE *fp);
|
u32 file_length(const char *dummy, FILE *fp);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
24
memory.c
24
memory.c
|
@ -2115,7 +2115,7 @@ s32 load_game_config(char *gamepak_title, char *gamepak_code, char *gamepak_make
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
s32 load_gamepak_raw(char *name)
|
s32 load_gamepak_raw(const char *name)
|
||||||
{
|
{
|
||||||
file_open(gamepak_file, name, read);
|
file_open(gamepak_file, name, read);
|
||||||
|
|
||||||
|
@ -2160,7 +2160,7 @@ char gamepak_code[5];
|
||||||
char gamepak_maker[3];
|
char gamepak_maker[3];
|
||||||
char gamepak_filename[512];
|
char gamepak_filename[512];
|
||||||
|
|
||||||
u32 load_gamepak(char *name)
|
u32 load_gamepak(const char *name)
|
||||||
{
|
{
|
||||||
char *dot_position = strrchr(name, '.');
|
char *dot_position = strrchr(name, '.');
|
||||||
s32 file_size;
|
s32 file_size;
|
||||||
|
@ -3119,6 +3119,26 @@ void init_memory()
|
||||||
bios_read_protect = 0xe129f000;
|
bios_read_protect = 0xe129f000;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void memory_term(void)
|
||||||
|
{
|
||||||
|
if (file_check_valid(gamepak_file_large))
|
||||||
|
{
|
||||||
|
file_close(gamepak_file_large);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gamepak_memory_map != NULL)
|
||||||
|
{
|
||||||
|
free(gamepak_memory_map);
|
||||||
|
gamepak_memory_map = NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gamepak_rom != NULL)
|
||||||
|
{
|
||||||
|
free(gamepak_rom);
|
||||||
|
gamepak_rom = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void bios_region_read_allow()
|
void bios_region_read_allow()
|
||||||
{
|
{
|
||||||
memory_map_read[0] = bios_rom;
|
memory_map_read[0] = bios_rom;
|
||||||
|
|
3
memory.h
3
memory.h
|
@ -175,13 +175,14 @@ extern char gamepak_filename[512];
|
||||||
|
|
||||||
cpu_alert_type dma_transfer(dma_transfer_type *dma);
|
cpu_alert_type dma_transfer(dma_transfer_type *dma);
|
||||||
u8 *memory_region(u32 address, u32 *memory_limit);
|
u8 *memory_region(u32 address, u32 *memory_limit);
|
||||||
u32 load_gamepak(char *name);
|
u32 load_gamepak(const char *name);
|
||||||
u32 load_backup(char *name);
|
u32 load_backup(char *name);
|
||||||
s32 load_bios(char *name);
|
s32 load_bios(char *name);
|
||||||
void update_backup();
|
void update_backup();
|
||||||
void update_backup_force();
|
void update_backup_force();
|
||||||
void init_memory();
|
void init_memory();
|
||||||
void init_gamepak_buffer();
|
void init_gamepak_buffer();
|
||||||
|
void memory_term(void);
|
||||||
void bios_region_read_allow();
|
void bios_region_read_allow();
|
||||||
void bios_region_read_protect();
|
void bios_region_read_protect();
|
||||||
u8 *load_gamepak_page(u32 physical_index);
|
u8 *load_gamepak_page(u32 physical_index);
|
||||||
|
|
51
sound.c
51
sound.c
|
@ -19,7 +19,9 @@
|
||||||
|
|
||||||
|
|
||||||
#include "common.h"
|
#include "common.h"
|
||||||
|
#ifndef __LIBRETRO__
|
||||||
#include <SDL.h>
|
#include <SDL.h>
|
||||||
|
#endif
|
||||||
u32 global_enable_audio = 1;
|
u32 global_enable_audio = 1;
|
||||||
|
|
||||||
direct_sound_struct direct_sound_channel[2];
|
direct_sound_struct direct_sound_channel[2];
|
||||||
|
@ -27,8 +29,10 @@ gbc_sound_struct gbc_sound_channel[4];
|
||||||
|
|
||||||
u32 sound_frequency = 44100;
|
u32 sound_frequency = 44100;
|
||||||
|
|
||||||
|
#ifndef __LIBRETRO__
|
||||||
SDL_mutex *sound_mutex;
|
SDL_mutex *sound_mutex;
|
||||||
static SDL_cond *sound_cv;
|
static SDL_cond *sound_cv;
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef PSP_BUILD
|
#ifdef PSP_BUILD
|
||||||
u32 audio_buffer_size_number = 1;
|
u32 audio_buffer_size_number = 1;
|
||||||
|
@ -44,7 +48,9 @@ static u32 sound_buffer_base;
|
||||||
static u32 sound_last_cpu_ticks;
|
static u32 sound_last_cpu_ticks;
|
||||||
static fixed16_16 gbc_sound_tick_step;
|
static fixed16_16 gbc_sound_tick_step;
|
||||||
|
|
||||||
|
#ifndef __LIBRETRO__
|
||||||
static u32 sound_exit_flag;
|
static u32 sound_exit_flag;
|
||||||
|
#endif
|
||||||
|
|
||||||
// Queue 1, 2, or 4 samples to the top of the DS FIFO, wrap around circularly
|
// Queue 1, 2, or 4 samples to the top of the DS FIFO, wrap around circularly
|
||||||
|
|
||||||
|
@ -447,6 +453,7 @@ void update_gbc_sound(u32 cpu_ticks)
|
||||||
gbc_sound_partial_ticks &= 0xFFFF;
|
gbc_sound_partial_ticks &= 0xFFFF;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifndef __LIBRETRO__
|
||||||
SDL_LockMutex(sound_mutex);
|
SDL_LockMutex(sound_mutex);
|
||||||
if(synchronize_flag)
|
if(synchronize_flag)
|
||||||
{
|
{
|
||||||
|
@ -487,6 +494,7 @@ void update_gbc_sound(u32 cpu_ticks)
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
if(sound_on == 1)
|
if(sound_on == 1)
|
||||||
{
|
{
|
||||||
gs = gbc_sound_channel + 0;
|
gs = gbc_sound_channel + 0;
|
||||||
|
@ -562,9 +570,11 @@ void update_gbc_sound(u32 cpu_ticks)
|
||||||
gbc_sound_buffer_index =
|
gbc_sound_buffer_index =
|
||||||
(gbc_sound_buffer_index + (buffer_ticks * 2)) % BUFFER_SIZE;
|
(gbc_sound_buffer_index + (buffer_ticks * 2)) % BUFFER_SIZE;
|
||||||
|
|
||||||
|
#ifndef __LIBRETRO__
|
||||||
SDL_UnlockMutex(sound_mutex);
|
SDL_UnlockMutex(sound_mutex);
|
||||||
|
|
||||||
SDL_CondSignal(sound_cv);
|
SDL_CondSignal(sound_cv);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#define sound_copy_normal() \
|
#define sound_copy_normal() \
|
||||||
|
@ -595,7 +605,7 @@ void update_gbc_sound(u32 cpu_ticks)
|
||||||
} \
|
} \
|
||||||
|
|
||||||
|
|
||||||
void sound_callback(void *userdata, Uint8 *stream, int length)
|
void sound_callback(void *userdata, u8 *stream, int length)
|
||||||
{
|
{
|
||||||
u32 sample_length = length / 2;
|
u32 sample_length = length / 2;
|
||||||
u32 _length;
|
u32 _length;
|
||||||
|
@ -604,6 +614,7 @@ void sound_callback(void *userdata, Uint8 *stream, int length)
|
||||||
s16 *source;
|
s16 *source;
|
||||||
s32 current_sample;
|
s32 current_sample;
|
||||||
|
|
||||||
|
#ifndef __LIBRETRO__
|
||||||
SDL_LockMutex(sound_mutex);
|
SDL_LockMutex(sound_mutex);
|
||||||
|
|
||||||
while(((gbc_sound_buffer_index - sound_buffer_base) % BUFFER_SIZE) <
|
while(((gbc_sound_buffer_index - sound_buffer_base) % BUFFER_SIZE) <
|
||||||
|
@ -611,6 +622,7 @@ void sound_callback(void *userdata, Uint8 *stream, int length)
|
||||||
{
|
{
|
||||||
SDL_CondWait(sound_cv, sound_mutex);
|
SDL_CondWait(sound_cv, sound_mutex);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
if(global_enable_audio)
|
if(global_enable_audio)
|
||||||
{
|
{
|
||||||
|
@ -645,9 +657,11 @@ void sound_callback(void *userdata, Uint8 *stream, int length)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifndef __LIBRETRO__
|
||||||
SDL_CondSignal(sound_cv);
|
SDL_CondSignal(sound_cv);
|
||||||
|
|
||||||
SDL_UnlockMutex(sound_mutex);
|
SDL_UnlockMutex(sound_mutex);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
// Special thanks to blarrg for the LSFR frequency used in Meridian, as posted
|
// Special thanks to blarrg for the LSFR frequency used in Meridian, as posted
|
||||||
|
@ -689,7 +703,9 @@ void reset_sound()
|
||||||
gbc_sound_struct *gs = gbc_sound_channel;
|
gbc_sound_struct *gs = gbc_sound_channel;
|
||||||
u32 i;
|
u32 i;
|
||||||
|
|
||||||
|
#ifndef __LIBRETRO__
|
||||||
SDL_LockMutex(sound_mutex);
|
SDL_LockMutex(sound_mutex);
|
||||||
|
#endif
|
||||||
|
|
||||||
sound_on = 0;
|
sound_on = 0;
|
||||||
sound_buffer_base = 0;
|
sound_buffer_base = 0;
|
||||||
|
@ -723,13 +739,16 @@ void reset_sound()
|
||||||
gs->active_flag = 0;
|
gs->active_flag = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifndef __LIBRETRO__
|
||||||
SDL_UnlockMutex(sound_mutex);
|
SDL_UnlockMutex(sound_mutex);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void sound_exit()
|
void sound_exit()
|
||||||
{
|
{
|
||||||
gbc_sound_buffer_index =
|
gbc_sound_buffer_index =
|
||||||
(sound_buffer_base + audio_buffer_size) % BUFFER_SIZE;
|
(sound_buffer_base + audio_buffer_size) % BUFFER_SIZE;
|
||||||
|
#ifndef __LIBRETRO__
|
||||||
SDL_PauseAudio(1);
|
SDL_PauseAudio(1);
|
||||||
sound_exit_flag = 1;
|
sound_exit_flag = 1;
|
||||||
SDL_CondSignal(sound_cv);
|
SDL_CondSignal(sound_cv);
|
||||||
|
@ -739,10 +758,12 @@ void sound_exit()
|
||||||
sound_mutex = NULL;
|
sound_mutex = NULL;
|
||||||
SDL_DestroyCond(sound_cv);
|
SDL_DestroyCond(sound_cv);
|
||||||
sound_cv = NULL;
|
sound_cv = NULL;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
void init_sound(int need_reset)
|
void init_sound(int need_reset)
|
||||||
{
|
{
|
||||||
|
#ifndef __LIBRETRO__
|
||||||
SDL_AudioSpec sound_settings;
|
SDL_AudioSpec sound_settings;
|
||||||
|
|
||||||
sound_exit_flag = 0;
|
sound_exit_flag = 0;
|
||||||
|
@ -777,6 +798,8 @@ void init_sound(int need_reset)
|
||||||
audio_buffer_size_number++;
|
audio_buffer_size_number++;
|
||||||
#ifndef PSP_BUILD
|
#ifndef PSP_BUILD
|
||||||
printf("audio: freq %d, size %d\n", sound_frequency, audio_buffer_size);
|
printf("audio: freq %d, size %d\n", sound_frequency, audio_buffer_size);
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
gbc_sound_tick_step =
|
gbc_sound_tick_step =
|
||||||
|
@ -788,7 +811,9 @@ void init_sound(int need_reset)
|
||||||
if (need_reset)
|
if (need_reset)
|
||||||
reset_sound();
|
reset_sound();
|
||||||
|
|
||||||
|
#ifndef __LIBRETRO__
|
||||||
SDL_PauseAudio(0);
|
SDL_PauseAudio(0);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
#define sound_savestate_builder(type) \
|
#define sound_savestate_builder(type) \
|
||||||
|
@ -811,3 +836,27 @@ void sound_##type##_savestate(file_tag_type savestate_file) \
|
||||||
sound_savestate_builder(read);
|
sound_savestate_builder(read);
|
||||||
sound_savestate_builder(write_mem);
|
sound_savestate_builder(write_mem);
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef __LIBRETRO__
|
||||||
|
#include "libretro.h"
|
||||||
|
|
||||||
|
static retro_audio_sample_batch_t audio_batch_cb;
|
||||||
|
void retro_set_audio_sample(retro_audio_sample_t cb) { }
|
||||||
|
void retro_set_audio_sample_batch(retro_audio_sample_batch_t cb) { audio_batch_cb = cb; }
|
||||||
|
|
||||||
|
void render_audio(void)
|
||||||
|
{
|
||||||
|
static s16 stream_base[1024];
|
||||||
|
u32 _length;
|
||||||
|
s16 *source;
|
||||||
|
u32 i;
|
||||||
|
s32 current_sample;
|
||||||
|
|
||||||
|
while (((gbc_sound_buffer_index - sound_buffer_base) % BUFFER_SIZE) > 512) {
|
||||||
|
sound_copy(sound_buffer_base, 512, normal);
|
||||||
|
audio_batch_cb(stream_base, 256);
|
||||||
|
sound_buffer_base += 512;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
111
sound.h
111
sound.h
|
@ -25,79 +25,79 @@
|
||||||
#define GBA_XTAL 16777216.0f
|
#define GBA_XTAL 16777216.0f
|
||||||
#define GBA_60HZ_RATE 16853760.0f /* 228*(272+960)*60 */
|
#define GBA_60HZ_RATE 16853760.0f /* 228*(272+960)*60 */
|
||||||
|
|
||||||
#if !defined(PSP_BUILD)
|
#if !defined(PSP_BUILD) && !defined(__LIBRETRO__)
|
||||||
// run GBA at 60Hz (~0.5% faster) to better match host display
|
// run GBA at 60Hz (~0.5% faster) to better match host display
|
||||||
#define GBC_BASE_RATE GBA_60HZ_RATE
|
#define GBC_BASE_RATE GBA_60HZ_RATE
|
||||||
#else
|
#else
|
||||||
#define GBC_BASE_RATE GBA_XTAL
|
#define GBC_BASE_RATE GBA_XTAL
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
DIRECT_SOUND_INACTIVE,
|
DIRECT_SOUND_INACTIVE,
|
||||||
DIRECT_SOUND_RIGHT,
|
DIRECT_SOUND_RIGHT,
|
||||||
DIRECT_SOUND_LEFT,
|
DIRECT_SOUND_LEFT,
|
||||||
DIRECT_SOUND_LEFTRIGHT
|
DIRECT_SOUND_LEFTRIGHT
|
||||||
} direct_sound_status_type;
|
} direct_sound_status_type;
|
||||||
|
|
||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
DIRECT_SOUND_VOLUME_50,
|
DIRECT_SOUND_VOLUME_50,
|
||||||
DIRECT_SOUND_VOLUME_100
|
DIRECT_SOUND_VOLUME_100
|
||||||
} direct_sound_volume_type;
|
} direct_sound_volume_type;
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
s8 fifo[32];
|
s8 fifo[32];
|
||||||
u32 fifo_base;
|
u32 fifo_base;
|
||||||
u32 fifo_top;
|
u32 fifo_top;
|
||||||
fixed8_24 fifo_fractional;
|
fixed8_24 fifo_fractional;
|
||||||
// The + 1 is to give some extra room for linear interpolation
|
// The + 1 is to give some extra room for linear interpolation
|
||||||
// when wrapping around.
|
// when wrapping around.
|
||||||
u32 buffer_index;
|
u32 buffer_index;
|
||||||
direct_sound_status_type status;
|
direct_sound_status_type status;
|
||||||
direct_sound_volume_type volume;
|
direct_sound_volume_type volume;
|
||||||
u32 last_cpu_ticks;
|
u32 last_cpu_ticks;
|
||||||
} direct_sound_struct;
|
} direct_sound_struct;
|
||||||
|
|
||||||
typedef enum
|
typedef enum
|
||||||
{
|
{
|
||||||
GBC_SOUND_INACTIVE,
|
GBC_SOUND_INACTIVE,
|
||||||
GBC_SOUND_RIGHT,
|
GBC_SOUND_RIGHT,
|
||||||
GBC_SOUND_LEFT,
|
GBC_SOUND_LEFT,
|
||||||
GBC_SOUND_LEFTRIGHT
|
GBC_SOUND_LEFTRIGHT
|
||||||
} gbc_sound_status_type;
|
} gbc_sound_status_type;
|
||||||
|
|
||||||
|
|
||||||
typedef struct
|
typedef struct
|
||||||
{
|
{
|
||||||
u32 rate;
|
u32 rate;
|
||||||
fixed16_16 frequency_step;
|
fixed16_16 frequency_step;
|
||||||
fixed16_16 sample_index;
|
fixed16_16 sample_index;
|
||||||
fixed16_16 tick_counter;
|
fixed16_16 tick_counter;
|
||||||
u32 total_volume;
|
u32 total_volume;
|
||||||
u32 envelope_initial_volume;
|
u32 envelope_initial_volume;
|
||||||
u32 envelope_volume;
|
u32 envelope_volume;
|
||||||
u32 envelope_direction;
|
u32 envelope_direction;
|
||||||
u32 envelope_status;
|
u32 envelope_status;
|
||||||
u32 envelope_step;
|
u32 envelope_step;
|
||||||
u32 envelope_ticks;
|
u32 envelope_ticks;
|
||||||
u32 envelope_initial_ticks;
|
u32 envelope_initial_ticks;
|
||||||
u32 sweep_status;
|
u32 sweep_status;
|
||||||
u32 sweep_direction;
|
u32 sweep_direction;
|
||||||
u32 sweep_ticks;
|
u32 sweep_ticks;
|
||||||
u32 sweep_initial_ticks;
|
u32 sweep_initial_ticks;
|
||||||
u32 sweep_shift;
|
u32 sweep_shift;
|
||||||
u32 length_status;
|
u32 length_status;
|
||||||
u32 length_ticks;
|
u32 length_ticks;
|
||||||
u32 noise_type;
|
u32 noise_type;
|
||||||
u32 wave_type;
|
u32 wave_type;
|
||||||
u32 wave_bank;
|
u32 wave_bank;
|
||||||
u32 wave_volume;
|
u32 wave_volume;
|
||||||
gbc_sound_status_type status;
|
gbc_sound_status_type status;
|
||||||
u32 active_flag;
|
u32 active_flag;
|
||||||
u32 master_enable;
|
u32 master_enable;
|
||||||
s8 *sample_data;
|
s8* sample_data;
|
||||||
} gbc_sound_struct;
|
} gbc_sound_struct;
|
||||||
|
|
||||||
extern direct_sound_struct direct_sound_channel[2];
|
extern direct_sound_struct direct_sound_channel[2];
|
||||||
|
@ -116,7 +116,9 @@ extern u32 global_enable_audio;
|
||||||
extern u32 enable_low_pass_filter;
|
extern u32 enable_low_pass_filter;
|
||||||
extern u32 audio_buffer_size_number;
|
extern u32 audio_buffer_size_number;
|
||||||
|
|
||||||
extern SDL_mutex *sound_mutex;
|
#ifndef __LIBRETRO__
|
||||||
|
extern SDL_mutex* sound_mutex;
|
||||||
|
#endif
|
||||||
|
|
||||||
void sound_timer_queue8(u32 channel, u8 value);
|
void sound_timer_queue8(u32 channel, u8 value);
|
||||||
void sound_timer_queue16(u32 channel, u16 value);
|
void sound_timer_queue16(u32 channel, u16 value);
|
||||||
|
@ -128,6 +130,11 @@ void init_sound(int need_reset);
|
||||||
void sound_write_mem_savestate(file_tag_type savestate_file);
|
void sound_write_mem_savestate(file_tag_type savestate_file);
|
||||||
void sound_read_savestate(file_tag_type savestate_file);
|
void sound_read_savestate(file_tag_type savestate_file);
|
||||||
|
|
||||||
|
#ifdef __LIBRETRO__
|
||||||
|
void render_audio(void);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#ifdef IN_MEMORY_C
|
#ifdef IN_MEMORY_C
|
||||||
|
|
||||||
#define gbc_sound_tone_control_low(channel, address) \
|
#define gbc_sound_tone_control_low(channel, address) \
|
||||||
|
|
14
video.c
14
video.c
|
@ -86,8 +86,13 @@ static void Ge_Finish_Callback(int id, void *arg)
|
||||||
#define get_screen_pitch() \
|
#define get_screen_pitch() \
|
||||||
screen_pitch \
|
screen_pitch \
|
||||||
|
|
||||||
#else
|
#elif defined(__LIBRETRO__)
|
||||||
|
u16 gba_screen_pixels[GBA_SCREEN_PITCH * GBA_SCREEN_HEIGHT];
|
||||||
|
|
||||||
|
#define get_screen_pixels() gba_screen_pixels
|
||||||
|
#define get_screen_pitch() GBA_SCREEN_PITCH
|
||||||
|
|
||||||
|
#else
|
||||||
SDL_Surface *screen;
|
SDL_Surface *screen;
|
||||||
const u32 video_scale = 1;
|
const u32 video_scale = 1;
|
||||||
|
|
||||||
|
@ -96,6 +101,7 @@ const u32 video_scale = 1;
|
||||||
|
|
||||||
#define get_screen_pitch() \
|
#define get_screen_pitch() \
|
||||||
(screen->pitch / 2) \
|
(screen->pitch / 2) \
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -3303,7 +3309,7 @@ void flip_screen()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#else
|
#elif !defined(__LIBRETRO__)
|
||||||
|
|
||||||
#define integer_scale_copy_2() \
|
#define integer_scale_copy_2() \
|
||||||
current_scanline_ptr[x2] = current_pixel; \
|
current_scanline_ptr[x2] = current_pixel; \
|
||||||
|
@ -3476,7 +3482,7 @@ void init_video()
|
||||||
GE_CMD(NOP, 0);
|
GE_CMD(NOP, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
#else
|
#elif !defined(__LIBRETRO__)
|
||||||
|
|
||||||
void init_video()
|
void init_video()
|
||||||
{
|
{
|
||||||
|
@ -3593,7 +3599,7 @@ void clear_screen(u16 color)
|
||||||
sceGuSync(0, 0); */
|
sceGuSync(0, 0); */
|
||||||
}
|
}
|
||||||
|
|
||||||
#else
|
#elif !defined(__LIBRETRO__)
|
||||||
|
|
||||||
void video_resolution_large()
|
void video_resolution_large()
|
||||||
{
|
{
|
||||||
|
|
4
video.h
4
video.h
|
@ -103,4 +103,8 @@ extern video_filter_type2 screen_filter2;
|
||||||
|
|
||||||
void set_gba_resolution(video_scale_type scale);
|
void set_gba_resolution(video_scale_type scale);
|
||||||
|
|
||||||
|
#ifdef __LIBRETRO__
|
||||||
|
extern u16 gba_screen_pixels[GBA_SCREEN_PITCH * GBA_SCREEN_HEIGHT];
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
2
zip.c
2
zip.c
|
@ -43,7 +43,7 @@ struct SZIPFileHeader
|
||||||
s16 ExtraFieldLength;
|
s16 ExtraFieldLength;
|
||||||
} __attribute__((packed));
|
} __attribute__((packed));
|
||||||
|
|
||||||
u32 load_file_zip(char *filename)
|
u32 load_file_zip(const char *filename)
|
||||||
{
|
{
|
||||||
struct SZIPFileHeader data;
|
struct SZIPFileHeader data;
|
||||||
char tmp[1024];
|
char tmp[1024];
|
||||||
|
|
Loading…
Reference in New Issue