X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=blobdiff_plain;f=common%2Femu.h;h=f51907ffeb45c83c63a2f8ceea1b1dd6cb55131e;hb=0c9ae59222a6fa9af18dcc072fdfb06cfca124d6;hp=f08d12acbe2b9cc7272a5403087e12d8f73258d4;hpb=0f4090a90a3d5337db985325f38c7de7ca757847;p=libpicofe.git diff --git a/common/emu.h b/common/emu.h index f08d12a..f51907f 100644 --- a/common/emu.h +++ b/common/emu.h @@ -9,6 +9,8 @@ extern "C" { #endif +#define array_size(x) (sizeof(x) / sizeof(x[0])) + extern void *g_screen_ptr; #if SCREEN_SIZE_FIXED @@ -26,11 +28,9 @@ extern int g_screen_height; #define EOPT_GZIP_SAVES (1<<3) #define EOPT_MMUHACK (1<<4) #define EOPT_NO_AUTOSVCFG (1<<5) -#define EOPT_16BPP (1<<7) +#define EOPT_16BPP (1<<7) // depreceted for .renderer #define EOPT_RAM_TIMINGS (1<<8) -#define EOPT_CONFIRM_SAVE (1<<9) #define EOPT_EN_CD_LEDS (1<<10) -#define EOPT_CONFIRM_LOAD (1<<11) #define EOPT_A_SN_GAMMA (1<<12) #define EOPT_VSYNC (1<<13) #define EOPT_GIZ_SCANLN (1<<14) @@ -39,6 +39,7 @@ extern int g_screen_height; #define EOPT_SHOW_RTC (1<<17) #define EOPT_NO_FRMLIMIT (1<<18) #define EOPT_WIZ_TEAR_FIX (1<<19) +#define EOPT_EXT_FRMLIMIT (1<<20) // no internal frame limiter (limited by snd, etc) enum { EOPT_SCALE_NONE = 0, @@ -47,6 +48,13 @@ enum { EOPT_SCALE_HW_HV, }; +enum { + EOPT_CONFIRM_NONE = 0, + EOPT_CONFIRM_SAVE = 1, + EOPT_CONFIRM_LOAD = 2, + EOPT_CONFIRM_BOTH = 3, +}; + typedef struct _currentConfig_t { int EmuOpt; int s_PicoOpt; @@ -55,6 +63,7 @@ typedef struct _currentConfig_t { int s_PicoAutoRgnOrder; int s_PicoCDBuffers; int Frameskip; + int confirm_save; int CPUclock; int volume; int gamma; @@ -64,6 +73,8 @@ typedef struct _currentConfig_t { float hscale32, hscale40; // psp: horizontal scale int gamma2; // psp: black level int turbo_rate; + int renderer; + int renderer32x; } currentConfig_t; extern currentConfig_t currentConfig, defaultConfig; @@ -97,6 +108,13 @@ enum TPicoGameState { PGS_SuspendWake, /* PSP */ }; +// media types +enum { + PM_BAD = 0, + PM_MD_CART, /* also 32x */ + PM_MARK3, + PM_CD, +}; void emu_init(void); void emu_finish(void); @@ -107,13 +125,13 @@ int emu_swap_cd(const char *fname); int emu_save_load_game(int load, int sram); void emu_reset_game(void); +void emu_prep_defconfig(void); void emu_set_defconfig(void); -int emu_read_config(int game, int no_defaults); +int emu_read_config(const char *rom_fname, int no_defaults); int emu_write_config(int game); char *emu_get_save_fname(int load, int is_sram, int slot); int emu_check_save_file(int slot); -void emu_setSaveStateCbs(int gz); void emu_text_out8 (int x, int y, const char *text); void emu_text_out16(int x, int y, const char *text);