- in_bind_key(dev_id, kc, bindtype, mask, unbind);\r
- }\r
-}\r
-\r
-// PicoPad[] format: MXYZ SACB RLDU\r
-me_bind_action me_ctrl_actions[15] =\r
-{\r
- { "UP ", 0x0001 },\r
- { "DOWN ", 0x0002 },\r
- { "LEFT ", 0x0004 },\r
- { "RIGHT ", 0x0008 },\r
- { "A ", 0x0040 },\r
- { "B ", 0x0010 },\r
- { "C ", 0x0020 },\r
- { "A turbo", 0x4000 },\r
- { "B turbo", 0x1000 },\r
- { "C turbo", 0x2000 },\r
- { "START ", 0x0080 },\r
- { "MODE ", 0x0800 },\r
- { "X ", 0x0400 },\r
- { "Y ", 0x0200 },\r
- { "Z ", 0x0100 }\r
-};\r
-\r
-me_bind_action emuctrl_actions[] =\r
-{\r
- { "Load State ", PEV_STATE_LOAD },\r
- { "Save State ", PEV_STATE_SAVE },\r
- { "Prev Save Slot ", PEV_SSLOT_PREV },\r
- { "Next Save Slot ", PEV_SSLOT_NEXT },\r
- { "Switch Renderer ", PEV_SWITCH_RND },\r
- { "Volume Down ", PEV_VOL_DOWN },\r
- { "Volume Up ", PEV_VOL_UP },\r
- { "Fast forward ", PEV_FF },\r
- { "Enter Menu ", PEV_MENU },\r
- { "Pico Next page ", PEV_PICO_PNEXT },\r
- { "Pico Prev page ", PEV_PICO_PPREV },\r
- { "Pico Switch input", PEV_PICO_SWINP },\r
- { NULL, 0 }\r
-};\r
-\r
-static int key_config_loop_wrap(menu_id id, int keys)\r
-{\r
- switch (id) {\r
- case MA_CTRL_PLAYER1:\r
- key_config_loop(me_ctrl_actions, array_size(me_ctrl_actions), 0);\r
- break;\r
- case MA_CTRL_PLAYER2:\r
- key_config_loop(me_ctrl_actions, array_size(me_ctrl_actions), 1);\r
- break;\r
- case MA_CTRL_EMU:\r
- key_config_loop(emuctrl_actions, array_size(emuctrl_actions) - 1, -1);\r
- break;\r
- default:\r
- break;\r
- }\r
- return 0;\r
-}\r
-\r
-static const char *mgn_dev_name(menu_id id, int *offs)\r
-{\r
- const char *name = NULL;\r
- static int it = 0;\r
-\r
- if (id == MA_CTRL_DEV_FIRST)\r
- it = 0;\r
-\r
- for (; it < IN_MAX_DEVS; it++) {\r
- name = in_get_dev_name(it, 1, 1);\r
- if (name != NULL)\r
- break;\r
- }\r
-\r
- it++;\r
- return name;\r
-}\r
-\r
-static int mh_saveloadcfg(menu_id id, int keys);\r
-static const char *mgn_savecfg(menu_id id, int *offs);\r
-\r
-static menu_entry e_menu_keyconfig[] =\r
-{\r
- mee_handler_id("Player 1", MA_CTRL_PLAYER1, key_config_loop_wrap),\r
- mee_handler_id("Player 2", MA_CTRL_PLAYER2, key_config_loop_wrap),\r
- mee_handler_id("Emulator controls", MA_CTRL_EMU, key_config_loop_wrap),\r
- mee_onoff ("6 button pad", MA_OPT_6BUTTON_PAD, PicoOpt, POPT_6BTN_PAD),\r
- mee_range ("Turbo rate", MA_CTRL_TURBO_RATE, currentConfig.turbo_rate, 1, 30),\r
- mee_handler_mkname_id(MA_OPT_SAVECFG, mh_saveloadcfg, mgn_savecfg),\r
- mee_handler_id("Save cfg for loaded game", MA_OPT_SAVECFG_GAME, mh_saveloadcfg),\r
- mee_label (""),\r
- mee_label ("Input devices:"),\r
- mee_label_mk (MA_CTRL_DEV_FIRST, mgn_dev_name),\r
- mee_label_mk (MA_CTRL_DEV_NEXT, mgn_dev_name),\r
- mee_label_mk (MA_CTRL_DEV_NEXT, mgn_dev_name),\r
- mee_label_mk (MA_CTRL_DEV_NEXT, mgn_dev_name),\r
- mee_label_mk (MA_CTRL_DEV_NEXT, mgn_dev_name),\r
- mee_label_mk (MA_CTRL_DEV_NEXT, mgn_dev_name),\r
- mee_label_mk (MA_CTRL_DEV_NEXT, mgn_dev_name),\r
- mee_end,\r
-};\r
-\r
-static int menu_loop_keyconfig(menu_id id, int keys)\r
-{\r
- static int sel = 0;\r
- me_loop(e_menu_keyconfig, &sel);\r
- return 0;\r
-}\r
-\r
-// ------------ SCD options menu ------------\r
-\r
-static const char *mgn_cdopt_ra(menu_id id, int *offs)\r
-{\r
- *offs = -5;\r
- if (PicoCDBuffers <= 0)\r
- return " OFF";\r
- sprintf(static_buff, "%5iK", PicoCDBuffers * 2);\r
- return static_buff;\r
-}\r
-\r
-static int mh_cdopt_ra(menu_id id, int keys)\r
-{\r
- if (keys & PBTN_LEFT) {\r
- PicoCDBuffers >>= 1;\r
- if (PicoCDBuffers < 2)\r
- PicoCDBuffers = 0;\r
- } else {\r
- if (PicoCDBuffers <= 0)\r
- PicoCDBuffers = 1;\r
- PicoCDBuffers <<= 1;\r
- if (PicoCDBuffers > 8*1024)\r
- PicoCDBuffers = 8*1024; // 16M\r
- }\r
- return 0;\r
-}\r
-\r
-static menu_entry e_menu_cd_options[] =\r
-{\r
- mee_onoff("CD LEDs", MA_CDOPT_LEDS, currentConfig.EmuOpt, 0x0400),\r
- mee_onoff("CDDA audio", MA_CDOPT_CDDA, PicoOpt, POPT_EN_MCD_CDDA),\r
- mee_onoff("PCM audio", MA_CDOPT_PCM, PicoOpt, POPT_EN_MCD_PCM),\r
- mee_cust ("ReadAhead buffer", MA_CDOPT_READAHEAD, mh_cdopt_ra, mgn_cdopt_ra),\r
- mee_onoff("SaveRAM cart", MA_CDOPT_SAVERAM, PicoOpt, POPT_EN_MCD_RAMCART),\r
- mee_onoff("Scale/Rot. fx (slow)", MA_CDOPT_SCALEROT_CHIP, PicoOpt, POPT_EN_MCD_GFX),\r
- mee_onoff("Better sync (slow)", MA_CDOPT_BETTER_SYNC, PicoOpt, POPT_EN_MCD_PSYNC),\r
- mee_end,\r
-};\r
-\r
-static int menu_loop_cd_options(menu_id id, int keys)\r
-{\r
- static int sel = 0;\r
- me_loop(e_menu_cd_options, &sel);\r
- return 0;\r
-}\r
-\r
-// ------------ adv options menu ------------\r
-\r
-static menu_entry e_menu_adv_options[] =\r
-{\r
- mee_onoff ("SRAM/BRAM saves", MA_OPT_SRAM_STATES, currentConfig.EmuOpt, EOPT_EN_SRAM),\r
- mee_onoff ("Disable sprite limit", MA_OPT2_NO_SPRITE_LIM, PicoOpt, POPT_DIS_SPRITE_LIM),\r
- mee_onoff ("Use second CPU for sound", MA_OPT_ARM940_SOUND, PicoOpt, POPT_EXT_FM),\r
- mee_onoff ("Emulate Z80", MA_OPT2_ENABLE_Z80, PicoOpt, POPT_EN_Z80),\r
- mee_onoff ("Emulate YM2612 (FM)", MA_OPT2_ENABLE_YM2612, PicoOpt, POPT_EN_FM),\r
- mee_onoff ("Emulate SN76496 (PSG)", MA_OPT2_ENABLE_SN76496,PicoOpt, POPT_EN_PSG),\r
- mee_onoff ("gzip savestates", MA_OPT2_GZIP_STATES, currentConfig.EmuOpt, EOPT_GZIP_SAVES),\r
- mee_onoff ("Don't save last used ROM", MA_OPT2_NO_LAST_ROM, currentConfig.EmuOpt, EOPT_NO_AUTOSVCFG),\r
- mee_onoff ("RAM overclock", MA_OPT2_RAMTIMINGS, currentConfig.EmuOpt, EOPT_RAM_TIMINGS),\r
- mee_onoff ("MMU hack", MA_OPT2_SQUIDGEHACK, currentConfig.EmuOpt, EOPT_MMUHACK),\r
- mee_onoff ("SVP dynarec", MA_OPT2_SVP_DYNAREC, PicoOpt, POPT_EN_SVP_DRC),\r
- mee_onoff ("Disable idle loop patching",MA_OPT2_NO_IDLE_LOOPS,PicoOpt, POPT_DIS_IDLE_DET),\r
- mee_end,\r
-};\r
-\r
-static int menu_loop_adv_options(menu_id id, int keys)\r
-{\r
- static int sel = 0;\r
- me_loop(e_menu_adv_options, &sel);\r
- return 0;\r
-}\r
-\r
-// ------------ gfx options menu ------------\r
-\r
-static const char *mgn_opt_scaling(menu_id id, int *offs)\r
-{\r
- *offs = -13;\r
- switch (currentConfig.scaling) {\r
- default: return " OFF";\r
- case EOPT_SCALE_HW_H: return " hw horizontal";\r
- case EOPT_SCALE_HW_HV: return "hw horiz. + vert";\r
- case EOPT_SCALE_SW_H: return " sw horizontal";\r
- }\r
-}\r
-\r
-static const char *mgn_aopt_gamma(menu_id id, int *offs)\r
-{\r
- sprintf(static_buff, "%i.%02i", currentConfig.gamma / 100, currentConfig.gamma%100);\r
- return static_buff;\r
-}\r
-\r
-static menu_entry e_menu_gfx_options[] =\r
-{\r
- mee_range_cust("Scaling", MA_OPT_SCALING, currentConfig.scaling, 0, 3, mgn_opt_scaling),\r
- mee_range_cust("Gamma correction", MA_OPT2_GAMMA, currentConfig.gamma, 1, 300, mgn_aopt_gamma),\r
- mee_onoff ("A_SN's gamma curve", MA_OPT2_A_SN_GAMMA, currentConfig.EmuOpt, EOPT_A_SN_GAMMA),\r
- mee_onoff ("Perfect vsync", MA_OPT2_VSYNC, currentConfig.EmuOpt, EOPT_PSYNC),\r
- mee_end,\r
-};\r
-\r
-static int menu_loop_gfx_options(menu_id id, int keys)\r
-{\r
- static int sel = 0;\r
- me_loop(e_menu_gfx_options, &sel);\r
- return 0;\r
-}\r
-\r
-// ------------ options menu ------------\r
-\r
-static menu_entry e_menu_options[];\r
-\r
-/* TODO: move to plat */\r
-static int mh_opt_render(menu_id id, int keys)\r
-{\r
- if (keys & PBTN_LEFT) {\r
- if (PicoOpt&0x10) PicoOpt&= ~0x10;\r
- else if (!(currentConfig.EmuOpt &0x80))currentConfig.EmuOpt |= 0x80;\r
- } else {\r
- if (PicoOpt&0x10) return 0;\r
- else if (!(currentConfig.EmuOpt &0x80))PicoOpt|= 0x10;\r
- else if ( currentConfig.EmuOpt &0x80) currentConfig.EmuOpt &= ~0x80;\r
- }\r
- return 0;\r
-}\r
-\r
-static int sndrate_prevnext(int rate, int dir)\r
-{\r
- static const int rates[] = { 8000, 11025, 16000, 22050, 44100 };\r
- int i;\r
-\r
- for (i = 0; i < 5; i++)\r
- if (rates[i] == rate) break;\r
-\r
- i += dir ? 1 : -1;\r
- if (i > 4) {\r
- if (!(PicoOpt & POPT_EN_STEREO)) {\r
- PicoOpt |= POPT_EN_STEREO;\r
- return rates[0];\r
- }\r
- return rates[4];\r
- }\r
- if (i < 0) {\r
- if (PicoOpt & POPT_EN_STEREO) {\r
- PicoOpt &= ~POPT_EN_STEREO;\r
- return rates[4];\r
- }\r
- return rates[0];\r
- }\r
- return rates[i];\r
-}\r
-\r
-static void region_prevnext(int right)\r
-{\r
- // jp_ntsc=1, jp_pal=2, usa=4, eu=8\r
- static const int rgn_orders[] = { 0x148, 0x184, 0x814, 0x418, 0x841, 0x481 };\r
- int i;\r
-\r
- if (right) {\r
- if (!PicoRegionOverride) {\r
- for (i = 0; i < 6; i++)\r
- if (rgn_orders[i] == PicoAutoRgnOrder) break;\r
- if (i < 5) PicoAutoRgnOrder = rgn_orders[i+1];\r
- else PicoRegionOverride=1;\r
- }\r
- else\r
- PicoRegionOverride <<= 1;\r
- if (PicoRegionOverride > 8)\r
- PicoRegionOverride = 8;\r
- } else {\r
- if (!PicoRegionOverride) {\r
- for (i = 0; i < 6; i++)\r
- if (rgn_orders[i] == PicoAutoRgnOrder) break;\r
- if (i > 0) PicoAutoRgnOrder = rgn_orders[i-1];\r
- }\r
- else\r
- PicoRegionOverride >>= 1;\r
- }\r
-}\r
-\r
-static int mh_opt_misc(menu_id id, int keys)\r
-{\r
- int i;\r
-\r
- switch (id) {\r
- case MA_OPT_SOUND_QUALITY:\r
- PsndRate = sndrate_prevnext(PsndRate, keys & PBTN_RIGHT);\r
- break;\r
- case MA_OPT_REGION:\r
- region_prevnext(keys & PBTN_RIGHT);\r
- break;\r
- case MA_OPT_CONFIRM_STATES:\r
- i = ((currentConfig.EmuOpt>>9)&1) | ((currentConfig.EmuOpt>>10)&2);\r
- i += (keys & PBTN_LEFT) ? -1 : 1;\r
- if (i < 0) i = 0; else if (i > 3) i = 3;\r
- i |= i << 1; i &= ~2;\r
- currentConfig.EmuOpt &= ~0xa00;\r
- currentConfig.EmuOpt |= i << 9;\r
- break;\r
- default:\r
- break;\r
- }\r
- return 0;\r
-}\r
-\r
-static int mh_saveloadcfg(menu_id id, int keys)\r
-{\r
- int ret;\r
-\r
- if (keys & (PBTN_LEFT|PBTN_RIGHT)) { // multi choice\r
- config_slot += (keys & PBTN_LEFT) ? -1 : 1;\r
- if (config_slot < 0) config_slot = 9;\r
- else if (config_slot > 9) config_slot = 0;\r
- me_enable(e_menu_options, MA_OPT_LOADCFG, config_slot != config_slot_current);\r
- return 0;\r
- }\r
-\r
- switch (id) {\r
- case MA_OPT_SAVECFG:\r
- case MA_OPT_SAVECFG_GAME:\r
- if (emu_write_config(id == MA_OPT_SAVECFG_GAME ? 1 : 0))\r
- me_update_msg("config saved");\r
- else\r
- me_update_msg("failed to write config");\r
- break;\r
- case MA_OPT_LOADCFG:\r
- ret = emu_read_config(1, 1);\r
- if (!ret) ret = emu_read_config(0, 1);\r
- if (ret) me_update_msg("config loaded");\r
- else me_update_msg("failed to load config");\r
- break;\r
- default:\r
- return 0;\r
- }\r
-\r
- return 1;\r
-}\r
-\r
-static const char *mgn_opt_renderer(menu_id id, int *offs)\r
-{\r
- *offs = -6;\r
- if (PicoOpt & POPT_ALT_RENDERER)\r
- return " 8bit fast";\r
- else if (currentConfig.EmuOpt & 0x80)\r
- return "16bit accurate";\r
- else\r
- return " 8bit accurate";\r
-}\r
-\r
-static const char *mgn_opt_fskip(menu_id id, int *offs)\r
-{\r
- if (currentConfig.Frameskip < 0)\r
- return "Auto";\r
- sprintf(static_buff, "%d", currentConfig.Frameskip);\r
- return static_buff;\r
-}\r
-\r
-static const char *mgn_opt_sound(menu_id id, int *offs)\r
-{\r
- const char *str2;\r
- *offs = -8;\r
- str2 = (PicoOpt & POPT_EN_STEREO) ? "stereo" : "mono";\r
- sprintf(static_buff, "%5iHz %s", PsndRate, str2);\r
- return static_buff;\r
-}\r
-\r
-static const char *mgn_opt_region(menu_id id, int *offs)\r
-{\r
- static const char *names[] = { "Auto", " Japan NTSC", " Japan PAL", " USA", " Europe" };\r
- static const char *names_short[] = { "", " JP", " JP", " US", " EU" };\r
- int code = PicoRegionOverride;\r
- int u, i = 0;\r
-\r
- *offs = -6;\r
- if (code) {\r
- code <<= 1;\r
- while ((code >>= 1)) i++;\r
- if (i > 4)\r
- return "unknown";\r
- return names[i];\r
- } else {\r
- strcpy(static_buff, "Auto:");\r
- for (u = 0; u < 3; u++) {\r
- code = (PicoAutoRgnOrder >> u*4) & 0xf;\r
- for (i = 0; code; code >>= 1, i++)\r
- ;\r
- strcat(static_buff, names_short[i]);\r
- }\r
- return static_buff;\r
- }\r
-}\r