mirror of
				https://github.com/RaySollium99/picodrive.git
				synced 2025-10-26 08:19:38 -04:00 
			
		
		
		
	Starting to copy some logic for emu from PSP
This commit is contained in:
		
							parent
							
								
									e22b24b81a
								
							
						
					
					
						commit
						ebf2b007d1
					
				
					 2 changed files with 267 additions and 33 deletions
				
			
		|  | @ -1,14 +1,26 @@ | |||
| #include <stddef.h> | ||||
| 
 | ||||
| #include <kernel.h> | ||||
| #include <ps2_joystick_driver.h> | ||||
| #include <ps2_audio_driver.h> | ||||
| #include <libpad.h> | ||||
| 
 | ||||
| #include "in_ps2.h" | ||||
| #include "../libpicofe/input.h" | ||||
| #include "../libpicofe/plat.h" | ||||
| #include "../common/input_pico.h" | ||||
| #include "../common/emu.h" | ||||
| 
 | ||||
| #include <pico/pico_int.h> | ||||
| 
 | ||||
| #define OSD_FPS_X 220 | ||||
| 
 | ||||
| static int osd_buf_cnt, osd_cdleds; | ||||
| 
 | ||||
| static int out_x, out_y; | ||||
| static int out_w, out_h; | ||||
| static float hscale, vscale; | ||||
| 
 | ||||
| static struct in_default_bind in_ps2_defbinds[] = | ||||
| { | ||||
| 	{ PAD_UP,          IN_BINDTYPE_PLAYER12, GBTN_UP }, | ||||
|  | @ -26,6 +38,145 @@ static struct in_default_bind in_ps2_defbinds[] = | |||
| 	{ 0, 0, 0 } | ||||
| }; | ||||
| 
 | ||||
| const char *renderer_names[] = { "16bit accurate", " 8bit accurate", " 8bit fast", NULL }; | ||||
| const char *renderer_names32x[] = { "accurate", "faster", "fastest", NULL }; | ||||
| enum renderer_types { RT_16BIT, RT_8BIT_ACC, RT_8BIT_FAST, RT_COUNT }; | ||||
| 
 | ||||
| #define is_16bit_mode() \ | ||||
| 	(currentConfig.renderer == RT_16BIT || (PicoIn.AHW & PAHW_32X)) | ||||
| 
 | ||||
| static int get_renderer(void) | ||||
| { | ||||
| 	if (PicoIn.AHW & PAHW_32X) | ||||
| 		return currentConfig.renderer32x; | ||||
| 	else | ||||
| 		return currentConfig.renderer; | ||||
| } | ||||
| 
 | ||||
| static void change_renderer(int diff) | ||||
| { | ||||
| 	int *r; | ||||
| 	if (PicoIn.AHW & PAHW_32X) | ||||
| 		r = ¤tConfig.renderer32x; | ||||
| 	else | ||||
| 		r = ¤tConfig.renderer; | ||||
| 	*r += diff; | ||||
| 
 | ||||
| 	if      (*r >= RT_COUNT) | ||||
| 		*r = 0; | ||||
| 	else if (*r < 0) | ||||
| 		*r = RT_COUNT - 1; | ||||
| } | ||||
| 
 | ||||
