notaz.gp2x.de
/
libpicofe.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
menu: support seeking the filelist with letter keys
[libpicofe.git]
/
common
/
emu.h
diff --git
a/common/emu.h
b/common/emu.h
index
f08d12a
..
75a5abe
100644
(file)
--- a/
common/emu.h
+++ b/
common/emu.h
@@
-9,6
+9,8
@@
extern "C" {
#endif
extern "C" {
#endif
+#define array_size(x) (sizeof(x) / sizeof(x[0]))
+
extern void *g_screen_ptr;
#if SCREEN_SIZE_FIXED
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_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_RAM_TIMINGS (1<<8)
-#define EOPT_CONFIRM_SAVE (1<<9)
#define EOPT_EN_CD_LEDS (1<<10)
#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)
#define EOPT_A_SN_GAMMA (1<<12)
#define EOPT_VSYNC (1<<13)
#define EOPT_GIZ_SCANLN (1<<14)
@@
-39,12
+39,19
@@
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_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,
enum {
EOPT_SCALE_NONE = 0,
- EOPT_SCALE_SW_H,
- EOPT_SCALE_HW_H,
- EOPT_SCALE_HW_HV,
+ EOPT_SCALE_SW,
+ EOPT_SCALE_HW,
+};
+
+enum {
+ EOPT_CONFIRM_NONE = 0,
+ EOPT_CONFIRM_SAVE = 1,
+ EOPT_CONFIRM_LOAD = 2,
+ EOPT_CONFIRM_BOTH = 3,
};
typedef struct _currentConfig_t {
};
typedef struct _currentConfig_t {
@@
-55,15
+62,21
@@
typedef struct _currentConfig_t {
int s_PicoAutoRgnOrder;
int s_PicoCDBuffers;
int Frameskip;
int s_PicoAutoRgnOrder;
int s_PicoCDBuffers;
int Frameskip;
+ int confirm_save;
int CPUclock;
int volume;
int gamma;
int CPUclock;
int volume;
int gamma;
- int scaling; // gp2x: 0=center, 1=hscale, 2=hvscale, 3=hsoftscale; psp: bilinear filtering
+ int scaling; // gp2x: EOPT_SCALE_*; psp: bilinear filtering
+ int vscaling;
int rotation; // for UIQ
float scale; // psp: screen scale
float hscale32, hscale40; // psp: horizontal scale
int gamma2; // psp: black level
int turbo_rate;
int rotation; // for UIQ
float scale; // psp: screen scale
float hscale32, hscale40; // psp: horizontal scale
int gamma2; // psp: black level
int turbo_rate;
+ int renderer;
+ int renderer32x;
+ int filter; // pandora
+ int analog_deadzone;
} currentConfig_t;
extern currentConfig_t currentConfig, defaultConfig;
} currentConfig_t;
extern currentConfig_t currentConfig, defaultConfig;
@@
-97,6
+110,13
@@
enum TPicoGameState {
PGS_SuspendWake, /* PSP */
};
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);
void emu_init(void);
void emu_finish(void);
@@
-107,13
+127,13
@@
int emu_swap_cd(const char *fname);
int emu_save_load_game(int load, int sram);
void emu_reset_game(void);
int emu_save_load_game(int load, int sram);
void emu_reset_game(void);
+void emu_prep_defconfig(void);
void emu_set_defconfig(void);
void emu_set_defconfig(void);
-int emu_read_config(
int g
ame, int no_defaults);
+int emu_read_config(
const char *rom_fn
ame, int no_defaults);
int emu_write_config(int game);
char *emu_get_save_fname(int load, int is_sram, int slot);
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);
+int emu_check_save_file(int slot, int *time);
void emu_text_out8 (int x, int y, const char *text);
void emu_text_out16(int x, int y, const char *text);
void emu_text_out8 (int x, int y, const char *text);
void emu_text_out16(int x, int y, const char *text);
@@
-126,6
+146,9
@@
void emu_get_game_name(char *str150);
void emu_set_fastforward(int set_on);
void emu_status_msg(const char *format, ...);
void emu_set_fastforward(int set_on);
void emu_status_msg(const char *format, ...);
+/* used by some (but not all) platforms */
+void emu_cmn_forced_frame(int no_scale, int do_emu);
+
#ifdef __cplusplus
} // extern "C"
#endif
#ifdef __cplusplus
} // extern "C"
#endif