mirror of
				https://github.com/RaySollium99/picodrive.git
				synced 2025-10-26 08:19:38 -04:00 
			
		
		
		
	sh2 drc host disassembler integration for gp2x
This commit is contained in:
		
							parent
							
								
									5a5d765c23
								
							
						
					
					
						commit
						f5939109c4
					
				
					 6 changed files with 26 additions and 11 deletions
				
			
		
							
								
								
									
										2
									
								
								Makefile
									
										
									
									
									
								
							
							
						
						
									
										2
									
								
								Makefile
									
										
									
									
									
								
							|  | @ -122,8 +122,6 @@ OBJS += platform/gp2x/emu.o | |||
| OBJS += platform/gp2x/vid_mmsp2.o  | ||||
| OBJS += platform/gp2x/vid_pollux.o  | ||||
| OBJS += platform/gp2x/warm.o  | ||||
| OBJS += platform/gp2x/host_dasm.o | ||||
| OBJS += cpu/sh2/mame/sh2dasm.o | ||||
| USE_FRONTEND = 1 | ||||
| PLATFORM_MP3 = 1 | ||||
| PLATFORM_ZLIB = 1 | ||||
|  |  | |||
|  | @ -4,10 +4,9 @@ CC = gcc | |||
| CXX = g++ | ||||
| AS = as | ||||
| STRIP = strip | ||||
| CFLAGS +=  -I/usr/include/SDL -D_GNU_SOURCE=1 -D_REENTRANT -Wno-unused-result -m32 #-DGPERF -pg | ||||
| CFLAGS +=  -I/usr/include/SDL -D_GNU_SOURCE=1 -D_REENTRANT -Wno-unused-result -m32 # -pg | ||||
| ASFLAGS +=  | ||||
| LDFLAGS += -m32 #-pg | ||||
| LDLIBS += -L$(HOME)/opt/binutils-i386/usr/lib/ -lbfd-2.24-multiarch -lopcodes-2.24-multiarch | ||||
| LDLIBS += -L/usr/lib/i386-linux-gnu/debug -L/home/build/opt/lib32 -lSDL-1.2 -lasound -lpng -lz -lm -ldl | ||||
| 
 | ||||
| ARCH = x86 | ||||
|  |  | |||
|  | @ -2744,7 +2744,7 @@ end_op: | |||
|     if (drcf.pending_branch_direct) | ||||
|     { | ||||
|       struct op_data *opd_b = | ||||
|         (op_flags[i] & OF_DELAY_OP) ? &ops[i-1] : opd; | ||||
|         (op_flags[i] & OF_DELAY_OP) ? opd-1 : opd; | ||||
|       u32 target_pc = opd_b->imm; | ||||
|       int cond = -1, ncond = -1; | ||||
|       void *target = NULL; | ||||
|  |  | |||
|  | @ -15,16 +15,17 @@ | |||
| 	else if ( val < min ) val = min; \ | ||||
| } | ||||
| 
 | ||||
| int mix_32_to_16l_level; | ||||
| 
 | ||||
| void mix_32_to_16l_stereo(short *dest, int *src, int count) | ||||
| void mix_32_to_16l_stereo_core(short *dest, int *src, int count, int level) | ||||
| { | ||||
| 	int l, r; | ||||
| 
 | ||||
| 	for (; count > 0; count--) | ||||
| 	{ | ||||
| 		l = r = *dest; | ||||
| 		l += *src++; | ||||
| 		r += *src++; | ||||
| 		l += *src++ >> level; | ||||
| 		r += *src++ >> level; | ||||
| 		Limit( l, MAXOUT, MINOUT ); | ||||
| 		Limit( r, MAXOUT, MINOUT ); | ||||
| 		*dest++ = l; | ||||
|  | @ -32,6 +33,15 @@ void mix_32_to_16l_stereo(short *dest, int *src, int count) | |||
| 	} | ||||
| } | ||||
| 
 | ||||
| void mix_32_to_16l_stereo_lvl(short *dest, int *src, int count) | ||||
| { | ||||
| 	mix_32_to_16l_stereo_core(dest, src, count, mix_32_to_16l_level); | ||||
| } | ||||
| 
 | ||||
| void mix_32_to_16l_stereo(short *dest, int *src, int count) | ||||
| { | ||||
| 	mix_32_to_16l_stereo_core(dest, src, count, 0); | ||||
| } | ||||
| 
 | ||||
| void mix_32_to_16_mono(short *dest, int *src, int count) | ||||
| { | ||||
|  |  | |||
|  | @ -161,8 +161,16 @@ SRCS_COMMON += $(R)cpu/sh2/compiler.c | |||
| ifdef drc_debug | ||||
| DEFINES += DRC_DEBUG=$(drc_debug) | ||||
| SRCS_COMMON += $(R)cpu/sh2/mame/sh2dasm.c | ||||
| SRCS_COMMON += $(R)platform/libpicofe/linux/host_dasm.c | ||||
| LDFLAGS += -lbfd -lopcodes -liberty | ||||
| DASM = $(R)platform/libpicofe/linux/host_dasm.c | ||||
| DASMLIBS = -lbfd -lopcodes -liberty | ||||
| ifeq "$(ARCH)" "arm" | ||||
| ifeq ($(filter_out $(shell $(CC) --print-file-name=libbfd.so),"/"),) | ||||
| DASM = $(R)platform/common/host_dasm_arm.c | ||||
| DASMLIBS = | ||||
| endif | ||||
| endif | ||||
| SRCS_COMMON += $(DASM) | ||||
| LDFLAGS += $(DASMLIBS) | ||||
| endif | ||||
| endif # use_sh2drc
 | ||||
| SRCS_COMMON += $(R)cpu/sh2/mame/sh2pico.c | ||||
|  |  | |||
|  | @ -2,7 +2,7 @@ | |||
| #include <stdlib.h> | ||||
| #include <string.h> | ||||
| 
 | ||||
| #include "../common/disarm.c" | ||||
| #include "disarm.c" | ||||
| 
 | ||||
| 
 | ||||
| /* symbols */ | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 kub
						kub