| static void apply_renderer(void) | ||||
| { | ||||
| 	PicoIn.opt &= ~(POPT_ALT_RENDERER|POPT_EN_SOFTSCALE); | ||||
| 	PicoIn.opt |= POPT_DIS_32C_BORDER; | ||||
| 
 | ||||
| 	switch (get_renderer()) { | ||||
| 	case RT_16BIT: | ||||
| 		PicoDrawSetOutFormat(PDF_RGB555, 0); | ||||
| 		break; | ||||
| 	case RT_8BIT_ACC: | ||||
| 		PicoDrawSetOutFormat(PDF_8BIT, 0); | ||||
| 		break; | ||||
| 	case RT_8BIT_FAST: | ||||
| 		PicoIn.opt |=  POPT_ALT_RENDERER; | ||||
| 		PicoDrawSetOutFormat(PDF_NONE, 0); | ||||
| 		break; | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| static void osd_text(int x, const char *text) | ||||
| { | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| static void blit_osd(void) | ||||
| { | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| static void cd_leds(void) | ||||
| { | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| static void blit_cdleds(void) | ||||
| { | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| void blitscreen_clut(void) | ||||
| { | ||||
| 
 | ||||
|     blit_osd(); | ||||
| 	blit_cdleds(); | ||||
| } | ||||
| 
 | ||||
| static void draw_pico_ptr(void) | ||||
| { | ||||
| 	// unsigned char *p = (unsigned char *)g_screen_ptr + 8;
 | ||||
| 
 | ||||
| 	// // only if pen enabled and for 8bit mode
 | ||||
| 	// if (pico_inp_mode == 0 || is_16bit_mode()) return;
 | ||||
| 
 | ||||
| 	// p += 512 * (pico_pen_y + PICO_PEN_ADJUST_Y);
 | ||||
| 	// p += pico_pen_x + PICO_PEN_ADJUST_X;
 | ||||
| 	// if (!(Pico.video.reg[12]&1) && !(PicoIn.opt & POPT_DIS_32C_BORDER))
 | ||||
| 	// 	p += 32;
 | ||||
| 
 | ||||
| 	// p[  -1] = 0xe0; p[   0] = 0xf0; p[   1] = 0xe0;
 | ||||
| 	// p[ 511] = 0xf0; p[ 512] = 0xf0; p[ 513] = 0xf0;
 | ||||
| 	// p[1023] = 0xe0; p[1024] = 0xf0; p[1025] = 0xe0;
 | ||||
| } | ||||
| 
 | ||||
| static void vidResetMode(void) {} | ||||
| 
 | ||||
| void pemu_sound_start(void) {} | ||||
| void pemu_sound_stop(void) {} | ||||
| 
 | ||||
| /* set default configuration values */ | ||||
| void pemu_prep_defconfig(void) | ||||
| { | ||||
| 	defaultConfig.s_PsndRate = 44100; | ||||
| 	defaultConfig.s_PicoCDBuffers = 64; | ||||
| 	defaultConfig.filter = EOPT_FILTER_BILINEAR; // bilinear filtering
 | ||||
| 	defaultConfig.scaling = EOPT_SCALE_43; | ||||
| 	defaultConfig.vscaling = EOPT_VSCALE_FULL; | ||||
| 	defaultConfig.renderer = RT_8BIT_ACC; | ||||
| 	defaultConfig.renderer32x = RT_8BIT_ACC; | ||||
| 	defaultConfig.EmuOpt |= EOPT_SHOW_RTC; | ||||
| } | ||||
| 
 | ||||
| /* check configuration for inconsistencies */ | ||||
| void pemu_validate_config(void) | ||||
| { | ||||
| 	if (currentConfig.gamma < -4 || currentConfig.gamma >  16) | ||||
| 		currentConfig.gamma = 0; | ||||
| 	if (currentConfig.gamma2 < 0 || currentConfig.gamma2 > 2) | ||||
| 		currentConfig.gamma2 = 0; | ||||
| } | ||||
| 
 | ||||
| /* finalize rendering a frame */ | ||||
| void pemu_finalize_frame(const char *fps, const char *notice) | ||||
| { | ||||
| 	int emu_opt = currentConfig.EmuOpt; | ||||
| 
 | ||||
| 	if (PicoIn.AHW & PAHW_PICO) | ||||
| 		draw_pico_ptr(); | ||||
| 
 | ||||
| 	osd_buf_cnt = 0; | ||||
| 	if (notice)      osd_text(4, notice); | ||||
| 	if (emu_opt & 2) osd_text(OSD_FPS_X, fps); | ||||
| 
 | ||||
| 	osd_cdleds = 0; | ||||
| 	if ((emu_opt & 0x400) && (PicoIn.AHW & PAHW_MCD)) | ||||
| 		cd_leds(); | ||||
| 
 | ||||
| 	FlushCache(WRITEBACK_DCACHE); | ||||
| } | ||||
| 
 | ||||
| void plat_init(void)  | ||||
| { | ||||
|     init_joystick_driver(false); | ||||
|  | @ -39,3 +190,117 @@ void plat_finish(void) { | |||
|     deinit_audio_driver(); | ||||
|     deinit_joystick_driver(false); | ||||
| } | ||||
| 
 | ||||
| /* display emulator status messages before holding emulation */ | ||||
| void plat_status_msg_busy_first(const char *msg) | ||||
| { | ||||
| 	plat_status_msg_busy_next(msg); | ||||
| } | ||||
| 
 | ||||
| void plat_status_msg_busy_next(const char *msg) | ||||
| { | ||||
| 	plat_status_msg_clear(); | ||||
| 	pemu_finalize_frame("", msg); | ||||
| 	plat_video_flip(); | ||||
| 	emu_status_msg(""); | ||||
| 	reset_timing = 1; | ||||
| } | ||||
| 
 | ||||
| /* clear status message area */ | ||||
| void plat_status_msg_clear(void) | ||||
| { | ||||
| 	// not needed since the screen buf is cleared through the GU
 | ||||
| } | ||||
| 
 | ||||
| /* change the audio volume setting */ | ||||
| void plat_update_volume(int has_changed, int is_up) | ||||
| { | ||||
| } | ||||
| 
 | ||||
| /* prepare for MD screen mode change */ | ||||
| void emu_video_mode_change(int start_line, int line_count, int start_col, int col_count) | ||||
| { | ||||
| 	int h43 = (col_count  >= 192 ? 320 : col_count); // ugh, mind GG...
 | ||||
| 	int v43 = (line_count >= 192 ? Pico.m.pal ? 240 : 224 : line_count); | ||||
| 
 | ||||
| 	out_y = start_line; out_x = start_col; | ||||
| 	out_h = line_count; out_w = col_count; | ||||
| 
 | ||||
| 	if (col_count == 248) // mind aspect ratio when blanking 1st column
 | ||||
| 		col_count = 256; | ||||
| 
 | ||||
| 	switch (currentConfig.vscaling) { | ||||
| 	case EOPT_VSCALE_FULL: | ||||
| 		line_count = v43; | ||||
| 		vscale = (float)270/line_count; | ||||
| 		break; | ||||
| 	case EOPT_VSCALE_NOBORDER: | ||||
| 		vscale = (float)270/line_count; | ||||
| 		break; | ||||
| 	default: | ||||
| 		vscale = 1; | ||||
| 		break; | ||||
| 	} | ||||
| 
 | ||||
| 	switch (currentConfig.scaling) { | ||||
| 	case EOPT_SCALE_43: | ||||
| 		hscale = (vscale*h43)/col_count; | ||||
| 		break; | ||||
| 	case EOPT_SCALE_STRETCH: | ||||
| 		hscale = (vscale*h43/2 + 480/2)/col_count; | ||||
| 		break; | ||||
| 	case EOPT_SCALE_WIDE: | ||||
| 		hscale = (float)480/col_count; | ||||
| 		break; | ||||
| 	default: | ||||
| 		hscale = vscale; | ||||
| 		break; | ||||
| 	} | ||||
| 
 | ||||
| 	vidResetMode(); | ||||
| } | ||||
| 
 | ||||
| /* render one frame in RGB */ | ||||
| void pemu_forced_frame(int no_scale, int do_emu) | ||||
| { | ||||
| 	Pico.m.dirtyPal = 1; | ||||
| 
 | ||||
| 	if (!no_scale) | ||||
| 		no_scale = currentConfig.scaling == EOPT_SCALE_NONE; | ||||
| 	emu_cmn_forced_frame(no_scale, do_emu, g_screen_ptr); | ||||
| } | ||||
| 
 | ||||
| /* change the platform output rendering */ | ||||
| void plat_video_toggle_renderer(int change, int is_menu_call) | ||||
| { | ||||
| 	change_renderer(change); | ||||
| 
 | ||||
| 	if (is_menu_call) | ||||
| 		return; | ||||
| 
 | ||||
| 	apply_renderer(); | ||||
| 	vidResetMode(); | ||||
| 	rendstatus_old = -1; | ||||
| 
 | ||||
| 	if (PicoIn.AHW & PAHW_32X) | ||||
| 		emu_status_msg(renderer_names32x[get_renderer()]); | ||||
| 	else | ||||
| 		emu_status_msg(renderer_names[get_renderer()]); | ||||
| } | ||||
| 
 | ||||
| /* prepare for emulator output rendering */ | ||||
| void plat_video_loop_prepare(void)  | ||||
| { | ||||
| 	apply_renderer(); | ||||
| 	vidResetMode(); | ||||
| } | ||||
| 
 | ||||
| /* prepare for entering the emulator loop */ | ||||
| void pemu_loop_prep(void) | ||||
| { | ||||
| } | ||||
| 
 | ||||
| /* terminate the emulator loop */ | ||||
| void pemu_loop_end(void) | ||||
| { | ||||
| } | ||||
|  | @ -19,9 +19,6 @@ | |||
| 
 | ||||
| #include "../libpicofe/plat.h" | ||||
| 
 | ||||
| const char *renderer_names[] = { "Software", "Hardware" }; | ||||
| const char *renderer_names32x[] = { "Software", "Hardware", "Hardware (fast)" }; | ||||
| 
 | ||||
| struct plat_target plat_target = {}; | ||||
| 
 | ||||
| static void reset_IOP() { | ||||
|  | @ -59,7 +56,7 @@ void plat_target_finish(void) | |||
| /* display a completed frame buffer and prepare a new render buffer */ | ||||
| void plat_video_flip(void) | ||||
| { | ||||
| 
 | ||||
|     blitscreen_clut(); | ||||
| } | ||||
| 
 | ||||
| /* wait for start of vertical blanking */ | ||||
|  | @ -243,32 +240,4 @@ void lprintf(const char *fmt, ...) | |||
| 	va_end(vl); | ||||
| } | ||||
| 
 | ||||
| void plat_video_toggle_renderer(int change, int menu_call) {} | ||||
| 
 | ||||
| void plat_update_volume(int has_changed, int is_up) {} | ||||
| 
 | ||||
| void plat_status_msg_busy_first(const char *msg) {} | ||||
| 
 | ||||
| void pemu_prep_defconfig(void) {} | ||||
| 
 | ||||
| void pemu_validate_config(void) {} | ||||
| 
 | ||||
| void plat_status_msg_clear(void) {} | ||||
| 
 | ||||
| void plat_status_msg_busy_next(const char *msg) {} | ||||
| 
 | ||||
| void plat_video_loop_prepare(void) {} | ||||
| 
 | ||||
| void plat_debug_cat(char *str) {} | ||||
| 
 | ||||
| void pemu_loop_prep(void) {} | ||||
| 
 | ||||
| void pemu_sound_start(void) {} | ||||
| 
 | ||||
| void pemu_loop_end(void) {} | ||||
| 
 | ||||
| void emu_video_mode_change(int start_line, int line_count, int start_col, int col_count) {} | ||||
| 
 | ||||
| void pemu_forced_frame(int no_scale, int do_emu) {} | ||||
| 
 | ||||
| void pemu_finalize_frame(const char *fps, const char *notice_msg) {} | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Francisco Javier Trujillo Mata
						Francisco Javier Trujillo Mata