diff options
author | twinaphex | 2016-08-05 19:46:46 +0200 |
---|---|---|
committer | twinaphex | 2016-08-05 19:46:46 +0200 |
commit | 38e5e34d5dc65432a11a4bbb4604885e7be9eb99 (patch) | |
tree | f61d917e3f7a7097603adda081fa902031feead4 | |
parent | 20fd45dfea4cd12e455492a5b36806c1c62b6465 (diff) | |
download | snes9x2002-38e5e34d5dc65432a11a4bbb4604885e7be9eb99.tar.gz snes9x2002-38e5e34d5dc65432a11a4bbb4604885e7be9eb99.tar.bz2 snes9x2002-38e5e34d5dc65432a11a4bbb4604885e7be9eb99.zip |
Remove this
-rw-r--r-- | old/Makefile | 241 | ||||
-rw-r--r-- | old/Makefile.22062010 | 105 | ||||
-rw-r--r-- | old/Makefile.gp2x | 105 | ||||
-rw-r--r-- | old/Makefile.last | 99 | ||||
-rw-r--r-- | old/Makefile.old | 243 | ||||
-rw-r--r-- | old/Makefile.wiz.OpenWiz | 82 | ||||
-rw-r--r-- | old/Makefile.wiz.bck | 82 | ||||
-rw-r--r-- | old/Makefile_giz | 88 | ||||
-rw-r--r-- | old/clip.cpp.new | 405 | ||||
-rw-r--r-- | old/gfx16.cpp.last | 3183 | ||||
-rw-r--r-- | old/gfx16.cpp.old2 | 3199 | ||||
-rw-r--r-- | old/rel/menu_header.bmp | bin | 46134 -> 0 bytes | |||
-rw-r--r-- | old/rel/readme.txt | 347 | ||||
-rw-r--r-- | old/rel/snesadvance.dat | 641 | ||||
-rw-r--r-- | old/snaporig.c | 411 | ||||
-rw-r--r-- | old/snaporig.h | 350 | ||||
-rw-r--r-- | old/spc700/Makefile | 13 | ||||
-rw-r--r-- | old/spc700/Makefile.win | 15 | ||||
-rw-r--r-- | old/spc700/debug/apu.h | 195 | ||||
-rw-r--r-- | old/spc700/debug/apumem.h | 222 | ||||
-rw-r--r-- | old/spc700/debug/port.h | 488 | ||||
-rw-r--r-- | old/spc700/debug/spc700.cpp | 2600 | ||||
-rw-r--r-- | old/spc700/debug/spc700.h | 172 | ||||
-rw-r--r-- | old/spc700/spcgen.c | 2164 | ||||
-rw-r--r-- | old/tile16.cpp.bak | 811 |
25 files changed, 0 insertions, 16261 deletions
diff --git a/old/Makefile b/old/Makefile deleted file mode 100644 index c967051..0000000 --- a/old/Makefile +++ /dev/null @@ -1,241 +0,0 @@ -# Two stages Makefile
-
-## Common vars
-
-DEFAULT = wiz
-NFAST = fast
-NCOMP = compatible
-ALL_TARGETS = wiz caanoo gp2x
-ODIR_SUFFIX = objs
-PNAME = pocketsnes
-
-## First stage
-ifneq ($(STAGE),2)
-
-FILE_DATE = $(shell date +%Y-%m-%d)
-
-export MNAME
-export VNAME
-export COPT
-export OBJS
-export ARCH
-export SDK
-export STAGE
-export FILE_DATE
-
-all:
- make wiz
- make caanoo
- make gp2x
-
-# default to fast version
-default: $(DEFAULT)f
-
-# clean
-clean: ALL_TARGETS_DIRS = $(addsuffix _$(NFAST)_$(ODIR_SUFFIX)/,$(ALL_TARGETS)) $(addsuffix _$(NCOMP)_$(ODIR_SUFFIX)/,$(ALL_TARGETS))
-clean:
- rm -f $(addsuffix *.o,$(ALL_TARGETS_DIRS))
- rm -f *.gpe
-
-# when release is targeted compile both fast and compatible versions
-release:
- make $(DEFAULT)f
- make $(DEFAULT)c
- rm -f rel/*.gpe
- cp $(PNAME)_$(DEFAULT)_*.gpe rel/.
- zip $(PNAME)-$(FILE_DATE).zip rel/*
-
-# invoke stage 2
-do: STAGE = 2
-do:
- make
-
-# ---------------------
-# Wiz
-# ---------------------
-
-# -- Wiz common
-wiz_common: MNAME = wiz
-wiz_common: COPT += -mcpu=arm926ej-s -mtune=arm926ej-s -g -D__WIZ__
-#wiz_common: COPT += -D__FAST_OBJS__
-#wiz_common: COPT += -O3
-wiz_common: COPT += -Os
-wiz_common: COPT += -ffast-math -msoft-float
-wiz_common: COPT += -finline -finline-functions -fexpensive-optimizations
-wiz_common: COPT += -falign-functions=32 -falign-loops -falign-labels -falign-jumps
-wiz_common: COPT += -fomit-frame-pointer
-wiz_common: COPT += -fno-common -fno-builtin -fstrict-aliasing -mstructure-size-boundary=32
-# -fweb -frename-registers
-# -fsplit-ivs-in-unroller
-#wiz_common: COPT += -Wall -Wno-sign-compare -Wunused -Wpointer-arith -Wcast-align -Waggregate-return
-wiz_common: OBJS = wiz_sdk.o warm.o squidgehack.o pollux_set.o
-wiz_common: OBJS += os9x_65c816_global.o os9x_65c816_spcasm.o os9x_65c816_spcc.o os9x_asm_cpu.o
-wiz_common: ARCH = arm-open2x-linux
-wiz_common: SDK = /opt/open2x/gcc-4.1.1-glibc-2.3.6
-#/$(ARCH)
-#wiz_common: ARCH = arm-openwiz-linux-gnu
-#wiz_common: SDK = /opt/openwiz/toolchain/$(ARCH)
-wiz_common: do
-
-# -- Fast version
-wizf: VNAME = $(NFAST)
-#wizf: COPT = -DASMCPU -D__DEBUG__
-wizf: COPT = -DASMCPU
-wizf: wiz_common
-
-# -- Normal version
-wizc: VNAME = $(NCOMP)
-wizc: COPT = -DUSE_SA1
-wizc: wiz_common
-
-wiz:
- make $@f
- make $@c
-
-# ---------------------
-# Caanoo
-# ---------------------
-
-# -- Caanoo common
-caanoo_common: MNAME = caanoo
-caanoo_common: COPT += -mcpu=arm926ej-s -mtune=arm926ej-s -g -D__WIZ__ -D__CAANOO__
-caanoo_common: COPT += -Os
-caanoo_common: COPT += -finline -finline-functions -fexpensive-optimizations
-caanoo_common: COPT += -falign-functions=32 -falign-loops -falign-labels -falign-jumps
-caanoo_common: COPT += -fomit-frame-pointer
-caanoo_common: COPT += -fno-common -fno-builtin -fstrict-aliasing -mstructure-size-boundary=32
-caanoo_common: OBJS = caanoo_sdk.o warm.o squidgehack.o pollux_set.o
-caanoo_common: OBJS += os9x_65c816_global.o os9x_65c816_spcasm.o os9x_65c816_spcc.o os9x_asm_cpu.o
-# EABI
-#caanoo_common: ARCH = arm-gph-linux-gnueabi
-#caanoo_common: SDK = /opt/caanoo_sdk/tools/gcc-4.2.4-glibc-2.7-eabi
-# OABI
-caanoo_common: COPT += -static -ffast-math -msoft-float
-caanoo_common: ARCH = arm-open2x-linux
-caanoo_common: SDK = /opt/open2x/gcc-4.1.1-glibc-2.3.6
-caanoo_common: do
-
-# -- Fast version
-caanoof: VNAME = $(NFAST)
-#caanoof: COPT = -DASMCPU -D__DEBUG__
-caanoof: COPT = -DASMCPU
-caanoof: caanoo_common
-
-# -- Normal version
-caanooc: VNAME = $(NCOMP)
-caanooc: COPT = -DUSE_SA1
-caanooc: caanoo_common
-
-caanoo:
- make $@f
- make $@c
-
-# ---------------------
-# GP2X
-# ---------------------
-
-# -- GP2X common
-gp2x_common: MNAME = gp2x
-gp2x_common: COPT += -mcpu=arm920t -mtune=arm920t -static -g -D__GP2X__
-gp2x_common: COPT += -Os
-gp2x_common: COPT += -ffast-math -msoft-float
-gp2x_common: COPT += -finline -finline-functions -fexpensive-optimizations
-gp2x_common: COPT += -falign-functions=32 -falign-loops -falign-labels -falign-jumps
-gp2x_common: COPT += -fomit-frame-pointer
-gp2x_common: COPT += -fno-common -fstrict-aliasing -mstructure-size-boundary=32
-gp2x_common: OBJS = gp2x_sdk.o warm.o squidgehack.o mmuhack.o
-gp2x_common: OBJS += os9x_65c816_global_armv4.o os9x_65c816_spcasm.o os9x_65c816_spcc.o os9x_asm_cpu.o
-gp2x_common: ARCH = arm-open2x-linux
-gp2x_common: SDK = /opt/open2x/gcc-4.1.1-glibc-2.3.6
-gp2x_common: do
-
-# -- Fast version
-gp2xf: VNAME = $(NFAST)
-gp2xf: COPT = -DASMCPU
-gp2xf: gp2x_common
-
-# -- Normal version
-gp2xc: VNAME = $(NCOMP)
-gp2xc: COPT = -DUSE_SA1
-gp2xc: gp2x_common
-
-gp2x:
- make $@f
- make $@c
-
-
-## Second stage
-else
-
-TOOLS = $(SDK)/bin
-GCC = $(TOOLS)/$(ARCH)-gcc
-STRIP = $(TOOLS)/$(ARCH)-strip
-ADSASM = $(TOOLS)/$(ARCH)-as
-LIBS = -I$(SDK)/include
-INCS = -L$(SDK)/lib
-ODIR = $(MNAME)_$(VNAME)_$(ODIR_SUFFIX)
-# Inopia's menu system, hacked for the GP2X under rlyeh's sdk
-PRELIBS = -lpthread -lz $(LIBS)
-
-#
-# SNES stuff (c-based)
-#
-#OBJS += touchscreen.o
-OBJS += apu.o apuaux.o c4.o c4emu.o cheats.o cheats2.o clip.o data.o screenshot.o
-OBJS += dsp1.o fxemu.o fxinst.o globals.o loadzip.o ppu.o
-OBJS += dma.o memmap.o
-OBJS += cpu.o cpuexec.o
-OBJS += cpuops.o
-OBJS += sa1.o sa1cpu.o
-OBJS += sdd1.o sdd1emu.o snapshot.o soundux.o spc700.o spc700a.o srtc.o
-#OBJS += spc_decode.o
-OBJS += tile16.o tile16add.o tile16add1_2.o tile16fadd1_2.o tile16sub.o tile16sub1_2.o tile16fsub1_2.o
-OBJS += mode7new.o mode7.o mode7add.o mode7add1_2.o mode7sub.o mode7sub1_2.o
-OBJS += mode7prio.o mode7addprio.o mode7add1_2prio.o mode7subprio.o mode7sub1_2prio.o
-OBJS += gfx16.o rops.o
-OBJS += usbjoy.o
-#
-# and some asm from LJP...
-#
-#OBJS += m3d_func.o
-#
-# Dave's minimal SDK
-#
-OBJS += menu.o config.o input.o gp2x_menutile.o gp2x_highlightbar.o \
- gp2x_menu_header.o unzip.o ioapi.o zip.o asm_util.o png.o graphics.o lodepng.o theme.o minIni.o
-OBJS += disk_img.o
-OBJS += memset.o memcmp.o memcpy.o strlen.o strcmp.o strncmp.o
-
-#
-# and the glue code that sticks it all together :)
-#
-OBJS += main.o
-FOBJS = $(addprefix $(ODIR)/,$(OBJS))
-COPT += $(INCS) $(LIBS)
-
-executable: $(FOBJS)
- $(GCC) $(COPT) $(FOBJS) $(PRELIBS) -o $(PNAME)d_$(MNAME)_$(VNAME).gpe -lstdc++ -lm
- $(STRIP) $(PNAME)d_$(MNAME)_$(VNAME).gpe -o $(PNAME)_$(MNAME)_$(VNAME).gpe
-
-$(FOBJS): | $(ODIR)
-
-$(ODIR):
- mkdir -p $(ODIR)
-
-tidy:
- rm $(ODIR)/*.o
-
-# -- Compilation rules
-$(ODIR)/%.o: %.cpp
- $(GCC) $(COPT) -c $< -o $@
-
-$(ODIR)/%.o: %.c
- $(GCC) $(COPT) -c $< -o $@
-
-$(ODIR)/%.o: %.s
- $(GCC) $(COPT) -c $< -o $@
-
-$(ODIR)/%.o: %.S
- $(GCC) $(COPT) -c $< -o $@
-
-endif
diff --git a/old/Makefile.22062010 b/old/Makefile.22062010 deleted file mode 100644 index 2fa3364..0000000 --- a/old/Makefile.22062010 +++ /dev/null @@ -1,105 +0,0 @@ -COPT = -mcpu=arm926ej-s -mtune=arm926ej-s -g -D__WIZ__
-COPT += -DASMCPU
-COPT += -DARM
-COPT += -DVAR_CYCLES
-#COPT += -D_C_GW_
-#COPT = -DUSE_SA1
-COPT += -O3
-# -DFAST_LSB_WORD_ACCESS
-COPT += -ffast-math -msoft-float
-COPT += -finline -finline-functions -fexpensive-optimizations
-COPT += -falign-functions=16 -falign-loops -falign-labels
-#COPT += -falign-jumps
-COPT += -fomit-frame-pointer
-COPT += -fstrict-aliasing -mstructure-size-boundary=32 -fweb -fsigned-char -frename-registers
-SDK = /opt/openwiz/toolchain/arm-openwiz-linux-gnu
-TOOLS = $(SDK)/bin
-ARCH = arm-openwiz-linux-gnu-
-GCC = $(TOOLS)/$(ARCH)gcc
-STRIP = $(TOOLS)/$(ARCH)strip
-ADSASM = $(TOOLS)/$(ARCH)as
-COPT += -I$(SDK)/include
-COPT += -L$(SDK)/lib
-#COPT += -fprofile-generate
-#COPT += -fprofile-use
-#
-# SNES stuff (c-based)
-#
-OBJS = memset.o memcpy.o
-OBJS += 2xsaiwin.o apu.o c4.o c4emu.o cheats.o cheats2.o clip.o data.o
-OBJS += dsp1.o fxemu.o fxinst.o globals.o loadzip.o ppu.o
-OBJS += dma.o memmap.o
-OBJS += cpu.o cpuexec.o
-OBJS += cpuops.o
-# OBJS += sa1.o sa1cpu.o
-OBJS += sdd1.o sdd1emu.o snapshot.o soundux.o spc_decode.o spc700.o spc700a.o srtc.o
-OBJS += tile16.o tile16add.cpp tile16sub.cpp gfx16.o
-OBJS += os9x_65c816.o os9x_asm_cpu.o
-OBJS += usbjoy.o
-#
-# and some asm from LJP...
-#
-OBJS += m3d_func.o
-#
-# Dave's minimal SDK
-#
-OBJS += wiz_sdk.o warm.o menu.o input.o gp2x_menutile.o gp2x_highlightbar.o \
- gp2x_menu_header.o unzip.o ioapi.o squidgehack.o zip.o asm_util.o pollux_set.o
-
-#
-# and the glue code that sticks it all together :)
-#
-OBJS += main.o
-
-# Inopia's menu system, hacked for the GP2X under rlyeh's sdk
-PRELIBS = -lpthread -lz $(LIBS)
-
-all: pocketsnes.gpe
-clean: tidy pocketsnes.gpe
-
-.c.o:
- $(GCC) $(COPT) -c $< -o $@
-
-.cpp.o:
- $(GCC) $(COPT) -c $< -o $@
-
-# make seems to lowercase the extensions, so files with '.S' end up being passed to the compiler as '.s', which means thousands of errors.
-# this is a small workaround.
-
-spc700a.o: spc700a.s
- $(GCC) $(COPT) -c $< -o $@
-
-os9x_65c816.o: os9x_65c816.s
- $(GCC) $(COPT) -c $< -o $@
-
-osnes9xgp_asmfunc.o: osnes9xgp_asmfunc.s
- $(GCC) $(COPT) -c $< -o $@
-
-m3d_func.o: m3d_func.S
- $(GCC) $(COPT) -c $< -o $@
-
-spc_decode.o: spc_decode.S
- $(GCC) $(COPT) -c $< -o $@
-
-memset.o: memset.s
- $(GCC) $(COPT) -c $< -o $@
-
-#sa1_asm.o: sa1_asm.s
-# $(GCC) $(COPT) -c $< -o $@
-
-memcpy.o: memcpy.s
- $(GCC) $(COPT) -c $< -o $@
-
-dspMixer.o: dspMixer.s
- $(GCC) $(COPT) -c $< -o $@
-
-asm_util.o: asm_util.S
- $(GCC) $(COPT) -c $< -o $@
-
-pocketsnesd.gpe: $(OBJS)
- $(GCC) $(COPT) $(OBJS) $(PRELIBS) -o $@ -lstdc++ -lm
-
-pocketsnes.gpe: pocketsnesd.gpe
- $(STRIP) pocketsnesd.gpe -o pocketsnes_wiz_fast.gpe
-tidy:
- rm *.o
diff --git a/old/Makefile.gp2x b/old/Makefile.gp2x deleted file mode 100644 index ecc07fd..0000000 --- a/old/Makefile.gp2x +++ /dev/null @@ -1,105 +0,0 @@ -COPT = -mcpu=arm926ej-s -mtune=arm926ej-s -static -g -D__WIZ__
-COPT += -DASMCPU
-COPT += -DARM
-COPT += -DVAR_CYCLES
-#COPT += -D_C_GW_
-#COPT = -DUSE_SA1
-COPT += -O3
-# -DFAST_LSB_WORD_ACCESS
-COPT += -ffast-math -msoft-float
-COPT += -finline -finline-functions -fexpensive-optimizations
-COPT += -falign-functions=16 -falign-loops -falign-labels
-#COPT += -falign-jumps
-COPT += -fomit-frame-pointer
-COPT += -fstrict-aliasing -mstructure-size-boundary=32 -fweb -fsigned-char -frename-registers
-SDK = /opt/openwiz/toolchain/arm-openwiz-linux-gnu
-TOOLS = $(SDK)/bin
-ARCH = arm-openwiz-linux-gnu-
-GCC = $(TOOLS)/$(ARCH)gcc
-STRIP = $(TOOLS)/$(ARCH)strip
-ADSASM = $(TOOLS)/$(ARCH)as
-COPT += -I$(SDK)/include
-COPT += -L$(SDK)/lib
-#COPT += -fprofile-generate
-#COPT += -fprofile-use
-#
-# SNES stuff (c-based)
-#
-OBJS = memset.o memcpy.o
-OBJS += 2xsaiwin.o apu.o c4.o c4emu.o cheats.o cheats2.o clip.o data.o
-OBJS += dsp1.o fxemu.o fxinst.o globals.o loadzip.o ppu.o
-OBJS += dma.o memmap.o
-OBJS += cpu.o cpuexec.o
-OBJS += cpuops.o
-# OBJS += sa1.o sa1cpu.o
-OBJS += sdd1.o sdd1emu.o snapshot.o soundux.o spc_decode.o spc700.o spc700a.o srtc.o
-OBJS += tile16.o tile16add.cpp tile16sub.cpp gfx16.o
-OBJS += os9x_65c816.o os9x_asm_cpu.o
-OBJS += usbjoy.o
-#
-# and some asm from LJP...
-#
-OBJS += m3d_func.o
-#
-# Dave's minimal SDK
-#
-OBJS += wiz_sdk.o warm.o menu.o input.o gp2x_menutile.o gp2x_highlightbar.o \
- gp2x_menu_header.o unzip.o ioapi.o squidgehack.o zip.o asm_util.o pollux_set.o
-
-#
-# and the glue code that sticks it all together :)
-#
-OBJS += main.o
-
-# Inopia's menu system, hacked for the GP2X under rlyeh's sdk
-PRELIBS = -lpthread -lz $(LIBS)
-
-all: pocketsnes.gpe
-clean: tidy pocketsnes.gpe
-
-.c.o:
- $(GCC) $(COPT) -c $< -o $@
-
-.cpp.o:
- $(GCC) $(COPT) -c $< -o $@
-
-# make seems to lowercase the extensions, so files with '.S' end up being passed to the compiler as '.s', which means thousands of errors.
-# this is a small workaround.
-
-spc700a.o: spc700a.s
- $(GCC) $(COPT) -c $< -o $@
-
-os9x_65c816.o: os9x_65c816.s
- $(GCC) $(COPT) -c $< -o $@
-
-osnes9xgp_asmfunc.o: osnes9xgp_asmfunc.s
- $(GCC) $(COPT) -c $< -o $@
-
-m3d_func.o: m3d_func.S
- $(GCC) $(COPT) -c $< -o $@
-
-spc_decode.o: spc_decode.S
- $(GCC) $(COPT) -c $< -o $@
-
-memset.o: memset.s
- $(GCC) $(COPT) -c $< -o $@
-
-#sa1_asm.o: sa1_asm.s
-# $(GCC) $(COPT) -c $< -o $@
-
-memcpy.o: memcpy.s
- $(GCC) $(COPT) -c $< -o $@
-
-dspMixer.o: dspMixer.s
- $(GCC) $(COPT) -c $< -o $@
-
-asm_util.o: asm_util.S
- $(GCC) $(COPT) -c $< -o $@
-
-pocketsnesd.gpe: $(OBJS)
- $(GCC) $(COPT) $(OBJS) $(PRELIBS) -o $@ -lstdc++ -lm
-
-pocketsnes.gpe: pocketsnesd.gpe
- $(STRIP) pocketsnesd.gpe -o pocketsnes_wiz_fast.gpe
-tidy:
- rm *.o
diff --git a/old/Makefile.last b/old/Makefile.last deleted file mode 100644 index 9249d22..0000000 --- a/old/Makefile.last +++ /dev/null @@ -1,99 +0,0 @@ -MNAME = wiz
-COPT = -mcpu=arm926ej-s -mtune=arm926ej-s -g -D__WIZ__
-COPT += -O3
-COPT += -ffast-math -msoft-float
-COPT += -finline -finline-functions -fexpensive-optimizations
-COPT += -falign-functions=32 -falign-loops -falign-labels
-COPT += -falign-jumps
-COPT += -fomit-frame-pointer
-#COPT += -fprofile-generate
-#COPT += -fprofile-use
-#COPT += -pg
-ARCH = arm-open2x-linux
-SDK = /opt/open2x/gcc-4.1.1-glibc-2.3.6/$(ARCH)
-TOOLS = $(SDK)/bin
-GCC = $(TOOLS)/$(ARCH)-gcc
-STRIP = $(TOOLS)/$(ARCH)-strip
-ADSASM = $(TOOLS)/$(ARCH)-as
-COPT += -I$(SDK)/include
-COPT += -L$(SDK)/lib
-#
-# SNES stuff (c-based)
-#
-OBJS = memcpy.o
-#OBJS += touchscreen.o
-OBJS += apu.o apuaux.o c4.o c4emu.o cheats.o cheats2.o clip.o data.o
-OBJS += dsp1.o fxemu.o fxinst.o globals.o loadzip.o ppu.o
-OBJS += dma.o memmap.o
-OBJS += cpu.o cpuexec.o
-OBJS += cpuops.o
-OBJS += sa1.o sa1cpu.o
-OBJS += sdd1.o sdd1emu.o snapshot.o soundux.o spc700.o spc700a.o srtc.o
-OBJS += spc_decode.o
-OBJS += tile16.o tile16add.o tile16add1_2.o tile16fadd1_2.o tile16sub.o tile16sub1_2.o tile16fsub1_2.o
-OBJS += mode7new.o mode7.o mode7add.o mode7add1_2.o mode7sub.o mode7sub1_2.o
-OBJS += mode7prio.o mode7addprio.o mode7add1_2prio.o mode7subprio.o mode7sub1_2prio.o
-OBJS += gfx16.o
-OBJS += os9x_65c816_global.o os9x_65c816_spcasm.o os9x_65c816_spcc.o os9x_asm_cpu.o
-OBJS += usbjoy.o
-#
-# and some asm from LJP...
-#
-OBJS += m3d_func.o
-#
-# Dave's minimal SDK
-#
-OBJS += loadlast.o wiz_sdk.o warm.o menu.o input.o gp2x_menutile.o gp2x_highlightbar.o \
- gp2x_menu_header.o unzip.o ioapi.o squidgehack.o zip.o asm_util.o pollux_set.o
-
-OBJS += disk_img.o
-#
-# and the glue code that sticks it all together :)
-#
-OBJS += main.o
-
-# Inopia's menu system, hacked for the GP2X under rlyeh's sdk
-PRELIBS = -lpthread -lz $(LIBS)
-
-all: vfast
-clean: tidy all
-
-first:
- mkdir -p $(MNAME)_$(VNAME)_obj
-
-$(OBJS): first
-
-pocketsnesd.gpe: $(OBJS)
- $(GCC) $(COPT) $(addprefix $(MNAME)_$(VNAME)_obj/,$(OBJS)) $(PRELIBS) -o pocketsnesd_$(MNAME)_$(VNAME).gpe -lstdc++ -lm
-
-pocketsnes.gpe: pocketsnesd.gpe
- $(STRIP) pocketsnesd_$(MNAME)_$(VNAME).gpe -o pocketsnes_$(MNAME)_$(VNAME).gpe
-
-tidy:
- rm $(OBJDIR)/*.o
-
-# -- Fast version
-vfast: VNAME = fast
-vfast: COPT += -DASMCPU
-vfast: OBJDIR = $(MNAME)_$(VNAME)_obj
-vfast: pocketsnes.gpe
-
-# -- Normal version
-vnormal: VNAME = normal
-vnormal: COPT += -DUSE_SA1
-vnormal: ODIR = $(MNAME)_$(VNAME)_obj
-vnormal: pocketsnes.gpe
-
-# -- Compilation rules
-%.o: %.cpp
- $(GCC) $(COPT) -c $< -o $(MNAME)_$(VNAME)_obj/$@
-
-%.o: %.c
- $(GCC) $(COPT) -c $< -o $(MNAME)_$(VNAME)_obj/$@
-
-%.o: %.s
- $(GCC) $(COPT) -c $< -o $(MNAME)_$(VNAME)_obj/$@
-
-%.o: %.S
- $(GCC) $(COPT) -c $< -o $(MNAME)_$(VNAME)_obj/$@
-
diff --git a/old/Makefile.old b/old/Makefile.old deleted file mode 100644 index 1c713c0..0000000 --- a/old/Makefile.old +++ /dev/null @@ -1,243 +0,0 @@ -# Two stages Makefile
-
-## Common vars
-
-DEFAULT = wiz
-NFAST = fast
-NCOMP = compatible
-ALL_TARGETS = wiz caanoo gp2x
-ODIR_SUFFIX = objs
-PNAME = pocketsnes
-
-## First stage
-ifneq ($(STAGE),2)
-
-FILE_DATE = $(shell date +%Y-%m-%d)
-
-export MNAME
-export VNAME
-export COPT
-export OBJS
-export ARCH
-export SDK
-export STAGE
-export FILE_DATE
-
-all:
- make wiz
- make caanoo
- make gp2x
-
-# default to fast version
-default: $(DEFAULT)f
-
-# clean
-clean: ALL_TARGETS_DIRS = $(addsuffix _$(NFAST)_$(ODIR_SUFFIX)/,$(ALL_TARGETS)) $(addsuffix _$(NCOMP)_$(ODIR_SUFFIX)/,$(ALL_TARGETS))
-clean:
- rm -f $(addsuffix *.o,$(ALL_TARGETS_DIRS))
- rm -f *.gpe
-
-# when release is targeted compile both fast and compatible versions
-release:
- make $(DEFAULT)f
- make $(DEFAULT)c
- rm -f rel/*.gpe
- cp $(PNAME)_$(DEFAULT)_*.gpe rel/.
- zip $(PNAME)-$(FILE_DATE).zip rel/*
-
-# invoke stage 2
-do: STAGE = 2
-do:
- make
-
-# ---------------------
-# Wiz
-# ---------------------
-
-# -- Wiz common
-wiz_common: MNAME = wiz
-wiz_common: COPT += -mcpu=arm926ej-s -mtune=arm926ej-s -g -D__WIZ__
-#wiz_common: COPT += -D__FAST_OBJS__
-#wiz_common: COPT += -O3
-wiz_common: COPT += -Os
-wiz_common: COPT += -ffast-math -msoft-float
-wiz_common: COPT += -finline -finline-functions -fexpensive-optimizations
-wiz_common: COPT += -falign-functions=32 -falign-loops -falign-labels -falign-jumps
-wiz_common: COPT += -fomit-frame-pointer
-wiz_common: COPT += -fno-common -fno-builtin -fstrict-aliasing -mstructure-size-boundary=32
-# -fweb -frename-registers
-# -fsplit-ivs-in-unroller
-#wiz_common: COPT += -Wall -Wno-sign-compare -Wunused -Wpointer-arith -Wcast-align -Waggregate-return
-wiz_common: OBJS = wiz_sdk.o warm.o squidgehack.o pollux_set.o
-wiz_common: OBJS += os9x_65c816_global.o os9x_65c816_spcasm.o os9x_65c816_spcc.o os9x_asm_cpu.o
-wiz_common: ARCH = arm-open2x-linux
-wiz_common: SDK = /opt/open2x/gcc-4.1.1-glibc-2.3.6
-#/$(ARCH)
-#wiz_common: ARCH = arm-openwiz-linux-gnu
-#wiz_common: SDK = /opt/openwiz/toolchain/$(ARCH)
-wiz_common: do
-
-# -- Fast version
-wizf: VNAME = $(NFAST)
-#wizf: COPT = -DASMCPU -D__DEBUG__
-wizf: COPT = -DASMCPU
-wizf: wiz_common
-
-# -- Normal version
-wizc: VNAME = $(NCOMP)
-wizc: COPT = -DUSE_SA1
-wizc: wiz_common
-
-wiz:
- make $@f
- make $@c
-
-# ---------------------
-# Caanoo
-# ---------------------
-
-# -- Caanoo common
-caanoo_common: MNAME = caanoo
-caanoo_common: COPT += -mcpu=arm926ej-s -mtune=arm926ej-s -g -D__WIZ__ -D__CAANOO__
-#caanoo_coomon: COPT += -D__FAST_OBJS__
-#caanoo_common: COPT += -O3
-caanoo_common: COPT += -Os
-caanoo_common: COPT += -finline -finline-functions -fexpensive-optimizations
-caanoo_common: COPT += -falign-functions=32 -falign-loops -falign-labels -falign-jumps
-caanoo_common: COPT += -fomit-frame-pointer
-caanoo_common: COPT += -fno-common -fno-builtin -fstrict-aliasing -mstructure-size-boundary=32
-caanoo_common: OBJS = caanoo_sdk.o warm.o squidgehack.o pollux_set.o
-caanoo_common: OBJS += os9x_65c816_global.o os9x_65c816_spcasm.o os9x_65c816_spcc.o os9x_asm_cpu.o
-# EABI
-#caanoo_common: ARCH = arm-gph-linux-gnueabi
-#caanoo_common: SDK = /opt/caanoo_sdk/tools/gcc-4.2.4-glibc-2.7-eabi
-# OABI
-caanoo_common: COPT += -static -ffast-math -msoft-float
-caanoo_common: ARCH = arm-open2x-linux
-caanoo_common: SDK = /opt/open2x/gcc-4.1.1-glibc-2.3.6
-caanoo_common: do
-
-# -- Fast version
-caanoof: VNAME = $(NFAST)
-#caanoof: COPT = -DASMCPU -D__DEBUG__
-caanoof: COPT = -DASMCPU
-caanoof: caanoo_common
-
-# -- Normal version
-caanooc: VNAME = $(NCOMP)
-caanooc: COPT = -DUSE_SA1
-caanooc: caanoo_common
-
-caanoo:
- make $@f
- make $@c
-
-# ---------------------
-# GP2X
-# ---------------------
-
-# -- GP2X common
-gp2x_common: MNAME = gp2x
-gp2x_common: COPT += -mcpu=arm920t -mtune=arm920t -static -g -D__GP2X__
-gp2x_common: COPT += -Os
-gp2x_common: COPT += -ffast-math -msoft-float
-gp2x_common: COPT += -finline -finline-functions -fexpensive-optimizations
-gp2x_common: COPT += -falign-functions=32 -falign-loops -falign-labels -falign-jumps
-gp2x_common: COPT += -fomit-frame-pointer
-gp2x_common: COPT += -fno-common -fstrict-aliasing -mstructure-size-boundary=32
-gp2x_common: OBJS = gp2x_sdk.o warm.o squidgehack.o mmuhack.o
-gp2x_common: OBJS += os9x_65c816_global_armv4.o os9x_65c816_spcasm.o os9x_65c816_spcc.o os9x_asm_cpu.o
-gp2x_common: ARCH = arm-open2x-linux
-gp2x_common: SDK = /opt/open2x/gcc-4.1.1-glibc-2.3.6
-gp2x_common: do
-
-# -- Fast version
-gp2xf: VNAME = $(NFAST)
-gp2xf: COPT = -DASMCPU
-gp2xf: gp2x_common
-
-# -- Normal version
-gp2xc: VNAME = $(NCOMP)
-gp2xc: COPT = -DUSE_SA1
-gp2xc: gp2x_common
-
-gp2x:
- make $@f
- make $@c
-
-
-## Second stage
-else
-
-TOOLS = $(SDK)/bin
-GCC = $(TOOLS)/$(ARCH)-gcc
-STRIP = $(TOOLS)/$(ARCH)-strip
-ADSASM = $(TOOLS)/$(ARCH)-as
-LIBS = -I$(SDK)/include
-INCS = -L$(SDK)/lib
-ODIR = $(MNAME)_$(VNAME)_$(ODIR_SUFFIX)
-# Inopia's menu system, hacked for the GP2X under rlyeh's sdk
-PRELIBS = -lpthread -lz $(LIBS)
-
-#
-# SNES stuff (c-based)
-#
-#OBJS += touchscreen.o
-OBJS += apu.o apuaux.o c4.o c4emu.o cheats.o cheats2.o clip.o data.o screenshot.o
-OBJS += dsp1.o fxemu.o fxinst.o globals.o loadzip.o ppu.o
-OBJS += dma.o memmap.o
-OBJS += cpu.o cpuexec.o
-OBJS += cpuops.o
-OBJS += sa1.o sa1cpu.o
-OBJS += sdd1.o sdd1emu.o snapshot.o soundux.o spc700.o spc700a.o srtc.o
-#OBJS += spc_decode.o
-OBJS += tile16.o tile16add.o tile16add1_2.o tile16fadd1_2.o tile16sub.o tile16sub1_2.o tile16fsub1_2.o
-OBJS += mode7new.o mode7.o mode7add.o mode7add1_2.o mode7sub.o mode7sub1_2.o
-OBJS += mode7prio.o mode7addprio.o mode7add1_2prio.o mode7subprio.o mode7sub1_2prio.o
-OBJS += gfx16.o rops.o
-OBJS += usbjoy.o
-#
-# and some asm from LJP...
-#
-#OBJS += m3d_func.o
-#
-# Dave's minimal SDK
-#
-OBJS += menu.o config.o input.o gp2x_menutile.o gp2x_highlightbar.o \
- gp2x_menu_header.o unzip.o ioapi.o zip.o asm_util.o png.o graphics.o lodepng.o theme.o minIni.o
-OBJS += disk_img.o
-OBJS += memset.o memcmp.o memcpy.o strlen.o strcmp.o strncmp.o
-
-#
-# and the glue code that sticks it all together :)
-#
-OBJS += main.o
-FOBJS = $(addprefix $(ODIR)/,$(OBJS))
-COPT += $(INCS) $(LIBS)
-
-executable: $(FOBJS)
- $(GCC) $(COPT) $(FOBJS) $(PRELIBS) -o $(PNAME)d_$(MNAME)_$(VNAME).gpe -lstdc++ -lm
- $(STRIP) $(PNAME)d_$(MNAME)_$(VNAME).gpe -o $(PNAME)_$(MNAME)_$(VNAME).gpe
-
-$(FOBJS): | $(ODIR)
-
-$(ODIR):
- mkdir -p $(ODIR)
-
-tidy:
- rm $(ODIR)/*.o
-
-# -- Compilation rules
-$(ODIR)/%.o: %.cpp
- $(GCC) $(COPT) -c $< -o $@
-
-$(ODIR)/%.o: %.c
- $(GCC) $(COPT) -c $< -o $@
-
-$(ODIR)/%.o: %.s
- $(GCC) $(COPT) -c $< -o $@
-
-$(ODIR)/%.o: %.S
- $(GCC) $(COPT) -c $< -o $@
-
-endif
diff --git a/old/Makefile.wiz.OpenWiz b/old/Makefile.wiz.OpenWiz deleted file mode 100644 index 4950675..0000000 --- a/old/Makefile.wiz.OpenWiz +++ /dev/null @@ -1,82 +0,0 @@ -COPT = -mcpu=arm926ej-s -mtune=arm926ej-s -g -O3 -static -D__WIZ__ -DUSE_SA1
-COPT += -ffast-math -fexpensive-optimizations -finline -finline-functions -msoft-float
-# -msoft-float
-COPT += -falign-functions=32 -falign-loops -falign-labels -falign-jumps -fomit-frame-pointer
-SDK = /opt/openwiz/toolchain/arm-openwiz-linux-gnu
-TOOLS = $(SDK)/bin
-ARCH = arm-openwiz-linux-gnu-
-GCC = $(TOOLS)/$(ARCH)gcc
-STRIP = $(TOOLS)/$(ARCH)strip
-ADSASM = $(TOOLS)/$(ARCH)as
-COPT += -I$(SDK)/include
-COPT += -L$(SDK)/lib
-#
-# SNES stuff (c-based)
-#
-OBJS = memset.o memcpy.o 2xsaiwin.o apu.o c4.o c4emu.o cheats.o cheats2.o clip.o cpu.o cpuexec.o data.o
-OBJS += dma.o dsp1.o fxemu.o fxinst.o gfx.o globals.o loadzip.o memmap.o ppu.o sa1.o sa1cpu.o
-OBJS += sdd1.o sdd1emu.o snapshot.o soundux.o spc700.o spc700a.o srtc.o tile.o usbjoy.o cpuops.o os9x_asm_cpu.o
-#
-# and some asm from LJP...
-#
-OBJS += m3d_func.o
-#
-# Dave's minimal SDK
-#
-OBJS += wiz_sdk.o warm.o menu.o input.o gp2x_menutile.o gp2x_highlightbar.o \
- gp2x_menu_header.o unzip.o ioapi.o squidgehack.o zip.o asm_util.o pollux_set.o
-
-#
-# and the glue code that sticks it all together :)
-#
-OBJS += main.o
-
-# Inopia's menu system, hacked for the GP2X under rlyeh's sdk
-PRELIBS = -lpthread -lz $(LIBS)
-
-all: pocketsnes.gpe
-clean: tidy pocketsnes.gpe
-
-.c.o:
- $(GCC) $(COPT) -c $< -o $@
-
-.cpp.o:
- $(GCC) $(COPT) -c $< -o $@
-
-# make seems to lowercase the extensions, so files with '.S' end up being passed to the compiler as '.s', which means thousands of errors.
-# this is a small workaround.
-
-spc700a.o: spc700a.s
- $(GCC) $(COPT) -c $< -o $@
-
-os9x_65c816.o: os9x_65c816.s
- $(GCC) $(COPT) -c $< -o $@
-
-osnes9xgp_asmfunc.o: osnes9xgp_asmfunc.s
- $(GCC) $(COPT) -c $< -o $@
-
-m3d_func.o: m3d_func.S
- $(GCC) $(COPT) -c $< -o $@
-
-spc_decode.o: spc_decode.s
- $(GCC) $(COPT) -c $< -o $@
-
-memset.o: memset.s
- $(GCC) $(COPT) -c $< -o $@
-
-memcpy.o: memcpy.s
- $(GCC) $(COPT) -c $< -o $@
-
-dspMixer.o: dspMixer.s
- $(GCC) $(COPT) -c $< -o $@
-
-asm_util.o: asm_util.S
- $(GCC) $(COPT) -c $< -o $@
-
-pocketsnesd.gpe: $(OBJS)
- $(GCC) $(COPT) $(OBJS) $(PRELIBS) -o $@ -lstdc++ -lm
-
-pocketsnes.gpe: pocketsnesd.gpe
- $(STRIP) pocketsnesd.gpe -o pocketsnes_wiz.gpe
-tidy:
- rm *.o
diff --git a/old/Makefile.wiz.bck b/old/Makefile.wiz.bck deleted file mode 100644 index b682196..0000000 --- a/old/Makefile.wiz.bck +++ /dev/null @@ -1,82 +0,0 @@ -COPT = -mcpu=arm926ej-s -mtune=arm926ej-s -g -O3 -static -D__WIZ__ -DUSE_SA1
-COPT += -ffast-math -fexpensive-optimizations -finline -finline-functions -msoft-float
-# -msoft-float
-COPT += -falign-functions=32 -falign-loops -falign-labels -falign-jumps -fomit-frame-pointer
-SDK = $(HOME)/GPH_SDK
-TOOLS = $(SDK)/tools/gcc-4.0.2-glibc-2.3.6/arm-linux/bin
-ARCH = arm-linux-
-GCC = $(TOOLS)/$(ARCH)gcc
-STRIP = $(TOOLS)/$(ARCH)strip
-ADSASM = $(TOOLS)/$(ARCH)as
-COPT += -I$(SDK)/include
-COPT += -L$(SDK)/lib/target
-#
-# SNES stuff (c-based)
-#
-OBJS = memset.o memcpy.o 2xsaiwin.o apu.o c4.o c4emu.o cheats.o cheats2.o clip.o cpu.o cpuexec.o data.o
-OBJS += dma.o dsp1.o fxemu.o fxinst.o gfx.o globals.o loadzip.o memmap.o ppu.o sa1.o sa1cpu.o
-OBJS += sdd1.o sdd1emu.o snapshot.o soundux.o spc700.o spc700a.o srtc.o tile.o usbjoy.o cpuops.o os9x_asm_cpu.o
-#
-# and some asm from LJP...
-#
-OBJS += m3d_func.o
-#
-# Dave's minimal SDK
-#
-OBJS += wiz_sdk.o warm.o menu.o input.o gp2x_menutile.o gp2x_highlightbar.o \
- gp2x_menu_header.o unzip.o ioapi.o squidgehack.o zip.o asm_util.o pollux_set.o
-
-#
-# and the glue code that sticks it all together :)
-#
-OBJS += main.o
-
-# Inopia's menu system, hacked for the GP2X under rlyeh's sdk
-PRELIBS = -lpthread -lz $(LIBS)
-
-all: pocketsnes.gpe
-clean: tidy pocketsnes.gpe
-
-.c.o:
- $(GCC) $(COPT) -c $< -o $@
-
-.cpp.o:
- $(GCC) $(COPT) -c $< -o $@
-
-# make seems to lowercase the extensions, so files with '.S' end up being passed to the compiler as '.s', which means thousands of errors.
-# this is a small workaround.
-
-spc700a.o: spc700a.s
- $(GCC) $(COPT) -c $< -o $@
-
-os9x_65c816.o: os9x_65c816.s
- $(GCC) $(COPT) -c $< -o $@
-
-osnes9xgp_asmfunc.o: osnes9xgp_asmfunc.s
- $(GCC) $(COPT) -c $< -o $@
-
-m3d_func.o: m3d_func.S
- $(GCC) $(COPT) -c $< -o $@
-
-spc_decode.o: spc_decode.s
- $(GCC) $(COPT) -c $< -o $@
-
-memset.o: memset.s
- $(GCC) $(COPT) -c $< -o $@
-
-memcpy.o: memcpy.s
- $(GCC) $(COPT) -c $< -o $@
-
-dspMixer.o: dspMixer.s
- $(GCC) $(COPT) -c $< -o $@
-
-asm_util.o: asm_util.S
- $(GCC) $(COPT) -c $< -o $@
-
-pocketsnesd.gpe: $(OBJS)
- $(GCC) $(COPT) $(OBJS) $(PRELIBS) -o $@ -lstdc++ -lm
-
-pocketsnes.gpe: pocketsnesd.gpe
- $(STRIP) pocketsnesd.gpe -o pocketsnes_wiz.gpe
-tidy:
- rm *.o
diff --git a/old/Makefile_giz b/old/Makefile_giz deleted file mode 100644 index f20d02c..0000000 --- a/old/Makefile_giz +++ /dev/null @@ -1,88 +0,0 @@ -#COPT = -static -g -I. -I C:/devkitGP2X/include -IC:/devkitGP2X/sysroot/usr/include -O3 -D__GP2X__
-
-SDK_BASE = C:/cygwin/usr/local/arm-wince-pe/lib/KGSDK
-ZLIB_BASE = C:/cygwin/usr/local/arm-wince-pe/lib/zlib
-
-#COPT = -IC:/cygwin/usr/local/arm-wince-pe/include -I$(SDK_BASE)/include -static -g -I. -O3 -mtune=arm920t -ftracer -fstrength-reduce -Wno-unused -funroll-loops -fomit-frame-pointer -fstrict-aliasing -ffast-math -D__GP2X__
-COPT = -IC:/cygwin/usr/local/arm-wince-pe/include -I$(SDK_BASE)/include -I$(ZLIB_BASE)/include -I . -mcpu=arm920 \
- -mtune=arm920t -O2 -msoft-float -ffast-math -fstrict-aliasing -mstructure-size-boundary=8 \
- -fexpensive-optimizations -fweb -frename-registers -fomit-frame-pointer -falign-functions -finline -finline-functions \
- -fno-builtin -fno-common -D__GIZ__
-GCC = arm-wince-pe-gcc
-STRIP = arm-wince-pe-strip
-ADSASM = armasm
-
-#
-# SNES stuff (c-based)
-#
-OBJS = 2xsaiwin.o apu.o c4.o c4emu.o cheats.o cheats2.o clip.o cpu.o cpuexec.o data.o
-OBJS += dma.o dsp1.o fxemu.o fxinst.o gfx.o globals.o loadzip.o memmap.o ppu.o
-OBJS += sdd1.o snapshot.o soundux.o spc700.o srtc.o tile.o
-#
-# ASM CPU Core, ripped from Yoyo's OpenSnes9X
-#
-OBJS += os9x_asm_cpu.o os9x_65c816.o spc700a.o
-#osnes9xgp_asmfunc.o
-#RenderASM/render8.o
-#
-# and some asm from LJP...
-#
-OBJS += m3d_func.o spc_decode.o
-#
-#
-#
-OBJS += giz_kgsdk.o menu.o input.o gp2x_menutile.o gp2x_highlightbar.o \
- gp2x_menu_header.o unzip.o ioapi.o giz_kgsdkasm.o
-
-#
-# and the glue code that sticks it all together :)
-#
-OBJS += main.o
-
-# Inopia's menu system, hacked for the GP2X under rlyeh's sdk
-PRELIBS = -LC:/cygwin/usr/local/arm-wince-pe/lib -L$(ZLIB_BASE) -lzip -L$(SDK_BASE) -lKGSDK $(LIBS)
-
-all: squidgesnes.gpe
-clean: tidy squidgesnes.gpe
-
-.c.o:
- $(GCC) $(COPT) -c $< -o $@
-
-.cpp.o:
- $(GCC) $(COPT) -c $< -o $@
-
-# make seems to lowercase the extensions, so files with '.S' end up being passed to the compiler as '.s', which means thousands of errors.
-# this is a small workaround.
-
-myuname.o: myuname.S
- $(GCC) $(COPT) -c $< -o $@
-
-os9x_65c816.o: os9x_65c816.s
- $(GCC) $(COPT) -c $< -o $@
-
-osnes9xgp_asmfunc.o: osnes9xgp_asmfunc.S
- $(GCC) $(COPT) -c $< -o $@
-
-m3d_func.o: m3d_func.S
- $(GCC) $(COPT) -c $< -o $@
-
-spc_decode.o: spc_decode.s
- $(GCC) $(COPT) -c $< -o $@
-
-spc700a.o: spc700a.s
- $(GCC) $(COPT) -c $< -o $@
-
-giz_kgsdkasm.o: giz_kgsdkasm.s
- $(GCC) $(COPT) -c $< -o $@
-
-RenderASM/render8.o: RenderASM/render8.S
- $(GCC) $(COPT) -c $< -o $@
-
-squidgesnesd.gpe: $(OBJS)
- $(GCC) $(COPT) $(OBJS) -static $(PRELIBS) -o $@ -lstdc++ -lm
-
-squidgesnes.gpe: squidgesnesd.gpe
- $(STRIP) squidgesnesd.gpe -o squidgesnes.gpe
- cp squidgesnes.gpe autorun.exe
-tidy:
- del *.o
diff --git a/old/clip.cpp.new b/old/clip.cpp.new deleted file mode 100644 index 895ea48..0000000 --- a/old/clip.cpp.new +++ /dev/null @@ -1,405 +0,0 @@ -/*********************************************************************************** - Snes9x - Portable Super Nintendo Entertainment System (TM) emulator. - - (c) Copyright 1996 - 2002 Gary Henderson (gary.henderson@ntlworld.com), - Jerremy Koot (jkoot@snes9x.com) - - (c) Copyright 2002 - 2004 Matthew Kendora - - (c) Copyright 2002 - 2005 Peter Bortas (peter@bortas.org) - - (c) Copyright 2004 - 2005 Joel Yliluoma (http://iki.fi/bisqwit/) - - (c) Copyright 2001 - 2006 John Weidman (jweidman@slip.net) - - (c) Copyright 2002 - 2006 funkyass (funkyass@spam.shaw.ca), - Kris Bleakley (codeviolation@hotmail.com) - - (c) Copyright 2002 - 2010 Brad Jorsch (anomie@users.sourceforge.net), - Nach (n-a-c-h@users.sourceforge.net), - zones (kasumitokoduck@yahoo.com) - - (c) Copyright 2006 - 2007 nitsuja - - (c) Copyright 2009 - 2010 BearOso, - OV2 - - - BS-X C emulator code - (c) Copyright 2005 - 2006 Dreamer Nom, - zones - - C4 x86 assembler and some C emulation code - (c) Copyright 2000 - 2003 _Demo_ (_demo_@zsnes.com), - Nach, - zsKnight (zsknight@zsnes.com) - - C4 C++ code - (c) Copyright 2003 - 2006 Brad Jorsch, - Nach - - DSP-1 emulator code - (c) Copyright 1998 - 2006 _Demo_, - Andreas Naive (andreasnaive@gmail.com), - Gary Henderson, - Ivar (ivar@snes9x.com), - John Weidman, - Kris Bleakley, - Matthew Kendora, - Nach, - neviksti (neviksti@hotmail.com) - - DSP-2 emulator code - (c) Copyright 2003 John Weidman, - Kris Bleakley, - Lord Nightmare (lord_nightmare@users.sourceforge.net), - Matthew Kendora, - neviksti - - DSP-3 emulator code - (c) Copyright 2003 - 2006 John Weidman, - Kris Bleakley, - Lancer, - z80 gaiden - - DSP-4 emulator code - (c) Copyright 2004 - 2006 Dreamer Nom, - John Weidman, - Kris Bleakley, - Nach, - z80 gaiden - - OBC1 emulator code - (c) Copyright 2001 - 2004 zsKnight, - pagefault (pagefault@zsnes.com), - Kris Bleakley - Ported from x86 assembler to C by sanmaiwashi - - SPC7110 and RTC C++ emulator code used in 1.39-1.51 - (c) Copyright 2002 Matthew Kendora with research by - zsKnight, - John Weidman, - Dark Force - - SPC7110 and RTC C++ emulator code used in 1.52+ - (c) Copyright 2009 byuu, - neviksti - - S-DD1 C emulator code - (c) Copyright 2003 Brad Jorsch with research by - Andreas Naive, - John Weidman - - S-RTC C emulator code - (c) Copyright 2001 - 2006 byuu, - John Weidman - - ST010 C++ emulator code - (c) Copyright 2003 Feather, - John Weidman, - Kris Bleakley, - Matthew Kendora - - Super FX x86 assembler emulator code - (c) Copyright 1998 - 2003 _Demo_, - pagefault, - zsKnight - - Super FX C emulator code - (c) Copyright 1997 - 1999 Ivar, - Gary Henderson, - John Weidman - - Sound emulator code used in 1.5-1.51 - (c) Copyright 1998 - 2003 Brad Martin - (c) Copyright 1998 - 2006 Charles Bilyue' - - Sound emulator code used in 1.52+ - (c) Copyright 2004 - 2007 Shay Green (gblargg@gmail.com) - - SH assembler code partly based on x86 assembler code - (c) Copyright 2002 - 2004 Marcus Comstedt (marcus@mc.pp.se) - - 2xSaI filter - (c) Copyright 1999 - 2001 Derek Liauw Kie Fa - - HQ2x, HQ3x, HQ4x filters - (c) Copyright 2003 Maxim Stepin (maxim@hiend3d.com) - - NTSC filter - (c) Copyright 2006 - 2007 Shay Green - - GTK+ GUI code - (c) Copyright 2004 - 2010 BearOso - - Win32 GUI code - (c) Copyright 2003 - 2006 blip, - funkyass, - Matthew Kendora, - Nach, - nitsuja - (c) Copyright 2009 - 2010 OV2 - - Mac OS GUI code - (c) Copyright 1998 - 2001 John Stiles - (c) Copyright 2001 - 2010 zones - - - Specific ports contains the works of other authors. See headers in - individual files. - - - Snes9x homepage: http://www.snes9x.com/ - - Permission to use, copy, modify and/or distribute Snes9x in both binary - and source form, for non-commercial purposes, is hereby granted without - fee, providing that this license information and copyright notice appear - with all copies and any derived work. - - This software is provided 'as-is', without any express or implied - warranty. In no event shall the authors be held liable for any damages - arising from the use of this software or it's derivatives. - - Snes9x is freeware for PERSONAL USE only. Commercial users should - seek permission of the copyright holders first. Commercial use includes, - but is not limited to, charging money for Snes9x or software derived from - Snes9x, including Snes9x or derivatives in commercial game bundles, and/or - using Snes9x as a promotion for your commercial product. - - The copyright holders request that bug fixes and improvements to the code - should be forwarded to them so everyone can benefit from the modifications - in future versions. - - Super NES and Super Nintendo Entertainment System are trademarks of - Nintendo Co., Limited and its subsidiary companies. - ***********************************************************************************/ - - -#include "snes9x.h" -#include "memmap.h" - -static uint8 region_map[6][6] = -{ - { 0, 0x01, 0x03, 0x07, 0x0f, 0x1f }, - { 0, 0, 0x02, 0x06, 0x0e, 0x1e }, - { 0, 0, 0, 0x04, 0x0c, 0x1c }, - { 0, 0, 0, 0, 0x08, 0x18 }, - { 0, 0, 0, 0, 0, 0x10 } -}; - -static inline uint8 CalcWindowMask (int, uint8, uint8); -static inline void StoreWindowRegions (uint8, ClipData *, int, int16 *, uint8 *, bool8, bool8 s = FALSE); - - -static inline uint8 CalcWindowMask (int i, uint8 W1, uint8 W2) -{ - if (!PPU.ClipWindow1Enable[i]) - { - if (!PPU.ClipWindow2Enable[i]) - return (0); - else - { - if (!PPU.ClipWindow2Inside[i]) - return (~W2); - return (W2); - } - } - else - { - if (!PPU.ClipWindow2Enable[i]) - { - if (!PPU.ClipWindow1Inside[i]) - return (~W1); - return (W1); - } - else - { - if (!PPU.ClipWindow1Inside[i]) - W1 = ~W1; - if (!PPU.ClipWindow2Inside[i]) - W2 = ~W2; - - switch (PPU.ClipWindowOverlapLogic[i]) - { - case 0: // OR - return (W1 | W2); - - case 1: // AND - return (W1 & W2); - - case 2: // XOR - return (W1 ^ W2); - - case 3: // XNOR - return (~(W1 ^ W2)); - } - } - } - - // Never get here - return (0); -} - -static inline void StoreWindowRegions (uint8 Mask, ClipData *Clip, int n_regions, int16 *windows, uint8 *drawing_modes, bool8 sub, bool8 StoreMode0) -{ - int ct = 0; - - for (int j = 0; j < n_regions; j++) - { - int DrawMode = drawing_modes[j]; - if (sub) - DrawMode |= 1; - if (Mask & (1 << j)) - DrawMode = 0; - - if (!StoreMode0 && !DrawMode) - continue; - - if (ct > 0 && Clip->Right[ct - 1] == windows[j] && Clip->DrawMode[ct - 1] == DrawMode) - Clip->Right[ct - 1] = windows[j + 1]; // This region borders with and has the same drawing mode as the previous region: merge them. - else - { - // Add a new region to the BG - Clip->Left[ct] = windows[j]; - Clip->Right[ct] = windows[j + 1]; - Clip->DrawMode[ct] = DrawMode; - ct++; - } - } - - Clip->Count = ct; -} - -void S9xComputeClipWindows (void) -{ - int16 windows[6] = { 0, 256, 256, 256, 256, 256 }; - uint8 drawing_modes[5] = { 0, 0, 0, 0, 0 }; - int n_regions = 1; - int i, j; - - // Calculate window regions. We have at most 5 regions, because we have 6 control points - // (screen edges, window 1 left & right, and window 2 left & right). - - if (PPU.Window1Left <= PPU.Window1Right) - { - if (PPU.Window1Left > 0) - { - windows[2] = 256; - windows[1] = PPU.Window1Left; - n_regions = 2; - } - - if (PPU.Window1Right < 255) - { - windows[n_regions + 1] = 256; - windows[n_regions] = PPU.Window1Right + 1; - n_regions++; - } - } - - if (PPU.Window2Left <= PPU.Window2Right) - { - for (i = 0; i <= n_regions; i++) - { - if (PPU.Window2Left == windows[i]) - break; - - if (PPU.Window2Left < windows[i]) - { - for (j = n_regions; j >= i; j--) - windows[j + 1] = windows[j]; - - windows[i] = PPU.Window2Left; - n_regions++; - break; - } - } - - for (; i <= n_regions; i++) - { - if (PPU.Window2Right + 1 == windows[i]) - break; - - if (PPU.Window2Right + 1 < windows[i]) - { - for (j = n_regions; j >= i; j--) - windows[j + 1] = windows[j]; - - windows[i] = PPU.Window2Right + 1; - n_regions++; - break; - } - } - } - - // Get a bitmap of which regions correspond to each window. - - uint8 W1, W2; - - if (PPU.Window1Left <= PPU.Window1Right) - { - for (i = 0; windows[i] != PPU.Window1Left; i++) ; - for (j = i; windows[j] != PPU.Window1Right + 1; j++) ; - W1 = region_map[i][j]; - } - else - W1 = 0; - - if (PPU.Window2Left <= PPU.Window2Right) - { - for (i = 0; windows[i] != PPU.Window2Left; i++) ; - for (j = i; windows[j] != PPU.Window2Right + 1; j++) ; - W2 = region_map[i][j]; - } - else - W2 = 0; - - // Color Window affects the drawing mode for each region. - // Modes are: 3=Draw as normal, 2=clip color (math only), 1=no math (draw only), 0=nothing. - - uint8 CW_color = 0, CW_math = 0; - uint8 CW = CalcWindowMask(5, W1, W2); - - switch (Memory.FillRAM[0x2130] & 0xc0) - { - case 0x00: CW_color = 0; break; - case 0x40: CW_color = ~CW; break; - case 0x80: CW_color = CW; break; - case 0xc0: CW_color = 0xff; break; - } - - switch (Memory.FillRAM[0x2130] & 0x30) - { - case 0x00: CW_math = 0; break; - case 0x10: CW_math = ~CW; break; - case 0x20: CW_math = CW; break; - case 0x30: CW_math = 0xff; break; - } - - for (i = 0; i < n_regions; i++) - { - if (!(CW_color & (1 << i))) - drawing_modes[i] |= 1; - if (!(CW_math & (1 << i))) - drawing_modes[i] |= 2; - } - - // Store backdrop clip window (draw everywhere color window allows) - - StoreWindowRegions(0, &IPPU.Clip[0][5], n_regions, windows, drawing_modes, FALSE, TRUE); - StoreWindowRegions(0, &IPPU.Clip[1][5], n_regions, windows, drawing_modes, TRUE, TRUE); - - // Store per-BG and OBJ clip windows - - for (j = 0; j < 5; j++) - { - uint8 W = Settings.DisableGraphicWindows ? 0 : CalcWindowMask(j, W1, W2); - for (int sub = 0; sub < 2; sub++) - { - if (Memory.FillRAM[sub + 0x212e] & (1 << j)) - StoreWindowRegions(W, &IPPU.Clip[sub][j], n_regions, windows, drawing_modes, sub); - else - StoreWindowRegions(0, &IPPU.Clip[sub][j], n_regions, windows, drawing_modes, sub); - } - } -} diff --git a/old/gfx16.cpp.last b/old/gfx16.cpp.last deleted file mode 100644 index 916d3dd..0000000 --- a/old/gfx16.cpp.last +++ /dev/null @@ -1,3183 +0,0 @@ -/* - * Snes9x - Portable Super Nintendo Entertainment System (TM) emulator. - * - * (c) Copyright 1996 - 2001 Gary Henderson (gary.henderson@ntlworld.com) and - * Jerremy Koot (jkoot@snes9x.com) - * - * Super FX C emulator code - * (c) Copyright 1997 - 1999 Ivar (ivar@snes9x.com) and - * Gary Henderson. - * Super FX assembler emulator code (c) Copyright 1998 zsKnight and _Demo_. - * - * DSP1 emulator code (c) Copyright 1998 Ivar, _Demo_ and Gary Henderson. - * C4 asm and some C emulation code (c) Copyright 2000 zsKnight and _Demo_. - * C4 C code (c) Copyright 2001 Gary Henderson (gary.henderson@ntlworld.com). - * - * DOS port code contains the works of other authors. See headers in - * individual files. - * - * Snes9x homepage: http://www.snes9x.com - * - * Permission to use, copy, modify and distribute Snes9x in both binary and - * source form, for non-commercial purposes, is hereby granted without fee, - * providing that this license information and copyright notice appear with - * all copies and any derived work. - * - * This software is provided 'as-is', without any express or implied - * warranty. In no event shall the authors be held liable for any damages - * arising from the use of this software. - * - * Snes9x is freeware for PERSONAL USE only. Commercial users should - * seek permission of the copyright holders first. Commercial use includes - * charging money for Snes9x or software derived from Snes9x. - * - * The copyright holders request that bug fixes and improvements to the code - * should be forwarded to them so everyone can benefit from the modifications - * in future versions. - * - * Super NES and Super Nintendo Entertainment System are trademarks of - * Nintendo Co., Limited and its subsidiary companies. - */ -#include "snes9x.h" - -#include "memmap.h" -#include "ppu.h" -#include "cpuexec.h" -#include "display.h" -#include "gfx.h" -#include "apu.h" -#include "cheats.h" -#include <stdint.h> -#include "asmmemfuncs.h" -#include "mode7.h" -#include "rops.h" -#include "tile16.h" -uint32 TileBlank; - -const int tx_table[16] = { -// t1 = 16, t2 = 0 - // FLIP = 0x00 - 16 + 0, // 0x00 - 16 + 1, // 0x01 - - // FLIP = 0x01 - 16 + 1 - 0, // 0x02 - 16 + 1 - 1, // 0x03 - - // FLIP = 0x02 - 0 + 0, // 0x04 - 0 + 1, // 0x05 - - // FLIP = 0x03 - 0 + 1 - 0, // 0x06 - 0 + 1 - 1, // 0x07 - -// t1 = 0, t2 = 16 - // FLIP = 0x00 - 0 + 0, // 0x08 - 0 + 1, // 0x09 - - // FLIP = 0x01 - 0 + 1 - 0, // 0x0A - 0 + 1 - 1, // 0x0B - - // FLIP = 0x02 - 16 + 0, // 0x0C - 16 + 1, // 0x0D - - // FLIP = 0x03 - 16 + 1 - 0, // 0x0E - 16 + 1 - 1 // 0x0F -}; - -#define M7 19 -#define M8 19 - -void ComputeClipWindows (); -static void S9xDisplayFrameRate (); -static void S9xDisplayString (const char *string); - -extern uint8 BitShifts[8][4]; -extern uint8 TileShifts[8][4]; -extern uint8 PaletteShifts[8][4]; -extern uint8 PaletteMasks[8][4]; -extern uint8 Depths[8][4]; -extern uint8 BGSizes [2]; - -extern NormalTileRenderer DrawTilePtr; -extern ClippedTileRenderer DrawClippedTilePtr; -extern NormalTileRenderer DrawHiResTilePtr; -extern ClippedTileRenderer DrawHiResClippedTilePtr; -extern LargePixelRenderer DrawLargePixelPtr; - -extern SBG BG; - -extern SLineData LineData[240]; -extern SLineMatrixData LineMatrixData [240]; - -extern uint8 Mode7Depths [2]; - -#define ON_MAIN(N) (GFX.r212c & (1 << (N))) - -#define SUB_OR_ADD(N) \ -(GFX.r2131 & (1 << (N))) - -#define ON_SUB(N) \ -((GFX.r2130 & 0x30) != 0x30 && \ - (GFX.r2130 & 2) && \ - (GFX.r212d & (1 << N))) - -#define ANYTHING_ON_SUB \ -((GFX.r2130 & 0x30) != 0x30 && \ - (GFX.r2130 & 2) && \ - (GFX.r212d & 0x1f)) - -#define ADD_OR_SUB_ON_ANYTHING \ -(GFX.r2131 & 0x3f) - -#define BLACK BUILD_PIXEL(0,0,0) - -void DrawNoZTile16 (uint32 Tile, uint32 Offset, uint32 StartLine, uint32 LineCount); -void DrawTile16 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); -void DrawClippedTile16 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); -void DrawTile16x2 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); -void DrawClippedTile16x2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); -void DrawTile16x2x2 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); -void DrawClippedTile16x2x2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); -void DrawLargePixel16 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Pixels, - uint32 StartLine, uint32 LineCount); - -void DrawNoZTile16Add (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - -void DrawTile16Add (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - -void DrawClippedTile16Add (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); - -void DrawNoZTile16Add1_2 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - -void DrawTile16Add1_2 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - -void DrawClippedTile16Add1_2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); - -void DrawTile16FixedAdd1_2 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - -void DrawClippedTile16FixedAdd1_2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); - -void DrawNoZTile16Sub (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - - -void DrawTile16Sub (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - -void DrawClippedTile16Sub (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); - -void DrawNoZTile16Sub1_2 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - - -void DrawTile16Sub1_2 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - -void DrawClippedTile16Sub1_2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); - -void DrawTile16FixedSub1_2 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - -void DrawClippedTile16FixedSub1_2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); - -void DrawLargePixel16Add (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Pixels, - uint32 StartLine, uint32 LineCount); - -void DrawLargePixel16Add1_2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Pixels, - uint32 StartLine, uint32 LineCount); - -void DrawLargePixel16Sub (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Pixels, - uint32 StartLine, uint32 LineCount); - -void DrawLargePixel16Sub1_2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Pixels, - uint32 StartLine, uint32 LineCount); - -void DrawHiResClippedTile16 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); - -void DrawHiResTile16 (uint32 Tile, uint32 Offset, - uint32 StartLine, uint32 LineCount); - -bool8_32 S9xGraphicsInit () -{ - register uint32 PixelOdd = 1; - register uint32 PixelEven = 2; - -#ifdef GFX_MULTI_FORMAT - if (GFX.BuildPixel == NULL) - S9xSetRenderPixelFormat (RGB565); -#endif - - for (uint8 bitshift = 0; bitshift < 4; bitshift++) - { - for (register int i = 0; i < 16; i++) - { - register uint32 h = 0; - register uint32 l = 0; - -#if defined(MSB_FIRST) - if (i & 8) - h |= (PixelOdd << 24); - if (i & 4) - h |= (PixelOdd << 16); - if (i & 2) - h |= (PixelOdd << 8); - if (i & 1) - h |= PixelOdd; - if (i & 8) - l |= (PixelOdd << 24); - if (i & 4) - l |= (PixelOdd << 16); - if (i & 2) - l |= (PixelOdd << 8); - if (i & 1) - l |= PixelOdd; -#else -// Wiz usa - if (i & 8) - h |= PixelOdd; - if (i & 4) - h |= PixelOdd << 8; - if (i & 2) - h |= PixelOdd << 16; - if (i & 1) - h |= PixelOdd << 24; - if (i & 8) - l |= PixelOdd; - if (i & 4) - l |= PixelOdd << 8; - if (i & 2) - l |= PixelOdd << 16; - if (i & 1) - l |= PixelOdd << 24; -#endif - - odd_high[bitshift][i] = h; - odd_low[bitshift][i] = l; - h = l = 0; - -#if defined(MSB_FIRST) - if (i & 8) - h |= (PixelEven << 24); - if (i & 4) - h |= (PixelEven << 16); - if (i & 2) - h |= (PixelEven << 8); - if (i & 1) - h |= PixelEven; - if (i & 8) - l |= (PixelEven << 24); - if (i & 4) - l |= (PixelEven << 16); - if (i & 2) - l |= (PixelEven << 8); - if (i & 1) - l |= PixelEven; -#else - if (i & 8) - h |= PixelEven; - if (i & 4) - h |= PixelEven << 8; - if (i & 2) - h |= PixelEven << 16; - if (i & 1) - h |= PixelEven << 24; - if (i & 8) - l |= PixelEven; - if (i & 4) - l |= PixelEven << 8; - if (i & 2) - l |= PixelEven << 16; - if (i & 1) - l |= PixelEven << 24; -#endif - - even_high[bitshift][i] = h; - even_low[bitshift][i] = l; - } - PixelEven <<= 2; - PixelOdd <<= 2; - } - - GFX.Delta = (GFX.SubScreen - GFX.Screen) >> 1; - GFX.DepthDelta = GFX.SubZBuffer - GFX.ZBuffer; - //GFX.InfoStringTimeout = 0; - //GFX.InfoString = NULL; - - PPU.BG_Forced = 0; - IPPU.OBJChanged = TRUE; - - IPPU.DirectColourMapsNeedRebuild = TRUE; - DrawTilePtr = DrawTile16; - DrawClippedTilePtr = DrawClippedTile16; - DrawLargePixelPtr = DrawLargePixel16; - DrawHiResTilePtr= DrawHiResTile16; - DrawHiResClippedTilePtr = DrawHiResClippedTile16; - S9xFixColourBrightness (); - - if (!(GFX.X2 = (uint16 *) malloc (sizeof (uint16) * 0x10000))) - return (FALSE); - - if (!(GFX.ZERO_OR_X2 = (uint16 *) malloc (sizeof (uint16) * 0x10000)) || - !(GFX.ZERO = (uint16 *) malloc (sizeof (uint16) * 0x10000))) - { - if (GFX.ZERO_OR_X2) - { - free ((char *) GFX.ZERO_OR_X2); - GFX.ZERO_OR_X2 = NULL; - } - if (GFX.X2) - { - free ((char *) GFX.X2); - GFX.X2 = NULL; - } - return (FALSE); - } - uint32 r, g, b; - - // Build a lookup table that multiplies a packed RGB value by 2 with - // saturation. - for (r = 0; r <= MAX_RED; r++) - { - uint32 r2 = r << 1; - if (r2 > MAX_RED) - r2 = MAX_RED; - for (g = 0; g <= MAX_GREEN; g++) - { - uint32 g2 = g << 1; - if (g2 > MAX_GREEN) - g2 = MAX_GREEN; - for (b = 0; b <= MAX_BLUE; b++) - { - uint32 b2 = b << 1; - if (b2 > MAX_BLUE) - b2 = MAX_BLUE; - GFX.X2 [BUILD_PIXEL2 (r, g, b)] = BUILD_PIXEL2 (r2, g2, b2); - GFX.X2 [BUILD_PIXEL2 (r, g, b) & ~ALPHA_BITS_MASK] = BUILD_PIXEL2 (r2, g2, b2); - } - } - } - ZeroMemory (GFX.ZERO, 0x10000 * sizeof (uint16)); - ZeroMemory (GFX.ZERO_OR_X2, 0x10000 * sizeof (uint16)); - // Build a lookup table that if the top bit of the color value is zero - // then the value is zero, otherwise multiply the value by 2. Used by - // the color subtraction code. - -#if defined(OLD_COLOUR_BLENDING) - for (r = 0; r <= MAX_RED; r++) - { - uint32 r2 = r; - if ((r2 & 0x10) == 0) - r2 = 0; - else - r2 = (r2 << 1) & MAX_RED; - - for (g = 0; g <= MAX_GREEN; g++) - { - uint32 g2 = g; - if ((g2 & GREEN_HI_BIT) == 0) - g2 = 0; - else - g2 = (g2 << 1) & MAX_GREEN; - - for (b = 0; b <= MAX_BLUE; b++) - { - uint32 b2 = b; - if ((b2 & 0x10) == 0) - b2 = 0; - else - b2 = (b2 << 1) & MAX_BLUE; - - GFX.ZERO_OR_X2 [BUILD_PIXEL2 (r, g, b)] = BUILD_PIXEL2 (r2, g2, b2); - GFX.ZERO_OR_X2 [BUILD_PIXEL2 (r, g, b) & ~ALPHA_BITS_MASK] = BUILD_PIXEL2 (r2, g2, b2); - } - } - } -#else - for (r = 0; r <= MAX_RED; r++) - { - uint32 r2 = r; - if ((r2 & 0x10) == 0) - r2 = 0; - else - r2 = (r2 << 1) & MAX_RED; - - if (r2 == 0) - r2 = 1; - for (g = 0; g <= MAX_GREEN; g++) - { - uint32 g2 = g; - if ((g2 & GREEN_HI_BIT) == 0) - g2 = 0; - else - g2 = (g2 << 1) & MAX_GREEN; - - if (g2 == 0) - g2 = 1; - for (b = 0; b <= MAX_BLUE; b++) - { - uint32 b2 = b; - if ((b2 & 0x10) == 0) - b2 = 0; - else - b2 = (b2 << 1) & MAX_BLUE; - - if (b2 == 0) - b2 = 1; - GFX.ZERO_OR_X2 [BUILD_PIXEL2 (r, g, b)] = BUILD_PIXEL2 (r2, g2, b2); - GFX.ZERO_OR_X2 [BUILD_PIXEL2 (r, g, b) & ~ALPHA_BITS_MASK] = BUILD_PIXEL2 (r2, g2, b2); - } - } - } -#endif - - // Build a lookup table that if the top bit of the color value is zero - // then the value is zero, otherwise its just the value. - for (r = 0; r <= MAX_RED; r++) - { - uint32 r2 = r; - if ((r2 & 0x10) == 0) - r2 = 0; - else - r2 &= ~0x10; - - for (g = 0; g <= MAX_GREEN; g++) - { - uint32 g2 = g; - if ((g2 & GREEN_HI_BIT) == 0) - g2 = 0; - else - g2 &= ~GREEN_HI_BIT; - for (b = 0; b <= MAX_BLUE; b++) - { - uint32 b2 = b; - if ((b2 & 0x10) == 0) - b2 = 0; - else - b2 &= ~0x10; - - GFX.ZERO [BUILD_PIXEL2 (r, g, b)] = BUILD_PIXEL2 (r2, g2, b2); - GFX.ZERO [BUILD_PIXEL2 (r, g, b) & ~ALPHA_BITS_MASK] = BUILD_PIXEL2 (r2, g2, b2); - } - } - } - - return (TRUE); -} - -void S9xGraphicsDeinit (void) -{ - // Free any memory allocated in S9xGraphicsInit - if (GFX.X2) - { - free ((char *) GFX.X2); - GFX.X2 = NULL; - } - if (GFX.ZERO_OR_X2) - { - free ((char *) GFX.ZERO_OR_X2); - GFX.ZERO_OR_X2 = NULL; - } - if (GFX.ZERO) - { - free ((char *) GFX.ZERO); - GFX.ZERO = NULL; - } -} - -void S9xBuildDirectColourMaps () -{ - for (uint32 p = 0; p < 8; p++) - { - for (uint32 c = 0; c < 256; c++) - { -// XXX: Brightness - DirectColourMaps [p][c] = BUILD_PIXEL (((c & 7) << 2) | ((p & 1) << 1), - ((c & 0x38) >> 1) | (p & 2), - ((c & 0xc0) >> 3) | (p & 4)); - } - } - IPPU.DirectColourMapsNeedRebuild = FALSE; -} - -void S9xStartScreenRefresh () -{ - if (IPPU.RenderThisFrame) - { - if (!S9xInitUpdate ()) - { - IPPU.RenderThisFrame = FALSE; - return; - } - IPPU.RenderedFramesCount++; - IPPU.PreviousLine = IPPU.CurrentLine = 0; - IPPU.MaxBrightness = PPU.Brightness; - IPPU.LatchedBlanking = PPU.ForcedBlanking; - IPPU.LatchedInterlace = (Memory.FillRAM[0x2133] & 1); - IPPU.RenderedScreenWidth = 256; - IPPU.RenderedScreenHeight = PPU.ScreenHeight; - IPPU.DoubleWidthPixels = FALSE; - - PPU.RecomputeClipWindows = TRUE; - GFX.DepthDelta = GFX.SubZBuffer - GFX.ZBuffer; - GFX.Delta = (GFX.SubScreen - GFX.Screen) >> 1; - - } - if (++IPPU.FrameCount % Memory.ROMFramesPerSecond == 0) - { - IPPU.DisplayedRenderedFrameCount = IPPU.RenderedFramesCount; - IPPU.RenderedFramesCount = 0; - IPPU.FrameCount = 0; - } -} - -void RenderLine (uint8 C) -{ - if (IPPU.RenderThisFrame) - { - - LineData[C].BG[0].VOffset = PPU.BG[0].VOffset + 1; - LineData[C].BG[0].HOffset = PPU.BG[0].HOffset; - LineData[C].BG[1].VOffset = PPU.BG[1].VOffset + 1; - LineData[C].BG[1].HOffset = PPU.BG[1].HOffset; - - if (PPU.BGMode == 7) - { - SLineMatrixData *p = &LineMatrixData [C]; - p->MatrixA = PPU.MatrixA; - p->MatrixB = PPU.MatrixB; - p->MatrixC = PPU.MatrixC; - p->MatrixD = PPU.MatrixD; - p->CentreX = PPU.CentreX; - p->CentreY = PPU.CentreY; - } - else - { - if (Settings.StarfoxHack && PPU.BG[2].VOffset == 0 && - PPU.BG[2].HOffset == 0xe000) - { - LineData[C].BG[2].VOffset = 0xe1; - LineData[C].BG[2].HOffset = 0; - } - else - { - LineData[C].BG[2].VOffset = PPU.BG[2].VOffset + 1; - LineData[C].BG[2].HOffset = PPU.BG[2].HOffset; - LineData[C].BG[3].VOffset = PPU.BG[3].VOffset + 1; - LineData[C].BG[3].HOffset = PPU.BG[3].HOffset; - } - - } - IPPU.CurrentLine = C + 1; - } -} - - -void S9xEndScreenRefresh() -{ - IPPU.HDMAStarted = FALSE; - -//RC - if (IPPU.RenderThisFrame) - { - FLUSH_REDRAW (); - //if (IPPU.ColorsChanged) - //{ - IPPU.ColorsChanged = FALSE; - //} - - - S9xDeinitUpdate (IPPU.RenderedScreenWidth, IPPU.RenderedScreenHeight, - 1); - } -#ifndef RC_OPTIMIZED - S9xApplyCheats (); -#endif - - -#ifdef DEBUGGER - if (CPU.Flags & FRAME_ADVANCE_FLAG) - { - if (ICPU.FrameAdvanceCount) - { - ICPU.FrameAdvanceCount--; - IPPU.RenderThisFrame = TRUE; - IPPU.FrameSkip = 0; - } - else - { - CPU.Flags &= ~FRAME_ADVANCE_FLAG; - CPU.Flags |= DEBUG_MODE_FLAG; - } - } -#endif - -/* - if (CPU.SRAMModified) - { - if (!CPU.AutoSaveTimer) - { - if (!(CPU.AutoSaveTimer = Settings.AutoSaveDelay * Memory.ROMFramesPerSecond)) - CPU.SRAMModified = FALSE; - } - else - { - if (!--CPU.AutoSaveTimer) - { - S9xAutoSaveSRAM (); - CPU.SRAMModified = FALSE; - } - } - } -*/ -} - -void S9xSetInfoString (const char *string) -{ - } - - - -int TileRenderer; -TileRendererSet TileRenderers[] = { - {DrawTile16Add, DrawClippedTile16Add, DrawLargePixel16Add}, // 0 -> GFX.r2131:7 = 0, GFX.r2131:6 = 0, GFX.r2130:1 = 0 - {DrawTile16Add, DrawClippedTile16Add, DrawLargePixel16Add}, // 1 -> GFX.r2131:7 = 0, GFX.r2131:6 = 0, GFX.r2130:1 = 1 - {DrawTile16FixedAdd1_2, DrawClippedTile16FixedAdd1_2, DrawLargePixel16Add1_2}, // 2 -> GFX.r2131:7 = 0, GFX.r2131:6 = 1, GFX.r2130:1 = 0 - {DrawTile16Add1_2, DrawClippedTile16Add1_2, DrawLargePixel16Add1_2}, // 3 -> GFX.r2131:7 = 0, GFX.r2131:6 = 1, GFX.r2130:1 = 1 - {DrawTile16Sub, DrawClippedTile16Sub, DrawLargePixel16Sub}, // 4 -> GFX.r2131:7 = 1, GFX.r2131:6 = 0, GFX.r2130:1 = 0 - {DrawTile16Sub, DrawClippedTile16Sub, DrawLargePixel16Sub}, // 5 -> GFX.r2131:7 = 1, GFX.r2131:6 = 0, GFX.r2130:1 = 1 - {DrawTile16FixedSub1_2, DrawClippedTile16FixedSub1_2, DrawLargePixel16Sub1_2}, // 6 -> GFX.r2131:7 = 1, GFX.r2131:6 = 1, GFX.r2130:1 = 0 - {DrawTile16Sub1_2, DrawClippedTile16Sub1_2, DrawLargePixel16Sub1_2}, // 7 -> GFX.r2131:7 = 1, GFX.r2131:6 = 1, GFX.r2130:1 = 1 - {DrawTile16, DrawClippedTile16, DrawLargePixel16} // 8 -> normal - }; -TileRendererSet TileRenderersNoZ[] = { - {DrawNoZTile16Add, DrawClippedTile16Add, DrawLargePixel16Add}, // 0 -> GFX.r2131:7 = 0, GFX.r2131:6 = 0, GFX.r2130:1 = 0 - {DrawNoZTile16Add, DrawClippedTile16Add, DrawLargePixel16Add}, // 1 -> GFX.r2131:7 = 0, GFX.r2131:6 = 0, GFX.r2130:1 = 1 - {DrawTile16FixedAdd1_2, DrawClippedTile16FixedAdd1_2, DrawLargePixel16Add1_2}, // 2 -> GFX.r2131:7 = 0, GFX.r2131:6 = 1, GFX.r2130:1 = 0 - {DrawNoZTile16Add1_2, DrawClippedTile16Add1_2, DrawLargePixel16Add1_2}, // 3 -> GFX.r2131:7 = 0, GFX.r2131:6 = 1, GFX.r2130:1 = 1 - {DrawNoZTile16Sub, DrawClippedTile16Sub, DrawLargePixel16Sub}, // 4 -> GFX.r2131:7 = 1, GFX.r2131:6 = 0, GFX.r2130:1 = 0 - {DrawNoZTile16Sub, DrawClippedTile16Sub, DrawLargePixel16Sub}, // 5 -> GFX.r2131:7 = 1, GFX.r2131:6 = 0, GFX.r2130:1 = 1 - {DrawTile16FixedSub1_2, DrawClippedTile16FixedSub1_2, DrawLargePixel16Sub1_2}, // 6 -> GFX.r2131:7 = 1, GFX.r2131:6 = 1, GFX.r2130:1 = 0 - {DrawNoZTile16Sub1_2, DrawClippedTile16Sub1_2, DrawLargePixel16Sub1_2}, // 7 -> GFX.r2131:7 = 1, GFX.r2131:6 = 1, GFX.r2130:1 = 1 - {DrawNoZTile16, DrawClippedTile16, DrawLargePixel16} // 8 -> normal - }; -static INLINE void SelectTileRenderer (bool8_32 normal, bool NoZ = false) -{ - if (normal) { - TileRenderer = 8; - } - else { - TileRenderer = (((GFX.r2131 >> 5) & 0x06) | ((GFX.r2130 >> 1) & 1)); - } - -#ifdef __DEBUG__ - char *TRName[] = { - "Add", "Add", "FixedAdd1_2", "Add1_2", - "Sub", "Sub", "FixedSub1_2", "Sub1_2", - "Normal" - }; - printf("SelectTileRenderer: %s\n", TRName[TileRenderer]); -#endif - - if (NoZ) { - DrawTilePtr = TileRenderersNoZ[TileRenderer].Normal; - DrawClippedTilePtr = TileRenderersNoZ[TileRenderer].Clipped; - DrawLargePixelPtr = TileRenderersNoZ[TileRenderer].Large; - } - else { - DrawTilePtr = TileRenderers[TileRenderer].Normal; - DrawClippedTilePtr = TileRenderers[TileRenderer].Clipped; - DrawLargePixelPtr = TileRenderers[TileRenderer].Large; - } -} - -void S9xSetupOBJ () -{ - int SmallSize; - int LargeSize; - - switch (PPU.OBJSizeSelect) - { - case 0: - SmallSize = 8; - LargeSize = 16; - break; - case 1: - SmallSize = 8; - LargeSize = 32; - break; - case 2: - SmallSize = 8; - LargeSize = 64; - break; - case 3: - SmallSize = 16; - LargeSize = 32; - break; - case 4: - SmallSize = 16; - LargeSize = 64; - break; - case 5: - default: - SmallSize = 32; - LargeSize = 64; - break; - } - - int C = 0; - - int FirstSprite = PPU.FirstSprite & 0x7f; - int S = FirstSprite; - do - { - int Size; - if (PPU.OBJ [S].Size) - Size = LargeSize; - else - Size = SmallSize; - - long VPos = PPU.OBJ [S].VPos; - - if (VPos >= PPU.ScreenHeight) - VPos -= 256; - if (PPU.OBJ [S].HPos < 256 && PPU.OBJ [S].HPos > -Size && - VPos < PPU.ScreenHeight && VPos > -Size) - { - int x = 0; - int a, b; - //GFX.OBJList[C++] = S; - // -- Sort objects (from low to high priority) - while (x < C) { - a = GFX.OBJList[x]; - if (PPU.OBJ[a].Priority >= PPU.OBJ[S].Priority) break; - x++; - } - - GFX.OBJList[x] = S; - x++; C++; - - while (x < C) { - b = GFX.OBJList[x]; - GFX.OBJList[x] = a; - a = b; - x++; - } - // -- - GFX.Sizes[S] = Size; - GFX.VPositions[S] = VPos; - } - S = (S + 1) & 0x7f; - } while (S != FirstSprite); - - // Terminate the list - GFX.OBJList [C] = -1; - IPPU.OBJChanged = FALSE; -} - -void DrawOBJS (bool8_32 OnMain = FALSE, uint8 D = 0) -{ - int bg_ta_ns; - int bg_ta; - uint32 O; - uint32 BaseTile, Tile; - - CHECK_SOUND(); - - BG.BitShift = 4; - SelectConvertTile(); - BG.TileShift = 5; - //BG.TileAddress = PPU.OBJNameBase; - BG.StartPalette = 128; - BG.PaletteShift = 4; - BG.PaletteMask = 7; - BG.Buffer = IPPU.TileCache [TILE_4BIT]; - BG.Buffered = IPPU.TileCached [TILE_4BIT]; - //BG.NameSelect = PPU.OBJNameSelect; - BG.DirectColourMode = FALSE; - - SelectPalette(); - bg_ta = PPU.OBJNameBase; - bg_ta_ns = bg_ta + PPU.OBJNameSelect; - - GFX.Z1 = D + 2; - - int I = 0; - for (int S = GFX.OBJList [I++]; S >= 0; S = GFX.OBJList [I++]) - { - int VPos = GFX.VPositions [S]; - int Size = GFX.Sizes[S]; - int TileInc = 1; - int Offset; - - if (VPos + Size <= (int) GFX.StartY || VPos > (int) GFX.EndY) - continue; - - if (OnMain && SUB_OR_ADD(4)) - { - SelectTileRenderer (!GFX.Pseudo && PPU.OBJ [S].Palette < 4, true); - } - - BaseTile = PPU.OBJ[S].Name | (PPU.OBJ[S].Palette << 10); - - if (PPU.OBJ[S].HFlip) - { - BaseTile += ((Size >> 3) - 1) | H_FLIP; - TileInc = -1; - } - - if (PPU.OBJ[S].VFlip) BaseTile |= V_FLIP; - //BaseTile |= PPU.OBJ[S].VFlip << 15; - - int clipcount = GFX.pCurrentClip->Count [4]; - if (!clipcount) clipcount = 1; - - GFX.Z2 = (PPU.OBJ[S].Priority + 1) * 4 + D; - - for (int clip = 0; clip < clipcount; clip++) - { - int Left; - int Right; - if (!GFX.pCurrentClip->Count [4]) - { - Left = 0; - Right = 256; - } - else - { - Left = GFX.pCurrentClip->Left [clip][4]; - Right = GFX.pCurrentClip->Right [clip][4]; - } - - if (Right <= Left || PPU.OBJ[S].HPos + Size <= Left || - PPU.OBJ[S].HPos >= Right) - continue; - - for (int Y = 0; Y < Size; Y += 8) - { - if (VPos + Y + 7 >= (int) GFX.StartY && VPos + Y <= (int) GFX.EndY) - { - int StartLine; - int TileLine; - int LineCount; - int Last; - - if ((StartLine = VPos + Y) < (int) GFX.StartY) - { - StartLine = GFX.StartY - StartLine; - LineCount = 8 - StartLine; - } - else - { - StartLine = 0; - LineCount = 8; - } - if ((Last = VPos + Y + 7 - GFX.EndY) > 0) - if ((LineCount -= Last) <= 0) - break; - - TileLine = StartLine << 3; - - O = (VPos + Y + StartLine) * GFX_PPL; - if (!PPU.OBJ[S].VFlip) Tile = BaseTile + (Y << 1); - else Tile = BaseTile + ((Size - Y - 8) << 1); - - if (Tile & 0x100) BG.TileAddress = bg_ta_ns; - else BG.TileAddress = bg_ta; - - int Middle = Size >> 3; - if (PPU.OBJ[S].HPos < Left) - { - Tile += ((Left - PPU.OBJ[S].HPos) >> 3) * TileInc; - Middle -= (Left - PPU.OBJ[S].HPos) >> 3; - O += Left * GFX_PIXSIZE; - if ((Offset = (Left - PPU.OBJ[S].HPos) & 7)) - { - O -= Offset * GFX_PIXSIZE; - int W = 8 - Offset; - int Width = Right - Left; - if (W > Width) W = Width; - //if (Tile & 0x100) BG.TileAddress = bg_ta_ns; - //else BG.TileAddress = bg_ta; - (*DrawClippedTilePtr) (Tile, O, Offset, W, TileLine, LineCount); - - if (W >= Width) - continue; - Tile += TileInc; - Middle--; - O += 8 * GFX_PIXSIZE; - } - } - else - O += PPU.OBJ[S].HPos * GFX_PIXSIZE; - - if (PPU.OBJ[S].HPos + Size >= Right) - { - Middle -= ((PPU.OBJ[S].HPos + Size + 7) - - Right) >> 3; - Offset = (Right - (PPU.OBJ[S].HPos + Size)) & 7; - } - else - Offset = 0; - - for (int X = 0; X < Middle; X++, O += 8 * GFX_PIXSIZE, - Tile += TileInc) - { - //if (Tile & 0x100) BG.TileAddress = bg_ta_ns; - //else BG.TileAddress = bg_ta; - (*DrawTilePtr) (Tile, O, TileLine, LineCount); - } - if (Offset) - { - //if (Tile & 0x100) BG.TileAddress = bg_ta_ns; - //else BG.TileAddress = bg_ta; - (*DrawClippedTilePtr) (Tile, O, 0, Offset, TileLine, LineCount); - } - } - } - } - } -} -void DrawBackgroundMosaic (uint32 BGMode, uint32 bg, uint8 Z1, uint8 Z2) -{ -#ifdef __DEBUG__ - printf("DrawBackgroundMosaic(%i, %i, %i, %i)\n", BGMode, bg, Z1, Z2); -#endif - CHECK_SOUND(); - - uint32 Tile; - uint16 *SC0; - uint16 *SC1; - uint16 *SC2; - uint16 *SC3; - uint8 depths [2] = {Z1, Z2}; - - if (BGMode == 0) - BG.StartPalette = bg << 5; - else - BG.StartPalette = 0; - SelectPalette(); - - SC0 = (uint16 *) &Memory.VRAM[PPU.BG[bg].SCBase << 1]; - - if (PPU.BG[bg].SCSize & 1) - SC1 = SC0 + 1024; - else - SC1 = SC0; - - if(((uint8*)SC1-Memory.VRAM)>=0x10000) - SC1-=0x08000; - - - if (PPU.BG[bg].SCSize & 2) - SC2 = SC1 + 1024; - else - SC2 = SC0; - - if(((uint8*)SC2-Memory.VRAM)>=0x10000) - SC2-=0x08000; - - - if (PPU.BG[bg].SCSize & 1) - SC3 = SC2 + 1024; - else - SC3 = SC2; - - if(((uint8*)SC3-Memory.VRAM)>=0x10000) - SC3-=0x08000; - - uint32 Lines; - uint32 OffsetMask; - uint32 OffsetShift; - - if (BG.TileSize == 16) - { - OffsetMask = 0x3ff; - OffsetShift = 4; - } - else - { - OffsetMask = 0x1ff; - OffsetShift = 3; - } - - for (uint32 Y = GFX.StartY; Y <= GFX.EndY; Y += Lines) - { - uint32 VOffset = LineData [Y].BG[bg].VOffset; - uint32 HOffset = LineData [Y].BG[bg].HOffset; - uint32 MosaicOffset = Y % PPU.Mosaic; - - for (Lines = 1; Lines < PPU.Mosaic - MosaicOffset; Lines++) - if ((VOffset != LineData [Y + Lines].BG[bg].VOffset) || - (HOffset != LineData [Y + Lines].BG[bg].HOffset)) - break; - - uint32 MosaicLine = VOffset + Y - MosaicOffset; - - if (Y + Lines > GFX.EndY) - Lines = GFX.EndY + 1 - Y; - uint32 VirtAlign = (MosaicLine & 7) << 3; - - uint16 *b1; - uint16 *b2; - - uint32 ScreenLine = MosaicLine >> OffsetShift; - uint32 Rem16 = MosaicLine & 15; - - if (ScreenLine & 0x20) - b1 = SC2, b2 = SC3; - else - b1 = SC0, b2 = SC1; - - b1 += (ScreenLine & 0x1f) << 5; - b2 += (ScreenLine & 0x1f) << 5; - uint16 *t; - uint32 Left = 0; - uint32 Right = 256; - - uint32 ClipCount = GFX.pCurrentClip->Count [bg]; - uint32 HPos = HOffset; - uint32 PixWidth = PPU.Mosaic; - - if (!ClipCount) - ClipCount = 1; - - for (uint32 clip = 0; clip < ClipCount; clip++) - { - if (GFX.pCurrentClip->Count [bg]) - { - Left = GFX.pCurrentClip->Left [clip][bg]; - Right = GFX.pCurrentClip->Right [clip][bg]; - uint32 r = Left % PPU.Mosaic; - HPos = HOffset + Left; - PixWidth = PPU.Mosaic - r; - } - uint32 s = Y * GFX_PPL + Left * GFX_PIXSIZE; - for (uint32 x = Left; x < Right; x += PixWidth, - s += PixWidth * GFX_PIXSIZE, - HPos += PixWidth, PixWidth = PPU.Mosaic) - { - uint32 Quot = (HPos & OffsetMask) >> 3; - - if (x + PixWidth >= Right) - PixWidth = Right - x; - - if (BG.TileSize == 8) - { - if (Quot > 31) - t = b2 + (Quot & 0x1f); - else - t = b1 + Quot; - } - else - { - if (Quot > 63) - t = b2 + ((Quot >> 1) & 0x1f); - else - t = b1 + (Quot >> 1); - } - - Tile = READ_2BYTES (t); - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - - // Draw tile... - if (BG.TileSize != 8) - { - if (Tile & H_FLIP) - { - // Horizontal flip, but what about vertical flip ? - if (Tile & V_FLIP) - { - // Both horzontal & vertical flip - if (Rem16 < 8) - { - (*DrawLargePixelPtr) (Tile + 17 - (Quot & 1), s, - HPos & 7, PixWidth, - VirtAlign, Lines); - } - else - { - (*DrawLargePixelPtr) (Tile + 1 - (Quot & 1), s, - HPos & 7, PixWidth, - VirtAlign, Lines); - } - } - else - { - // Horizontal flip only - if (Rem16 > 7) - { - (*DrawLargePixelPtr) (Tile + 17 - (Quot & 1), s, - HPos & 7, PixWidth, - VirtAlign, Lines); - } - else - { - (*DrawLargePixelPtr) (Tile + 1 - (Quot & 1), s, - HPos & 7, PixWidth, - VirtAlign, Lines); - } - } - } - else - { - // No horizontal flip, but is there a vertical flip ? - if (Tile & V_FLIP) - { - // Vertical flip only - if (Rem16 < 8) - { - (*DrawLargePixelPtr) (Tile + 16 + (Quot & 1), s, - HPos & 7, PixWidth, - VirtAlign, Lines); - } - else - { - (*DrawLargePixelPtr) (Tile + (Quot & 1), s, - HPos & 7, PixWidth, - VirtAlign, Lines); - } - } - else - { - // Normal unflipped - if (Rem16 > 7) - { - (*DrawLargePixelPtr) (Tile + 16 + (Quot & 1), s, - HPos & 7, PixWidth, - VirtAlign, Lines); - } - else - { - (*DrawLargePixelPtr) (Tile + (Quot & 1), s, - HPos & 7, PixWidth, - VirtAlign, Lines); - } - } - } - } - else - (*DrawLargePixelPtr) (Tile, s, HPos & 7, PixWidth, - VirtAlign, Lines); - } - } - } -} - -void DrawBackgroundOffset (uint32 BGMode, uint32 bg, uint8 Z1, uint8 Z2) -{ -#ifdef __DEBUG__ - printf("DrawBackgroundOffse(%i, %i, %i, %i)\n", BGMode, bg, Z1, Z2); -#endif - - CHECK_SOUND(); - - uint32 Tile; - uint16 *SC0; - uint16 *SC1; - uint16 *SC2; - uint16 *SC3; - uint16 *BPS0; - uint16 *BPS1; - uint16 *BPS2; - uint16 *BPS3; - uint32 Width; - int VOffsetOffset = BGMode == 4 ? 0 : 32; - uint8 depths [2] = {Z1, Z2}; - - BG.StartPalette = 0; - SelectPalette(); - - BPS0 = (uint16 *) &Memory.VRAM[PPU.BG[2].SCBase << 1]; - - if (PPU.BG[2].SCSize & 1) - BPS1 = BPS0 + 1024; - else - BPS1 = BPS0; - - if (PPU.BG[2].SCSize & 2) - BPS2 = BPS1 + 1024; - else - BPS2 = BPS0; - - if (PPU.BG[2].SCSize & 1) - BPS3 = BPS2 + 1024; - else - BPS3 = BPS2; - - SC0 = (uint16 *) &Memory.VRAM[PPU.BG[bg].SCBase << 1]; - - if (PPU.BG[bg].SCSize & 1) - SC1 = SC0 + 1024; - else - SC1 = SC0; - - if(((uint8*)SC1-Memory.VRAM)>=0x10000) - SC1-=0x08000; - - - if (PPU.BG[bg].SCSize & 2) - SC2 = SC1 + 1024; - else - SC2 = SC0; - - if(((uint8*)SC2-Memory.VRAM)>=0x10000) - SC2-=0x08000; - - - if (PPU.BG[bg].SCSize & 1) - SC3 = SC2 + 1024; - else - SC3 = SC2; - - if(((uint8*)SC3-Memory.VRAM)>=0x10000) - SC3-=0x08000; - - static const int Lines = 1; - int OffsetMask; - int OffsetShift; - int OffsetEnableMask = 1 << (bg + 13); - - if (BG.TileSize == 16) - { - OffsetMask = 0x3ff; - OffsetShift = 4; - } - else - { - OffsetMask = 0x1ff; - OffsetShift = 3; - } - - TileBlank = 0xFFFFFFFF; - for (uint32 Y = GFX.StartY; Y <= GFX.EndY; Y++) - { - uint32 VOff = LineData [Y].BG[2].VOffset - 1; - uint32 HOff = LineData [Y].BG[2].HOffset; - int VirtAlign; - int ScreenLine = VOff >> 3; - uint16 *s0; - uint16 *s1; - uint16 *s2; - - if (ScreenLine & 0x20) - s1 = BPS2, s2 = BPS3; - else - s1 = BPS0, s2 = BPS1; - - s1 += (ScreenLine & 0x1f) << 5; - s2 += (ScreenLine & 0x1f) << 5; - - if(BGMode != 4) - { - if((ScreenLine & 0x1f) == 0x1f) - { - if(ScreenLine & 0x20) - VOffsetOffset = BPS0 - BPS2 - 0x1f*32; - else - VOffsetOffset = BPS2 - BPS0 - 0x1f*32; - } - else - { - VOffsetOffset = 32; - } - } - int clipcount = GFX.pCurrentClip->Count [bg]; - if (!clipcount) - clipcount = 1; - - for (int clip = 0; clip < clipcount; clip++) - { - uint32 Left; - uint32 Right; - - if (!GFX.pCurrentClip->Count [bg]) - { - Left = 0; - Right = 256; - } - else - { - Left = GFX.pCurrentClip->Left [clip][bg]; - Right = GFX.pCurrentClip->Right [clip][bg]; - - if (Right <= Left) - continue; - } - - uint32 VOffset; - uint32 HOffset; - uint32 LineHOffset=LineData [Y].BG[bg].HOffset; - uint32 Offset; - uint32 HPos; - uint32 Quot; - uint32 Count; - uint16 *t; - uint32 Quot2; - uint32 VCellOffset; - uint32 HCellOffset; - uint16 *b1; - uint16 *b2; - uint32 TotalCount = 0; - uint32 MaxCount = 8; - - uint32 s = Left * GFX_PIXSIZE + Y * GFX_PPL; - bool8_32 left_hand_edge = (Left == 0); - Width = Right - Left; - - if (Left & 7) - MaxCount = 8 - (Left & 7); - - while (Left < Right) - { - if (left_hand_edge) - { - // The SNES offset-per-tile background mode has a - // hardware limitation that the offsets cannot be set - // for the tile at the left-hand edge of the screen. - VOffset = LineData [Y].BG[bg].VOffset; - HOffset = LineHOffset; - left_hand_edge = FALSE; - } - else - { - // All subsequent offset tile data is shifted left by one, - // hence the - 1 below. - Quot2 = ((HOff + Left - 1) & OffsetMask) >> 3; - - if (Quot2 > 31) - s0 = s2 + (Quot2 & 0x1f); - else - s0 = s1 + Quot2; - - HCellOffset = READ_2BYTES (s0); - - if (BGMode == 4) - { - VOffset = LineData [Y].BG[bg].VOffset; - HOffset=LineHOffset; - if ((HCellOffset & OffsetEnableMask)) - { - if (HCellOffset & 0x8000) - VOffset = HCellOffset + 1; - else - HOffset = HCellOffset; - } - } - else - { - VCellOffset = READ_2BYTES (s0 + VOffsetOffset); - if ((VCellOffset & OffsetEnableMask)) - VOffset = VCellOffset + 1; - else - VOffset = LineData [Y].BG[bg].VOffset; - - if ((HCellOffset & OffsetEnableMask)) - HOffset = (HCellOffset & ~7)|(LineHOffset&7); - else - HOffset=LineHOffset; - } - } - VirtAlign = ((Y + VOffset) & 7) << 3; - ScreenLine = (VOffset + Y) >> OffsetShift; - - int tx_index; - tx_index = ( ((VOffset + Y) & 15) <= 7 ) << 3; - - if (ScreenLine & 0x20) - b1 = SC2, b2 = SC3; - else - b1 = SC0, b2 = SC1; - - b1 += (ScreenLine & 0x1f) << 5; - b2 += (ScreenLine & 0x1f) << 5; - - HPos = (HOffset + Left) & OffsetMask; - - Quot = HPos >> 3; - - if (BG.TileSize == 8) - { - if (Quot > 31) - t = b2 + (Quot & 0x1f); - else - t = b1 + Quot; - } - else - { - if (Quot > 63) - t = b2 + ((Quot >> 1) & 0x1f); - else - t = b1 + (Quot >> 1); - } - - if (MaxCount + TotalCount > Width) - MaxCount = Width - TotalCount; - - Offset = HPos & 7; - - Count = 8 - Offset; - if (Count > MaxCount) - Count = MaxCount; - - s -= Offset * GFX_PIXSIZE; - Tile = READ_2BYTES(t); - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - - if (Tile != TileBlank) - if (BG.TileSize == 8) - (*DrawClippedTilePtr) (Tile, s, Offset, Count, VirtAlign, Lines); - else - { - Tile += tx_table[tx_index + ((Tile & (H_FLIP | V_FLIP)) >> 13) + (Quot & 1)]; - if (Tile != TileBlank){ - (*DrawClippedTilePtr) (Tile, s, Offset, Count, VirtAlign, Lines); - } - } - - Left += Count; - TotalCount += Count; - s += (Offset + Count) * GFX_PIXSIZE; - MaxCount = 8; - } - } - } -} - -void DrawBackgroundMode5 (uint32 /* BGMODE */, uint32 bg, uint8 Z1, uint8 Z2) -{ -#ifdef __DEBUG__ - printf("DrawBackgroundMode5(?, %i, %i, %i)\n", bg, Z1, Z2); -#endif - - CHECK_SOUND(); - - uint8 depths [2] = {Z1, Z2}; - - uint32 Tile; - uint16 *SC0; - uint16 *SC1; - uint16 *SC2; - uint16 *SC3; - uint32 Width; - - BG.StartPalette = 0; - SelectPalette(); - - SC0 = (uint16 *) &Memory.VRAM[PPU.BG[bg].SCBase << 1]; - - if ((PPU.BG[bg].SCSize & 1)) - SC1 = SC0 + 1024; - else - SC1 = SC0; - - if((SC1-(unsigned short*)Memory.VRAM)>0x10000) - SC1=(uint16*)&Memory.VRAM[(((uint8*)SC1)-Memory.VRAM)%0x10000]; - - if ((PPU.BG[bg].SCSize & 2)) - SC2 = SC1 + 1024; - else SC2 = SC0; - - if(((uint8*)SC2-Memory.VRAM)>=0x10000) - SC2-=0x08000; - - if ((PPU.BG[bg].SCSize & 1)) - SC3 = SC2 + 1024; - else - SC3 = SC2; - - if(((uint8*)SC3-Memory.VRAM)>=0x10000) - SC3-=0x08000; - int Lines; - int VOffsetMask; - int VOffsetShift; - - if (BG.TileSize == 16) - { - VOffsetMask = 0x3ff; - VOffsetShift = 4; - } - else - { - VOffsetMask = 0x1ff; - VOffsetShift = 3; - } - int endy = GFX.EndY; - - for (int Y = GFX.StartY; Y <= endy; Y += Lines) - { - //int y = Y; - uint32 VOffset = LineData [Y].BG[bg].VOffset; - uint32 HOffset = LineData [Y].BG[bg].HOffset; - int VirtAlign = (Y + VOffset) & 7; - - for (Lines = 1; Lines < 8 - VirtAlign; Lines++) - if ((VOffset != LineData [Y + Lines].BG[bg].VOffset) || - (HOffset != LineData [Y + Lines].BG[bg].HOffset)) - break; - - HOffset <<= 1; - if (Y + Lines > endy) - Lines = endy + 1 - Y; - - int ScreenLine = (VOffset + Y) >> VOffsetShift; - int t1; - int t2; - if (((VOffset + Y) & 15) > 7) - { - t1 = 16; - t2 = 0; - } - else - { - t1 = 0; - t2 = 16; - } - uint16 *b1; - uint16 *b2; - - if (ScreenLine & 0x20) - b1 = SC2, b2 = SC3; - else - b1 = SC0, b2 = SC1; - - b1 += (ScreenLine & 0x1f) << 5; - b2 += (ScreenLine & 0x1f) << 5; - - int clipcount = GFX.pCurrentClip->Count [bg]; - if (!clipcount) - clipcount = 1; - for (int clip = 0; clip < clipcount; clip++) - { - int Left; - int Right; - - if (!GFX.pCurrentClip->Count [bg]) - { - Left = 0; - Right = 512; - } - else - { - Left = GFX.pCurrentClip->Left [clip][bg] * 2; - Right = GFX.pCurrentClip->Right [clip][bg] * 2; - - if (Right <= Left) - continue; - } - - uint32 s = (Left>>1) * GFX_PIXSIZE + Y * GFX_PPL; - uint32 HPos = (HOffset + Left * GFX_PIXSIZE) & 0x3ff; - - uint32 Quot = HPos >> 3; - uint32 Count = 0; - - uint16 *t; - if (Quot > 63) - t = b2 + ((Quot >> 1) & 0x1f); - else - t = b1 + (Quot >> 1); - - Width = Right - Left; - // Left hand edge clipped tile - if (HPos & 7) - { - int Offset = (HPos & 7); - Count = 8 - Offset; - if (Count > Width) - Count = Width; - s -= (Offset>>1); - Tile = READ_2BYTES (t); - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - - if (BG.TileSize == 8) - { - if (!(Tile & H_FLIP)) - { - // Normal, unflipped - (*DrawHiResClippedTilePtr) (Tile + (Quot & 1), - s, Offset, Count, VirtAlign, Lines); - } - else - { - // H flip - (*DrawHiResClippedTilePtr) (Tile + 1 - (Quot & 1), - s, Offset, Count, VirtAlign, Lines); - } - } - else - { - if (!(Tile & (V_FLIP | H_FLIP))) - { - // Normal, unflipped - (*DrawHiResClippedTilePtr) (Tile + t1 + (Quot & 1), - s, Offset, Count, VirtAlign, Lines); - } - else - if (Tile & H_FLIP) - { - if (Tile & V_FLIP) - { - // H & V flip - (*DrawHiResClippedTilePtr) (Tile + t2 + 1 - (Quot & 1), - s, Offset, Count, VirtAlign, Lines); - } - else - { - // H flip only - (*DrawHiResClippedTilePtr) (Tile + t1 + 1 - (Quot & 1), - s, Offset, Count, VirtAlign, Lines); - } - } - else - { - // V flip only - (*DrawHiResClippedTilePtr) (Tile + t2 + (Quot & 1), - s, Offset, Count, VirtAlign, Lines); - } - } - - t += Quot & 1; - if (Quot == 63) - t = b2; - else if (Quot == 127) - t = b1; - Quot++; - s += 4; - } - - // Middle, unclipped tiles - Count = Width - Count; - int Middle = Count >> 3; - Count &= 7; - for (int C = Middle; C > 0; s += 4, Quot++, C--) - { - Tile = READ_2BYTES(t); - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - if (BG.TileSize == 8) - { - if (!(Tile & H_FLIP)) - { - // Normal, unflipped - (*DrawHiResTilePtr) (Tile + (Quot & 1), - s, VirtAlign, Lines); - } - else - { - // H flip - (*DrawHiResTilePtr) (Tile + 1 - (Quot & 1), - s, VirtAlign, Lines); - } - } - else - { - if (!(Tile & (V_FLIP | H_FLIP))) - { - // Normal, unflipped - (*DrawHiResTilePtr) (Tile + t1 + (Quot & 1), - s, VirtAlign, Lines); - } - else - if (Tile & H_FLIP) - { - if (Tile & V_FLIP) - { - // H & V flip - (*DrawHiResTilePtr) (Tile + t2 + 1 - (Quot & 1), - s, VirtAlign, Lines); - } - else - { - // H flip only - (*DrawHiResTilePtr) (Tile + t1 + 1 - (Quot & 1), - s, VirtAlign, Lines); - } - } - else - { - // V flip only - (*DrawHiResTilePtr) (Tile + t2 + (Quot & 1), - s, VirtAlign, Lines); - } - } - - t += Quot & 1; - if (Quot == 63) - t = b2; - else - if (Quot == 127) - t = b1; - } - - // Right-hand edge clipped tiles - if (Count) - { - Tile = READ_2BYTES(t); - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - if (BG.TileSize == 8) - { - if (!(Tile & H_FLIP)) - { - // Normal, unflipped - (*DrawHiResClippedTilePtr) (Tile + (Quot & 1), - s, 0, Count, VirtAlign, Lines); - } - else - { - // H flip - (*DrawHiResClippedTilePtr) (Tile + 1 - (Quot & 1), - s, 0, Count, VirtAlign, Lines); - } - } - else - { - if (!(Tile & (V_FLIP | H_FLIP))) - { - // Normal, unflipped - (*DrawHiResClippedTilePtr) (Tile + t1 + (Quot & 1), - s, 0, Count, VirtAlign, Lines); - } - else - if (Tile & H_FLIP) - { - if (Tile & V_FLIP) - { - // H & V flip - (*DrawHiResClippedTilePtr) (Tile + t2 + 1 - (Quot & 1), - s, 0, Count, VirtAlign, Lines); - } - else - { - // H flip only - (*DrawHiResClippedTilePtr) (Tile + t1 + 1 - (Quot & 1), - s, 0, Count, VirtAlign, Lines); - } - } - else - { - // V flip only - (*DrawHiResClippedTilePtr) (Tile + t2 + (Quot & 1), - s, 0, Count, VirtAlign, Lines); - } - } - } - } - } -} - -void DrawBackground_8(uint32 BGMode, uint32 bg, uint8 Z1, uint8 Z2) -{ -#ifdef __DEBUG__ - printf("DrawBackground_8(%i, %i, %i, %i)\n", BGMode, bg, Z1, Z2); -#endif - //uint32 Tile; - uint16 *SC0; - uint16 *SC1; - uint16 *SC2; - uint16 *SC3; - uint32 depths [2] = {Z1, Z2}; - - SC0 = (uint16 *) &Memory.VRAM[PPU.BG[bg].SCBase << 1]; - - SC1 = SC0 + ((PPU.BG[bg].SCSize & 1) << 10); - - if(SC1 >= (unsigned short*)(Memory.VRAM+0x10000)) SC1 = (uint16*)&Memory.VRAM[((uint8*)SC1-&Memory.VRAM[0]) & 0xffff]; - - if (PPU.BG[bg].SCSize & 2) - SC2 = SC1 + 1024; - else - SC2 = SC0; - - if(((uint8*)SC2-Memory.VRAM)>=0x10000) SC2 -= 0x08000; - - SC3 = SC2 + ((PPU.BG[bg].SCSize & 1) << 10); - - if(((uint8*)SC3-Memory.VRAM)>=0x10000) SC3 -= 0x08000; - - int Lines; - - TileBlank = 0xFFFFFFFF; - for (uint32 Y = GFX.StartY; Y <= GFX.EndY; Y += Lines){ - int y_ppl = Y * GFX_PPL; - uint32 VOffset = LineData [Y].BG[bg].VOffset; - uint32 HOffset = LineData [Y].BG[bg].HOffset; - int VirtAlign = (Y + VOffset) & 7; - - int maxLines = GFX.EndY - Y + 1; - if ((8 - VirtAlign) < maxLines) maxLines = (8 - VirtAlign); - - for (Lines = 1; Lines < maxLines; Lines++) - if ((VOffset != LineData [Y + Lines].BG[bg].VOffset) || - (HOffset != LineData [Y + Lines].BG[bg].HOffset)) - break; - - - VirtAlign <<= 3; - - uint32 ScreenLine = (VOffset + Y) >> 3; - uint16 *b1; - uint16 *b2; - - if (ScreenLine & 0x20) - b1 = SC2, b2 = SC3; - else - b1 = SC0, b2 = SC1; - - b1 += (ScreenLine & 0x1f) << 5; - b2 += (ScreenLine & 0x1f) << 5; - - uint32 Left; - uint32 Right; - int clip = 0; - int clipcount = GFX.pCurrentClip->Count [bg]; - if (!clipcount) { - Left = 0; - Right = 256; - } - - do { - if (clipcount) { - Left = GFX.pCurrentClip->Left [clip][bg]; - Right = GFX.pCurrentClip->Right [clip][bg]; - - if (Right <= Left) {clip++; continue;} - } - - uint32 s = Left + y_ppl; - uint32 HPos = (HOffset + Left) & 0x1ff; - uint32 Quot = HPos >> 3; - uint32 Count = 0; - uint16 *t; - uint16 *b; - - if (Quot > 31) { - t = b2 + (Quot & 0x1f); - b = b1; - Quot -= 32; - } - else { - t = b1 + Quot; - b = b2; - } - - uint32 Width = Right - Left; - - // Left hand edge clipped tile - uint32 Offset = (HPos & 7); - if (Offset){ - Count = 8 - Offset; - if (Count > Width) Count = Width; - s -= Offset; - //Tile = READ_2BYTES(t); - register uint32 Tile = *(t++); - if (Tile != TileBlank){ - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - (*DrawClippedTilePtr) (Tile, s, Offset, Count, VirtAlign, Lines); - } - //t++; - if (Quot == 31) t = b; - //else if (Quot == 63) t = b1; - Quot++; - s += 8; - } - - // Middle, unclipped tiles - Count = Width - Count; - for (int C = Count >> 3; C > 0; s += 8, Quot++, C--){ - //Tile = READ_2BYTES(t); - register uint32 Tile = *(t++); - if (Tile != TileBlank){ - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - (*DrawTilePtr) (Tile, s, VirtAlign, Lines); - } - - //t++; - if (Quot == 31) t = b; - //else if (Quot == 63) t = b1; - } - - // Right-hand edge clipped tiles - if (Count & 7){ - //Tile = READ_2BYTES(t); - register uint32 Tile = *t; - if (Tile != TileBlank){ - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - (*DrawClippedTilePtr) (Tile, s, 0, Count & 7, VirtAlign, Lines); - } - } - clip ++; - } while (clip < clipcount); - } -} - -void DrawBackground_16 (uint32 BGMode, uint32 bg, uint8 Z1, uint8 Z2) -{ -#ifdef __DEBUG__ - printf("DrawBackground_16(%i, %i, %i, %i)\n", BGMode, bg, Z1, Z2); -#endif - //uint32 Tile; - uint16 *SC0; - uint16 *SC1; - uint16 *SC2; - uint16 *SC3; - uint32 depths [2] = {Z1, Z2}; - - SC0 = (uint16 *) &Memory.VRAM[PPU.BG[bg].SCBase << 1]; - - SC1 = SC0 + ((PPU.BG[bg].SCSize & 1) << 10); - - if(SC1 >= (unsigned short*)(Memory.VRAM+0x10000)) SC1 = (uint16*)&Memory.VRAM[((uint8*)SC1-&Memory.VRAM[0]) & 0xffff]; - - if (PPU.BG[bg].SCSize & 2) - SC2 = SC1 + 1024; - else - SC2 = SC0; - - if(((uint8*)SC2-Memory.VRAM)>=0x10000) SC2 -= 0x08000; - - SC3 = SC2 + ((PPU.BG[bg].SCSize & 1) << 10); - - if(((uint8*)SC3-Memory.VRAM)>=0x10000) SC3 -= 0x08000; - - int Lines; - - TileBlank = 0xFFFFFFFF; - for (uint32 Y = GFX.StartY; Y <= GFX.EndY; Y += Lines){ - int y_ppl = Y * GFX_PPL; - uint32 VOffset = LineData [Y].BG[bg].VOffset; - uint32 HOffset = LineData [Y].BG[bg].HOffset; - int VirtAlign = (Y + VOffset) & 7; - - int maxLines = GFX.EndY - Y + 1; - if ((8 - VirtAlign) < maxLines) maxLines = (8 - VirtAlign); - - for (Lines = 1; Lines < maxLines; Lines++) - if ((VOffset != LineData [Y + Lines].BG[bg].VOffset) || - (HOffset != LineData [Y + Lines].BG[bg].HOffset)) - break; - - - VirtAlign <<= 3; - - uint32 ScreenLine = (VOffset + Y) >> 4; - int tx_index = ( ((VOffset + Y) & 15) <= 7 ) << 3; - uint16 *b1; - uint16 *b2; - - if (ScreenLine & 0x20) - b1 = SC2, b2 = SC3; - else - b1 = SC0, b2 = SC1; - - b1 += (ScreenLine & 0x1f) << 5; - b2 += (ScreenLine & 0x1f) << 5; - - uint32 Left; - uint32 Right; - int clip = 0; - int clipcount = GFX.pCurrentClip->Count [bg]; - if (!clipcount) { - Left = 0; - Right = 256; - } - - do { - if (clipcount) { - Left = GFX.pCurrentClip->Left [clip][bg]; - Right = GFX.pCurrentClip->Right [clip][bg]; - - if (Right <= Left) {clip++; continue;} - } - - uint32 s = Left + y_ppl; - uint32 HPos = (HOffset + Left) & 0x3ff; - uint32 Quot = HPos >> 3; - uint32 Count = 0; - uint16 *t; - uint16 *b; - - if (Quot > 63) { - t = b2 + ((Quot >> 1) & 0x1f); - b = b1; - Quot -= 64; - } - else { - t = b1 + (Quot >> 1); - b = b2; - } - - - uint32 Width = Right - Left; - - // Left hand edge clipped tile - uint32 Offset = (HPos & 7); - if (Offset){ - Count = 8 - Offset; - if (Count > Width) Count = Width; - s -= Offset; - //Tile = READ_2BYTES(t); - uint32 Tile = *(t); - Tile += tx_table[tx_index + ((Tile & (H_FLIP | V_FLIP)) >> 13) + (Quot & 1)]; - if (Tile != TileBlank){ - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - (*DrawClippedTilePtr) (Tile, s, Offset, Count, VirtAlign, Lines); - } - //t++; - t += Quot & 1; - if (Quot == 63) t = b; - Quot++; - s += 8; - } - - // Middle, unclipped tiles - Count = Width - Count; - for (int C = Count >> 3; C > 0; s += 8, Quot++, C--){ - //Tile = READ_2BYTES(t); - uint32 Tile = *(t); - Tile += tx_table[tx_index + ((Tile & (H_FLIP | V_FLIP)) >> 13) + (Quot & 1)]; - if (Tile != TileBlank){ - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - //(*DrawTilePtr) (Tile, s, VirtAlign, Lines); - } - - //t++; - t += Quot & 1; - if (Quot == 63) t = b; - } - - // Right-hand edge clipped tiles - if (Count & 7){ - //Tile = READ_2BYTES(t); - uint32 Tile = *(t); - Tile += tx_table[tx_index + ((Tile & (H_FLIP | V_FLIP)) >> 13) + (Quot & 1)]; - if (Tile != TileBlank){ - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - (*DrawClippedTilePtr) (Tile, s, 0, Count & 7, VirtAlign, Lines); - } - } - clip ++; - } while (clip < clipcount); - } -} - - -inline void DrawBackground (uint32 BGMode, uint32 bg, uint8 Z1, uint8 Z2) -{ -//StartAnalyze(); - - BG.TileSize = BGSizes [PPU.BG[bg].BGSize]; - BG.BitShift = BitShifts[BGMode][bg]; - SelectConvertTile(); - BG.TileShift = TileShifts[BGMode][bg]; - BG.TileAddress = PPU.BG[bg].NameBase << 1; - BG.NameSelect = 0; - BG.Buffer = IPPU.TileCache [Depths [BGMode][bg]]; - BG.Buffered = IPPU.TileCached [Depths [BGMode][bg]]; - BG.PaletteShift = PaletteShifts[BGMode][bg]; - BG.PaletteMask = PaletteMasks[BGMode][bg]; - BG.DirectColourMode = (BGMode == 3 || BGMode == 4) && bg == 0 && (GFX.r2130 & 1); - - if (IPPU.DirectColourMapsNeedRebuild && BG.DirectColourMode) S9xBuildDirectColourMaps (); - - if (PPU.BGMosaic [bg] && PPU.Mosaic > 1){ - DrawBackgroundMosaic (BGMode, bg, Z1, Z2); - return; - - } - switch (BGMode) - { - case 2: - case 4: // Used by Puzzle Bobble - DrawBackgroundOffset (BGMode, bg, Z1, Z2); - break; - - case 5: - case 6: // XXX: is also offset per tile. - DrawBackgroundMode5 (BGMode, bg, Z1, Z2); - break; - case 0: - case 1: - case 3: - CHECK_SOUND(); - - if (BGMode == 0) BG.StartPalette = bg << 5; - else BG.StartPalette = 0; - SelectPalette(); - - if (BG.TileSize == 8) DrawBackground_8 (BGMode, bg, Z1, Z2); - else DrawBackground_16 (BGMode, bg, Z1, Z2); - break; - } -} - -#define _BUILD_SETUP(F) \ -GFX.BuildPixel = BuildPixel##F; \ -GFX.BuildPixel2 = BuildPixel2##F; \ -GFX.DecomposePixel = DecomposePixel##F; \ -RED_LOW_BIT_MASK = RED_LOW_BIT_MASK_##F; \ -GREEN_LOW_BIT_MASK = GREEN_LOW_BIT_MASK_##F; \ -BLUE_LOW_BIT_MASK = BLUE_LOW_BIT_MASK_##F; \ -RED_HI_BIT_MASK = RED_HI_BIT_MASK_##F; \ -GREEN_HI_BIT_MASK = GREEN_HI_BIT_MASK_##F; \ -BLUE_HI_BIT_MASK = BLUE_HI_BIT_MASK_##F; \ -MAX_RED = MAX_RED_##F; \ -MAX_GREEN = MAX_GREEN_##F; \ -MAX_BLUE = MAX_BLUE_##F; \ -GREEN_HI_BIT = ((MAX_GREEN_##F + 1) >> 1); \ -SPARE_RGB_BIT_MASK = SPARE_RGB_BIT_MASK_##F; \ -RGB_LOW_BITS_MASK = (RED_LOW_BIT_MASK_##F | \ - GREEN_LOW_BIT_MASK_##F | \ - BLUE_LOW_BIT_MASK_##F); \ -RGB_HI_BITS_MASK = (RED_HI_BIT_MASK_##F | \ - GREEN_HI_BIT_MASK_##F | \ - BLUE_HI_BIT_MASK_##F); \ -RGB_HI_BITS_MASKx2 = ((RED_HI_BIT_MASK_##F | \ - GREEN_HI_BIT_MASK_##F | \ - BLUE_HI_BIT_MASK_##F) << 1); \ -RGB_REMOVE_LOW_BITS_MASK = ~RGB_LOW_BITS_MASK; \ -FIRST_COLOR_MASK = FIRST_COLOR_MASK_##F; \ -SECOND_COLOR_MASK = SECOND_COLOR_MASK_##F; \ -THIRD_COLOR_MASK = THIRD_COLOR_MASK_##F; \ -ALPHA_BITS_MASK = ALPHA_BITS_MASK_##F; \ -FIRST_THIRD_COLOR_MASK = FIRST_COLOR_MASK | THIRD_COLOR_MASK; \ -TWO_LOW_BITS_MASK = RGB_LOW_BITS_MASK | (RGB_LOW_BITS_MASK << 1); \ -HIGH_BITS_SHIFTED_TWO_MASK = (( (FIRST_COLOR_MASK | SECOND_COLOR_MASK | THIRD_COLOR_MASK) & \ - ~TWO_LOW_BITS_MASK ) >> 2); - -void RenderScreen (uint8 *Screen, bool8_32 sub, bool8_32 force_no_add, uint8 D) -{ - bool8_32 BG0; - bool8_32 BG1; - bool8_32 BG2; - bool8_32 BG3; - bool8_32 OB; - - GFX.S = Screen; - - if (!sub) - { - GFX.pCurrentClip = &IPPU.Clip [0]; - BG0 = ON_MAIN (0) && !(Settings.os9x_hack & GFX_IGNORE_BG0); - BG1 = ON_MAIN (1) && !(Settings.os9x_hack & GFX_IGNORE_BG1); - BG2 = ON_MAIN (2) && !(Settings.os9x_hack & GFX_IGNORE_BG2); - BG3 = ON_MAIN (3) && !(Settings.os9x_hack & GFX_IGNORE_BG3); - OB = ON_MAIN (4) && !(Settings.os9x_hack & GFX_IGNORE_OBJ); - } - else - { - GFX.pCurrentClip = &IPPU.Clip [1]; - BG0 = ON_SUB (0) && !(Settings.os9x_hack & GFX_IGNORE_BG0); - BG1 = ON_SUB (1) && !(Settings.os9x_hack & GFX_IGNORE_BG1); - BG2 = ON_SUB (2) && !(Settings.os9x_hack & GFX_IGNORE_BG2); - BG3 = ON_SUB (3) && !(Settings.os9x_hack & GFX_IGNORE_BG3); - OB = ON_SUB (4) && !(Settings.os9x_hack & GFX_IGNORE_OBJ); - } - -#ifdef __DEBUG__ - printf("Screen[y1,y2]:[%i,%i],Mode:%i, BG0:%i,BG1:%i,BG2:%i,BG3:%i,OBJ:%i\n", GFX.StartY, GFX.EndY, PPU.BGMode, BG0, BG1, BG2, BG3, OB); -#endif - - sub |= force_no_add; - - if (PPU.BGMode <= 1) - { - if (OB) - { - SelectTileRenderer (sub || !SUB_OR_ADD(4), true); - DrawOBJS (!sub, D); - } - if (BG0) - { - SelectTileRenderer (sub || !SUB_OR_ADD(0), false); - DrawBackground (PPU.BGMode, 0, D + 10, D + 14); - } - if (BG1) - { - SelectTileRenderer (sub || !SUB_OR_ADD(1), false); - DrawBackground (PPU.BGMode, 1, D + 9, D + 13); - } - if (BG2) - { - SelectTileRenderer (sub || !SUB_OR_ADD(2), false); - DrawBackground (PPU.BGMode, 2, D + 3, - PPU.BG3Priority ? D + 17 : D + 6); - } - if (BG3 && PPU.BGMode == 0) - { - SelectTileRenderer (sub || !SUB_OR_ADD(3), false); - DrawBackground (PPU.BGMode, 3, D + 2, D + 5); - } - } - else if (PPU.BGMode != 7) - { - if (OB) - { - SelectTileRenderer (sub || !SUB_OR_ADD(4), true); - DrawOBJS (!sub, D); - } - if (BG0) - { - SelectTileRenderer (sub || !SUB_OR_ADD(0), false); - DrawBackground (PPU.BGMode, 0, D + 5, D + 13); - } - if (PPU.BGMode != 6 && BG1) - { - SelectTileRenderer (sub || !SUB_OR_ADD(1), false); - DrawBackground (PPU.BGMode, 1, D + 2, D + 9); - } - } - else - { - if (OB && ((SNESGameFixes.Mode7Hack && D) || !SNESGameFixes.Mode7Hack)) - { - SelectTileRenderer (sub || !SUB_OR_ADD(4), true); - DrawOBJS (!sub, D); - } - if (BG0 || ((Memory.FillRAM [0x2133] & 0x40) && BG1)) - { - int bg; - - if ((Memory.FillRAM [0x2133] & 0x40)&&BG1) - { - Mode7Depths [0] = (BG0?5:1) + D; - Mode7Depths [1] = 9 + D; - bg = 1; - if (sub || !SUB_OR_ADD(0)) - { - DrawBGMode7Background16Prio (Screen, bg); - } - else - { - if (GFX.r2131 & 0x80) - { - if (GFX.r2131 & 0x40) - { - DrawBGMode7Background16PrioSub1_2 (Screen, bg); - } - else - { - DrawBGMode7Background16PrioSub (Screen, bg); - } - } - else - { - if (GFX.r2131 & 0x40) - { - DrawBGMode7Background16PrioAdd1_2 (Screen, bg); - } - else - { - DrawBGMode7Background16PrioAdd (Screen, bg); - } - } - } - } - else - { - bg = 0; - if (sub || !SUB_OR_ADD(0)) - { - if (D || !SNESGameFixes.Mode7Hack) DrawBGMode7Background16 (Screen, bg, D+5); - else DrawBGMode7Background16New (Screen); - } - else - { - if (GFX.r2131 & 0x80) - { - if (GFX.r2131 & 0x40) - { - DrawBGMode7Background16Sub1_2 (Screen, bg, D+5); - } - else - { - DrawBGMode7Background16Sub (Screen, bg, D+5); - } - } - else - { - if (GFX.r2131 & 0x40) - { - DrawBGMode7Background16Add1_2 (Screen, bg, D+5); - } - else - { - DrawBGMode7Background16Add (Screen, bg, D+5); - } - } - } - } - } - if (OB && SNESGameFixes.Mode7Hack && D==0) - { - SelectTileRenderer (sub || !SUB_OR_ADD(4), true); - DrawOBJS (!sub, D); - } - } -} - -#include "font.h" - -void DisplayChar (uint8 *Screen, uint8 c) -{ - int line = (((c & 0x7f) - 32) >> 4) * font_height; - int offset = (((c & 0x7f) - 32) & 15) * font_width; - int h, w; - uint16 *s = (uint16 *) Screen; - for (h = 0; h < font_height; h++, line++, - s += GFX_PPL - font_width) - { - for (w = 0; w < font_width; w++, s++) - { - uint8 p = font [line][offset + w]; - - if (p == '#') - *s = 0xffff; - else - if (p == '.') - *s = BLACK; - } - } -} - -static void S9xDisplayFrameRate () -{ - uint8 *Screen = GFX.Screen + 2 + - (IPPU.RenderedScreenHeight - font_height - 1) * GFX_PITCH; - char string [10]; - int len = 5; - - sprintf (string, "%02d/%02d", IPPU.DisplayedRenderedFrameCount, - (int) Memory.ROMFramesPerSecond); - - int i; - for (i = 0; i < len; i++) - { - DisplayChar (Screen, string [i]); - Screen += (font_width - 1) * sizeof (uint16); - } -} - -static void S9xDisplayString (const char *string) -{ - uint8 *Screen = GFX.Screen + 2 + - (IPPU.RenderedScreenHeight - font_height * 5) * GFX_PITCH; - int len = strlen (string); - int max_chars = IPPU.RenderedScreenWidth / (font_width - 1); - int char_count = 0; - int i; - - for (i = 0; i < len; i++, char_count++) - { - if (char_count >= max_chars || string [i] < 32) - { - Screen -= (font_width - 1) * sizeof (uint16) * max_chars; - Screen += font_height * GFX_PITCH; - if (Screen >= GFX.Screen + GFX_PITCH * IPPU.RenderedScreenHeight) - break; - char_count -= max_chars; - } - if (string [i] < 32) - continue; - DisplayChar (Screen, string [i]); - Screen += (font_width - 1) * sizeof (uint16); - } -} - - -void S9xUpdateScreen () // ~30-50ms! (called from FLUSH_REDRAW()) -{ - GFX.S = GFX.Screen; - - unsigned char *memoryfillram = Memory.FillRAM; - - // get local copies of vid registers to be used later - GFX.r2131 = memoryfillram [0x2131]; // ADDITION/SUBTRACTION & SUBTRACTION DESIGNATION FOR EACH SCREEN - GFX.r212c = memoryfillram [0x212c]; // MAIN SCREEN, DESIGNATION - used to enable BGS - GFX.r212d = memoryfillram [0x212d]; // SUB SCREEN DESIGNATION - used to enable sub BGS - GFX.r2130 = memoryfillram [0x2130]; // INITIAL SETTINGS FOR FIXED COLOR ADDITION OR SCREEN ADDITION - - // If external sync is off and - // main screens have not been configured the same as the sub screen and - // color addition and subtraction has been diabled then - // Pseudo is 1 - // anything else it is 0 - GFX.Pseudo = (memoryfillram [0x2133] & 8) != 0 && // Use EXTERNAL SYNCHRONIZATION? - (GFX.r212c & 15) != (GFX.r212d & 15) && // Are the main screens different from the sub screens? - (GFX.r2131 & 0x3f) == 0; // Is colour data addition/subtraction disabled on all BGS? - - // If sprite data has been changed then go through and - // refresh the sprites. - if (IPPU.OBJChanged) S9xSetupOBJ (); - - if (PPU.RecomputeClipWindows) ComputeClipWindows (); - - GFX.StartY = IPPU.PreviousLine; - if ((GFX.EndY = IPPU.CurrentLine - 1) >= PPU.ScreenHeight) - GFX.EndY = PPU.ScreenHeight - 1; - - uint32 starty = GFX.StartY; - uint32 endy = GFX.EndY; - uint32 black = BLACK | (BLACK << 16); - - - if (GFX.Pseudo) - { - GFX.r2131 = 0x5f; //0101 1111 - enable addition/subtraction on all BGS and sprites and "1/2 OF COLOR DATA" DESIGNATION - GFX.r212c &= (Memory.FillRAM [0x212d] | 0xf0); - GFX.r212d |= (Memory.FillRAM [0x212c] & 0x0f); - GFX.r2130 |= 2; // enable ADDITION/SUBTRACTION FOR SUB SCREEN - } - - // Check to see if any transparency effects are currently in use - if (!PPU.ForcedBlanking && ADD_OR_SUB_ON_ANYTHING && - (GFX.r2130 & 0x30) != 0x30 && - !((GFX.r2130 & 0x30) == 0x10 && IPPU.Clip[1].Count[5] == 0)) - { - // transparency effects in use, so lets get busy! - ClipData *pClip; - uint32 fixedColour; - GFX.FixedColour = BUILD_PIXEL (IPPU.XB [PPU.FixedColourRed], - IPPU.XB [PPU.FixedColourGreen], - IPPU.XB [PPU.FixedColourBlue]); - fixedColour = (GFX.FixedColour<<16|GFX.FixedColour); - // Clear the z-buffer, marking areas 'covered' by the fixed - // colour as depth 1. - pClip = &IPPU.Clip [1]; - - // Clear the z-buffer - - if (pClip->Count [5]) - { - - // Colour window enabled. - // loop around all of the lines being updated - for (uint32 y = starty; y <= endy; y++) - { - // Clear the subZbuffer - memset32 ((uint32_t*)(GFX.SubZBuffer + y * GFX_ZPITCH),0, (256>>2)); - // Clear the Zbuffer - memset32 ((uint32_t*)(GFX.ZBuffer + y * GFX_ZPITCH),0, (256>>2)); - if (IPPU.Clip[0].Count [5]) { - // if there is clipping then clear subscreen to a black color - memset32 ((uint32_t*)(GFX.SubScreen + y * GFX_PITCH), black, (256>>1)); - } - - // loop through all window clippings - for (uint32 c = 0; c < pClip->Count [5]; c++) - { - if (pClip->Right [c][5] > pClip->Left [c][5]) - { - memset (GFX.SubZBuffer + y * GFX_ZPITCH + pClip->Left [c][5], - 1, pClip->Right [c][5] - pClip->Left [c][5]); - - if (IPPU.Clip [0].Count [5]) - { - // Blast, have to clear the sub-screen to the fixed-colour - // because there is a colour window in effect clipping - // the main screen that will allow the sub-screen - // 'underneath' to show through. - - register unsigned int width = pClip->Right [c][5] - pClip->Left [c][5]; - if (width > 0) { - __asm__ volatile ( - " mov r0, %[fixedcolour] \n" - " subs %[width], %[width], #4 \n" - " bmi 2f \n" - - "1: \n" - " subs %[width], %[width], #4 \n" - " stmia %[p]!, {r0, %[fixedcolour]}\n" - " bpl 1b \n" - - "2: \n" - " tst %[width], #1 \n" - " strneh %[fixedcolour], [%[p]], #2 \n" - - " tst %[width], #2 \n" - " strne %[fixedcolour], [%[p]], #4 \n" - - : [width] "+r" (width) - : [fixedcolour] "r" (fixedColour), - [p] "r" (((uint16 *) (GFX.SubScreen + y * GFX_PITCH)) + pClip->Left [c][5]) - : "r0", "cc" - ); - } - } - } - } - } - - } - else - { - // No windows are clipping the main screen - // this simplifies the screen clearing process - // loop through all of the lines to be updated - for (uint32 y = starty; y <= endy; y++) { - // Clear the Zbuffer - memset32 ((uint32_t*)(GFX.ZBuffer + y * GFX_ZPITCH),0, (256>>2)); - // clear the sub Zbuffer to 1 - memset32 ((uint32_t*)(GFX.SubZBuffer + y * GFX_ZPITCH), 0x01010101, (256>>2)); - - if (IPPU.Clip [0].Count [5]) { - // Blast, have to clear the sub-screen to the fixed-colour - // because there is a colour window in effect clipping - // the main screen that will allow the sub-screen - // 'underneath' to show through. - - memset32 ((uint32_t*)(GFX.SubScreen + y * GFX_PITCH), fixedColour, (256>>1)); - } - } - } - if (ANYTHING_ON_SUB) - { - GFX.DB = GFX.SubZBuffer; - RenderScreen (GFX.SubScreen, TRUE, TRUE, SUB_SCREEN_DEPTH); - } - - if (IPPU.Clip [0].Count [5]) - { - __asm__ volatile ( - "1: \n" - " mov r1, #(256 >> 2) \n" - - "2: \n" - // four pixels at once - " ldrb r0, [%[d]], #1 \n" - " ldrb r4, [%[d]], #1 \n" - - " bics r0, r0, #1 \n" - " ldrneh r0, [%[p], %[delta]] \n" - - " bics r4, r4, #1 \n" - " ldrneh r4, [%[p], %[delta2]] \n" - - " strh r0, [%[p]], #2 \n" - " strh r4, [%[p]], #2 \n" - - " ldrb r0, [%[d]], #1 \n" - " ldrb r4, [%[d]], #1 \n" - - " bics r0, r0, #1 \n" - " ldrneh r0, [%[p], %[delta]] \n" - - " bics r4, r4, #1 \n" - " ldrneh r4, [%[p], %[delta2]] \n" - - " strh r0, [%[p]], #2 \n" - " strh r4, [%[p]], #2 \n" - - " subs r1, r1, #1 \n" - " bne 2b \n" - "3: \n" - " subs %[lines], %[lines], #1 \n" - " add %[p], %[p], #(640 - 512) \n" - " add %[d], %[d], #(320 - 256) \n" - " bne 1b \n" - "4: \n" - - : - : [p] "r" ((uint16 *) (GFX.Screen + starty * GFX_PITCH)), - [d] "r" (GFX.SubZBuffer + starty * GFX_ZPITCH), - [delta] "r" (GFX.Delta << 1), - [delta2] "r" ((GFX.Delta << 1) + 2), - [lines] "r" (endy - starty + 1) - : "r0", "r1", "r3", "r4", "cc" - ); - } - - GFX.DB = GFX.ZBuffer; - RenderScreen (GFX.Screen, FALSE, FALSE, MAIN_SCREEN_DEPTH); - if (SUB_OR_ADD(5)) - { - uint32 back = IPPU.ScreenColors [0]; - uint32 Left = 0; - uint32 Right = 256; - uint32 Count; - - pClip = &IPPU.Clip [0]; - - for (uint32 y = starty; y <= endy; y++) - { - if (!(Count = pClip->Count [5])) - { - Left = 0; - Right = 256; - Count = 1; - } - - for (uint32 b = 0; b < Count; b++) - { - if (pClip->Count [5]) - { - Left = pClip->Left [b][5]; - Right = pClip->Right [b][5]; - if (Right <= Left) - continue; - } -#define SUBSCREEN_BG(rop, half) \ -\ -__asm__ volatile (\ -" ldrb r0, [%[d]], #1 \n"\ -"71: \n"\ -\ -" movs r0, r0 \n"\ -" ldreqb r1, [%[d], %[zdelta]] \n"\ -" bne 72f \n"\ -\ -" cmp r1, #1 \n"\ -" beq 74f \n"\ -" ldrh r1, [%[p], %[delta]] \n"\ -" mov r0, %[back] \n"\ -\ -ROP_##rop##half (r0, r1)\ -\ -" strh r0, [%[p]] \n"\ -"72: \n"\ -" add %[p], %[p], #2 \n"\ -" subs %[c], %[c], #1 \n"\ -" ldrneb r0, [%[d]], #1 \n"\ -" bne 71b \n"\ -" b 75f \n"\ -"74: \n"\ -" streqh %[fixedcolour], [%[p]], #2 \n"\ -" strloh %[back], [%[p]], #2 \n"\ -" subs %[c], %[c], #1 \n"\ -" ldrneb r0, [%[d]], #1 \n"\ -" bne 71b \n"\ -"75: \n"\ -:\ -:[p] "r" ((uint16 *) (GFX.Screen + y * GFX_PITCH) + Left),\ - [d] "r" (GFX.ZBuffer + y * GFX_ZPITCH + Left),\ - [zdelta] "r" (GFX.DepthDelta),\ - [back] "r" (back),\ - [delta] "r" (GFX.Delta << 1),\ - [fixedcolour] "r" (COLOR_##rop (back, GFX.FixedColour)),\ - [c] "r" (Right - Left) \ -: "r0", "r1", "cc"\ -); - if (GFX.r2131 & 0x80) - { - if (GFX.r2131 & 0x40) - { - SUBSCREEN_BG(SUB, 1_2) - } - else - { - SUBSCREEN_BG(SUB, ) - - } - } - else - if (GFX.r2131 & 0x40) - { - SUBSCREEN_BG(ADD, 1_2) - } - else if (back != 0) { - SUBSCREEN_BG(ADD, ) - } - else - { - if (!pClip->Count [5]) - { - // The backdrop has not been cleared yet - so - // copy the sub-screen to the main screen - // or fill it with the back-drop colour if the - // sub-screen is clear. - __asm__ volatile ( - " ldrb r0, [%[d]], #1 \n" - "31: \n" - - " movs r0, r0 \n" - " ldreqb r1, [%[d], %[zdelta]] \n" - " bne 32f \n" - - " cmp r1, #1 \n" - " ldrhih r0, [%[p], %[delta]] \n" - " strloh %[back], [%[p]] \n" - " streqh %[fixedcolour], [%[p]] \n" - " strhih r0, [%[p]] \n" - - "32: \n" - " subs %[c], %[c], #1 \n" - " add %[p], %[p], #2 \n" - " ldrneb r0, [%[d]], #1 \n" - " bne 31b \n" - " \n" - : - :[p] "r" ((uint16 *) (GFX.Screen + y * GFX_PITCH) + Left), - [d] "r" (GFX.ZBuffer + y * GFX_ZPITCH + Left), - [zdelta] "r" (GFX.DepthDelta), - [back] "r" (back), - [delta] "r" (GFX.Delta << 1), - [fixedcolour] "r" (GFX.FixedColour), - [c] "r" (Right - Left) - : "r0", "r1", "cc" - - ); - - } - } - } - } - - } - else - { - // Subscreen not being added to back - uint32 back = IPPU.ScreenColors [0] | (IPPU.ScreenColors [0] << 16); - pClip = &IPPU.Clip [0]; - - if (pClip->Count [5]) - { - for (uint32 y = starty; y <= endy; y++) - { - for (uint32 b = 0; b < pClip->Count [5]; b++) - { - uint32 Left = pClip->Left [b][5]; - uint32 Right = pClip->Right [b][5]; - if (Left >= Right) continue; - __asm__ volatile ( - - " tst %[c], #1 \n" - " bne 21f \n" - - " ldrb r0, [%[d]], #1 \n" - " add %[p], %[p], #2 \n" - " movs r0, r0 \n" - " streqh %[back], [%[p], #-2] \n" - " subs %[c], %[c], #1 \n" - " beq 22f \n" - - "21: \n" - - " ldrb r0, [%[d]], #1 \n" - " ldrb r1, [%[d]], #1 \n" - " add %[p], %[p], #4 \n" - - " movs r0, r0 \n" - " streqh %[back], [%[p], #-4] \n" - - " movs r1, r1 \n" - " streqh %[back], [%[p], #-2] \n" - - " subs %[c], %[c], #2 \n" - " bhi 21b \n" - "22: \n" - : - :[p] "r" ((uint16 *) (GFX.Screen + y * GFX_PITCH) + Left), - [d] "r" (GFX.ZBuffer + y * GFX_ZPITCH + Left), - [back] "r" (back), - [c] "r" (Right - Left) - : "r0", "r1", "cc" - - ); - } - } - } - else - { - __asm__ volatile ( - "@ -- SubScreen clear \n" - "1113: \n" - " mov r1, #(256/8) \n" - "1112: \n" - " ldr r0, [%[d]], #4 \n" - - " add %[p], %[p], #8 \n" - - " tst r0, #0x0ff \n" - " streqh %[back], [%[p], #-8] \n" - - " tst r0, #0x0ff00 \n" - " streqh %[back], [%[p], #-6] \n" - - " tst r0, #0x0ff0000 \n" - " streqh %[back], [%[p], #-4] \n" - - " tst r0, #0x0ff000000 \n" - " streqh %[back], [%[p], #-2] \n" - - " ldr r0, [%[d]], #4 \n" - - " add %[p], %[p], #8 \n" - - " tst r0, #0x0ff \n" - " streqh %[back], [%[p], #-8] \n" - - " tst r0, #0x0ff00 \n" - " streqh %[back], [%[p], #-6] \n" - - " tst r0, #0x0ff0000 \n" - " streqh %[back], [%[p], #-4] \n" - - " tst r0, #0x0ff000000 \n" - " streqh %[back], [%[p], #-2] \n" - - " subs r1, r1, #1 \n" - " bne 1112b \n" - - " subs %[lines], %[lines], #1 \n" - " add %[p], %[p], #(640-512) \n" - " add %[d], %[d], #(320-256) \n" - " bne 1113b \n" - "1114:" - : - :[p] "r" (GFX.Screen + starty * GFX_PITCH), - [d] "r" (GFX.ZBuffer + starty * GFX_ZPITCH), - [back] "r" (back), - [lines] "r" (endy - starty + 1) - : "r0", "r1", "cc" - ); - } - } - } - else - { - // 16bit and transparency but currently no transparency effects in - // operation. - - // get the back colour of the current screen - uint32 back = IPPU.ScreenColors [0] | - (IPPU.ScreenColors [0] << 16); - - // if forceblanking in use then use black instead of the back color - if (PPU.ForcedBlanking) - back = black; - - // not sure what Clip is used for yet - // could be a check to see if there is any clipping present? - if (IPPU.Clip [0].Count[5]) - { - - // loop through all of the lines that are going to be updated as part of this screen update - for (uint32 y = starty; y <= endy; y++) - { - memset32 ((uint32_t*)(GFX.Screen + y * GFX_PITCH), black, - IPPU.RenderedScreenWidth>>1); - - if (black!=back) - { - for (uint32 c = 0; c < IPPU.Clip [0].Count [5]; c++) - { - if (IPPU.Clip [0].Right [c][5] > IPPU.Clip [0].Left [c][5]) - { - register unsigned int width = IPPU.Clip [0].Right [c][5] - IPPU.Clip [0].Left [c][5]; - if (width > 0) { - __asm__ volatile ( - " mov r0, %[back] \n" - " subs %[width], %[width], #4 \n" - " bmi 2f \n" - - "1: \n" - " subs %[width], %[width], #4 \n" - " stmia %[p]!, {r0, %[back]} \n" - " bpl 1b \n" - - "2: \n" - " tst %[width], #1 \n" - " strneh %[back], [%[p]], #2 \n" - - " tst %[width], #2 \n" - " strne %[back], [%[p]], #4 \n" - : [width] "+r" (width) - : [back] "r" (back | (back << 16)), - [p] "r" (((uint16 *) (GFX.SubScreen + y * GFX_PITCH)) + IPPU.Clip [0].Left [c][5]) - : "r0", "cc" - ); - } - - } - } - } - } - } - else - { - // there is no clipping to worry about so just fill with the back colour - for (uint32 y = starty; y <= endy; y++) { - memset32 ((uint32_t*)(GFX.Screen + y * GFX_PITCH), back, (256>>1)); - } - - } - - // If Forced blanking is not in effect - if (!PPU.ForcedBlanking) - { - // Clear the Zbuffer for each of the lines which are going to be updated - for (uint32 y = starty; y <= endy; y++) { - memset32 ((uint32_t*)(GFX.ZBuffer + y * GFX_ZPITCH), 0, (256>>2)); - } - GFX.DB = GFX.ZBuffer; // save pointer to Zbuffer in GFX object - RenderScreen (GFX.Screen, FALSE, TRUE, SUB_SCREEN_DEPTH); - } - } - IPPU.PreviousLine = IPPU.CurrentLine; -} - -// -x- -void S9xUpdateScreenNoTransparency () // ~30-50ms! (called from FLUSH_REDRAW()) -{ - GFX.S = GFX.Screen; - - unsigned char *memoryfillram = Memory.FillRAM; - - // get local copies of vid registers to be used later - GFX.r2131 = memoryfillram [0x2131]; // ADDITION/SUBTRACTION & SUBTRACTION DESIGNATION FOR EACH SCREEN - GFX.r212c = memoryfillram [0x212c]; // MAIN SCREEN, DESIGNATION - used to enable BGS - GFX.r212d = memoryfillram [0x212d]; // SUB SCREEN DESIGNATION - used to enable sub BGS - GFX.r2130 = memoryfillram [0x2130]; // INITIAL SETTINGS FOR FIXED COLOR ADDITION OR SCREEN ADDITION - - // If external sync is off and - // main screens have not been configured the same as the sub screen and - // color addition and subtraction has been diabled then - // Pseudo is 1 - // anything else it is 0 - GFX.Pseudo = (memoryfillram [0x2133] & 8) != 0 && // Use EXTERNAL SYNCHRONIZATION? - (GFX.r212c & 15) != (GFX.r212d & 15) && // Are the main screens different from the sub screens? - (GFX.r2131 & 0x3f) == 0; // Is colour data addition/subtraction disabled on all BGS? - - // If sprite data has been changed then go through and - // refresh the sprites. - if (IPPU.OBJChanged) - { - S9xSetupOBJ (); - } - - if (PPU.RecomputeClipWindows) ComputeClipWindows(); - - GFX.StartY = IPPU.PreviousLine; - if ((GFX.EndY = IPPU.CurrentLine - 1) >= PPU.ScreenHeight) - GFX.EndY = PPU.ScreenHeight - 1; - - uint32 starty = GFX.StartY; - uint32 endy = GFX.EndY; - - uint32 black = BLACK | (BLACK << 16); - - // get back colour to be used in clearing the screen - register uint32 back; - if (!(Memory.FillRAM [0x2131] & 0x80) &&(Memory.FillRAM[0x2131] & 0x20) && - (PPU.FixedColourRed || PPU.FixedColourGreen || PPU.FixedColourBlue)) - { - back = (IPPU.XB[PPU.FixedColourRed]<<11) | - (IPPU.XB[PPU.FixedColourGreen] << 6) | - (IPPU.XB[PPU.FixedColourBlue] << 1) | 1; - back = (back << 16) | back; - } - else - { - back = IPPU.ScreenColors [0] | (IPPU.ScreenColors [0] << 16); - } - - // if Forcedblanking in use then back colour becomes black - if (PPU.ForcedBlanking) - back = black; - else - { - SelectTileRenderer (TRUE); //selects the tile renderers to be used - // TRUE means to use the default - // FALSE means use best renderer based on current - // graphics register settings - } - - // now clear all graphics lines which are being updated using the back colour - for (register uint32 y = starty; y <= endy; y++) - { - memset32 ((uint32_t*)(GFX.Screen + y * GFX_PITCH), back, - IPPU.RenderedScreenWidth>>1); - } - - if (!PPU.ForcedBlanking) - { - // Loop through all lines being updated and clear the - // zbuffer for each of the lines - for (uint32 y = starty; y <= endy; y++) - { - memset32 ((uint32_t*)(GFX.ZBuffer + y * GFX_ZPITCH), 0, - IPPU.RenderedScreenWidth>>2); - } - GFX.DB = GFX.ZBuffer; // save pointer to Zbuffer in GFX object - GFX.pCurrentClip = &IPPU.Clip [0]; - -// Define an inline function to handle clipping -#define FIXCLIP(n) \ -if (GFX.r212c & (1 << (n))) \ - GFX.pCurrentClip = &IPPU.Clip [0]; \ -else \ - GFX.pCurrentClip = &IPPU.Clip [1] - -// Define an inline function to handle which BGs are being displayed -#define DISPLAY(n) ((GFX.r212c & n) || ((GFX.r212d & n) && subadd)) - - uint8 subadd = GFX.r2131 & 0x3f; - - // go through all BGS are check if they need to be displayed - bool8_32 BG0 = DISPLAY(1) && !(Settings.os9x_hack & GFX_IGNORE_BG0); - bool8_32 BG1 = DISPLAY(2) && !(Settings.os9x_hack & GFX_IGNORE_BG1); - bool8_32 BG2 = DISPLAY(4) && !(Settings.os9x_hack & GFX_IGNORE_BG2); - bool8_32 BG3 = DISPLAY(8) && !(Settings.os9x_hack & GFX_IGNORE_BG3); - bool8_32 OB = DISPLAY(16) && !(Settings.os9x_hack & GFX_IGNORE_OBJ); - - if (PPU.BGMode <= 1) - { - // screen modes 0 and 1 - if (OB) - { - FIXCLIP(4); - DrawOBJS (FALSE, 0); - } - if (BG0) - { - FIXCLIP(0); - DrawBackground (PPU.BGMode, 0, 10, 14); - } - if (BG1) - { - FIXCLIP(1); - DrawBackground (PPU.BGMode, 1, 9, 13); - } - if (BG2) - { - FIXCLIP(2); - DrawBackground (PPU.BGMode, 2, 3, - PPU.BG3Priority ? 17 : 6); - } - if (BG3 && PPU.BGMode == 0) - { - FIXCLIP(3); - DrawBackground (PPU.BGMode, 3, 2, 5); - } - } - else if (PPU.BGMode != 7) - { - // screen modes 2 and up but not mode 7 - if (OB) - { - FIXCLIP(4); - DrawOBJS (FALSE, 0); - } - if (BG0) - { - FIXCLIP(0); - DrawBackground (PPU.BGMode, 0, 5, 13); - } - if (BG1 && PPU.BGMode != 6) - { - FIXCLIP(1); - DrawBackground (PPU.BGMode, 1, 2, 9); - } - } - else - { - // screen mode 7 - DrawBGMode7Background16New (GFX.Screen); - if (OB) - { - FIXCLIP(4); - DrawOBJS (FALSE, 0); - } - } - } - IPPU.PreviousLine = IPPU.CurrentLine; -} - -// -x- - -#ifdef GFX_MULTI_FORMAT - -#define _BUILD_PIXEL(F) \ -uint32 BuildPixel##F(uint32 R, uint32 G, uint32 B) \ -{ \ - return (BUILD_PIXEL_##F(R,G,B)); \ -}\ -uint32 BuildPixel2##F(uint32 R, uint32 G, uint32 B) \ -{ \ - return (BUILD_PIXEL2_##F(R,G,B)); \ -} \ -void DecomposePixel##F(uint32 pixel, uint32 &R, uint32 &G, uint32 &B) \ -{ \ - DECOMPOSE_PIXEL_##F(pixel,R,G,B); \ -} - -_BUILD_PIXEL(RGB565) -_BUILD_PIXEL(RGB555) -_BUILD_PIXEL(BGR565) -_BUILD_PIXEL(BGR555) -_BUILD_PIXEL(GBR565) -_BUILD_PIXEL(GBR555) -_BUILD_PIXEL(RGB5551) - -bool8_32 S9xSetRenderPixelFormat (int format) -{ - extern uint32 current_graphic_format; - - current_graphic_format = format; - - switch (format) - { - case RGB565: - _BUILD_SETUP(RGB565) - return (TRUE); - case RGB555: - _BUILD_SETUP(RGB555) - return (TRUE); - case BGR565: - _BUILD_SETUP(BGR565) - return (TRUE); - case BGR555: - _BUILD_SETUP(BGR555) - return (TRUE); - case GBR565: - _BUILD_SETUP(GBR565) - return (TRUE); - case GBR555: - _BUILD_SETUP(GBR555) - return (TRUE); - case RGB5551: - _BUILD_SETUP(RGB5551) - return (TRUE); - default: - break; - } - return (FALSE); -} -#endif diff --git a/old/gfx16.cpp.old2 b/old/gfx16.cpp.old2 deleted file mode 100644 index d5e27a0..0000000 --- a/old/gfx16.cpp.old2 +++ /dev/null @@ -1,3199 +0,0 @@ -/* - * Snes9x - Portable Super Nintendo Entertainment System (TM) emulator. - * - * (c) Copyright 1996 - 2001 Gary Henderson (gary.henderson@ntlworld.com) and - * Jerremy Koot (jkoot@snes9x.com) - * - * Super FX C emulator code - * (c) Copyright 1997 - 1999 Ivar (ivar@snes9x.com) and - * Gary Henderson. - * Super FX assembler emulator code (c) Copyright 1998 zsKnight and _Demo_. - * - * DSP1 emulator code (c) Copyright 1998 Ivar, _Demo_ and Gary Henderson. - * C4 asm and some C emulation code (c) Copyright 2000 zsKnight and _Demo_. - * C4 C code (c) Copyright 2001 Gary Henderson (gary.henderson@ntlworld.com). - * - * DOS port code contains the works of other authors. See headers in - * individual files. - * - * Snes9x homepage: http://www.snes9x.com - * - * Permission to use, copy, modify and distribute Snes9x in both binary and - * source form, for non-commercial purposes, is hereby granted without fee, - * providing that this license information and copyright notice appear with - * all copies and any derived work. - * - * This software is provided 'as-is', without any express or implied - * warranty. In no event shall the authors be held liable for any damages - * arising from the use of this software. - * - * Snes9x is freeware for PERSONAL USE only. Commercial users should - * seek permission of the copyright holders first. Commercial use includes - * charging money for Snes9x or software derived from Snes9x. - * - * The copyright holders request that bug fixes and improvements to the code - * should be forwarded to them so everyone can benefit from the modifications - * in future versions. - * - * Super NES and Super Nintendo Entertainment System are trademarks of - * Nintendo Co., Limited and its subsidiary companies. - */ -#include "snes9x.h" - -#include "memmap.h" -#include "ppu.h" -#include "cpuexec.h" -#include "display.h" -#include "gfx.h" -#include "apu.h" -#include "cheats.h" -#include <stdint.h> -#include "asmmemfuncs.h" -#include "mode7.h" -#include "rops.h" -#include "tile16.h" -uint32 TileBlank; -// V_FLIP 0x8000 -// H_FLIP 0x4000 -//Tile += tx_table[tx_index + ((Tile & (H_FLIP | V_FLIP)) >> 13) + (Quot & 1)]; -// (((Tile & H_FLIP) >> 14) ^ (Quot & 1)) + (((Tile & V_FLIP) >> 11) ^ (16) ^ tx_index) - - -const int tx_table[16] = { -// t1 = 16, t2 = 0 - // FLIP = 0x00 - 16 + 0, // 0x00 - 16 + 1, // 0x01 - - // FLIP = 0x01 - 16 + 1 - 0, // 0x02 - 16 + 1 - 1, // 0x03 - - // FLIP = 0x02 - 0 + 0, // 0x04 - 0 + 1, // 0x05 - - // FLIP = 0x03 - 0 + 1 - 0, // 0x06 - 0 + 1 - 1, // 0x07 - -// t1 = 0, t2 = 16 - // FLIP = 0x00 - 0 + 0, // 0x08 - 0 + 1, // 0x09 - - // FLIP = 0x01 - 0 + 1 - 0, // 0x0A - 0 + 1 - 1, // 0x0B - - // FLIP = 0x02 - 16 + 0, // 0x0C - 16 + 1, // 0x0D - - // FLIP = 0x03 - 16 + 1 - 0, // 0x0E - 16 + 1 - 1 // 0x0F -}; - -#define M7 19 -#define M8 19 - -void ComputeClipWindows (); -static void S9xDisplayFrameRate (); -static void S9xDisplayString (const char *string); - -extern uint8 BitShifts[8][4]; -extern uint8 TileShifts[8][4]; -extern uint8 PaletteShifts[8][4]; -extern uint8 PaletteMasks[8][4]; -extern uint8 Depths[8][4]; -extern uint8 BGSizes [2]; - -extern NormalTileRenderer DrawTilePtr; -extern ClippedTileRenderer DrawClippedTilePtr; -extern NormalTileRenderer DrawHiResTilePtr; -extern ClippedTileRenderer DrawHiResClippedTilePtr; -extern LargePixelRenderer DrawLargePixelPtr; - -extern SBG BG; - -extern SLineData LineData[240]; -extern SLineMatrixData LineMatrixData [240]; - -extern uint8 Mode7Depths [2]; - -#define ON_MAIN(N) (GFX.r212c & (1 << (N))) - -#define SUB_OR_ADD(N) \ -(GFX.r2131 & (1 << (N))) - -#define ON_SUB(N) \ -((GFX.r2130 & 0x30) != 0x30 && \ - (GFX.r2130 & 2) && \ - (GFX.r212d & (1 << N))) - -#define ANYTHING_ON_SUB \ -((GFX.r2130 & 0x30) != 0x30 && \ - (GFX.r2130 & 2) && \ - (GFX.r212d & 0x1f)) - -#define ADD_OR_SUB_ON_ANYTHING \ -(GFX.r2131 & 0x3f) - -#define BLACK BUILD_PIXEL(0,0,0) - -void DrawNoZTile16 (uint32 Tile, uint32 Offset, uint32 StartLine, uint32 LineCount); -void DrawTile16 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); -void DrawClippedTile16 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); -void DrawTile16x2 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); -void DrawClippedTile16x2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); -void DrawTile16x2x2 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); -void DrawClippedTile16x2x2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); -void DrawLargePixel16 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Pixels, - uint32 StartLine, uint32 LineCount); - -void DrawNoZTile16Add (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - -void DrawTile16Add (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - -void DrawClippedTile16Add (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); - -void DrawNoZTile16Add1_2 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - -void DrawTile16Add1_2 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - -void DrawClippedTile16Add1_2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); - -void DrawTile16FixedAdd1_2 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - -void DrawClippedTile16FixedAdd1_2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); - -void DrawNoZTile16Sub (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - - -void DrawTile16Sub (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - -void DrawClippedTile16Sub (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); - -void DrawNoZTile16Sub1_2 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - - -void DrawTile16Sub1_2 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - -void DrawClippedTile16Sub1_2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); - -void DrawTile16FixedSub1_2 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount); - -void DrawClippedTile16FixedSub1_2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); - -void DrawLargePixel16Add (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Pixels, - uint32 StartLine, uint32 LineCount); - -void DrawLargePixel16Add1_2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Pixels, - uint32 StartLine, uint32 LineCount); - -void DrawLargePixel16Sub (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Pixels, - uint32 StartLine, uint32 LineCount); - -void DrawLargePixel16Sub1_2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Pixels, - uint32 StartLine, uint32 LineCount); - -void DrawHiResClippedTile16 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount); - -void DrawHiResTile16 (uint32 Tile, uint32 Offset, - uint32 StartLine, uint32 LineCount); - -bool8_32 S9xGraphicsInit () -{ - register uint32 PixelOdd = 1; - register uint32 PixelEven = 2; - -#ifdef GFX_MULTI_FORMAT - if (GFX.BuildPixel == NULL) - S9xSetRenderPixelFormat (RGB565); -#endif - - for (uint8 bitshift = 0; bitshift < 4; bitshift++) - { - for (register int i = 0; i < 16; i++) - { - register uint32 h = 0; - register uint32 l = 0; - -#if defined(MSB_FIRST) - if (i & 8) - h |= (PixelOdd << 24); - if (i & 4) - h |= (PixelOdd << 16); - if (i & 2) - h |= (PixelOdd << 8); - if (i & 1) - h |= PixelOdd; - if (i & 8) - l |= (PixelOdd << 24); - if (i & 4) - l |= (PixelOdd << 16); - if (i & 2) - l |= (PixelOdd << 8); - if (i & 1) - l |= PixelOdd; -#else -// Wiz usa - if (i & 8) - h |= PixelOdd; - if (i & 4) - h |= PixelOdd << 8; - if (i & 2) - h |= PixelOdd << 16; - if (i & 1) - h |= PixelOdd << 24; - if (i & 8) - l |= PixelOdd; - if (i & 4) - l |= PixelOdd << 8; - if (i & 2) - l |= PixelOdd << 16; - if (i & 1) - l |= PixelOdd << 24; -#endif - - odd_high[bitshift][i] = h; - odd_low[bitshift][i] = l; - h = l = 0; - -#if defined(MSB_FIRST) - if (i & 8) - h |= (PixelEven << 24); - if (i & 4) - h |= (PixelEven << 16); - if (i & 2) - h |= (PixelEven << 8); - if (i & 1) - h |= PixelEven; - if (i & 8) - l |= (PixelEven << 24); - if (i & 4) - l |= (PixelEven << 16); - if (i & 2) - l |= (PixelEven << 8); - if (i & 1) - l |= PixelEven; -#else - if (i & 8) - h |= PixelEven; - if (i & 4) - h |= PixelEven << 8; - if (i & 2) - h |= PixelEven << 16; - if (i & 1) - h |= PixelEven << 24; - if (i & 8) - l |= PixelEven; - if (i & 4) - l |= PixelEven << 8; - if (i & 2) - l |= PixelEven << 16; - if (i & 1) - l |= PixelEven << 24; -#endif - - even_high[bitshift][i] = h; - even_low[bitshift][i] = l; - } - PixelEven <<= 2; - PixelOdd <<= 2; - } - - GFX.Delta = (GFX.SubScreen - GFX.Screen) >> 1; - GFX.DepthDelta = GFX.SubZBuffer - GFX.ZBuffer; - //GFX.InfoStringTimeout = 0; - //GFX.InfoString = NULL; - - PPU.BG_Forced = 0; - IPPU.OBJChanged = TRUE; - - IPPU.DirectColourMapsNeedRebuild = TRUE; - DrawTilePtr = DrawTile16; - DrawClippedTilePtr = DrawClippedTile16; - DrawLargePixelPtr = DrawLargePixel16; - DrawHiResTilePtr= DrawHiResTile16; - DrawHiResClippedTilePtr = DrawHiResClippedTile16; - S9xFixColourBrightness (); - - if (!(GFX.X2 = (uint16 *) malloc (sizeof (uint16) * 0x10000))) - return (FALSE); - - if (!(GFX.ZERO_OR_X2 = (uint16 *) malloc (sizeof (uint16) * 0x10000)) || - !(GFX.ZERO = (uint16 *) malloc (sizeof (uint16) * 0x10000))) - { - if (GFX.ZERO_OR_X2) - { - free ((char *) GFX.ZERO_OR_X2); - GFX.ZERO_OR_X2 = NULL; - } - if (GFX.X2) - { - free ((char *) GFX.X2); - GFX.X2 = NULL; - } - return (FALSE); - } - uint32 r, g, b; - - // Build a lookup table that multiplies a packed RGB value by 2 with - // saturation. - for (r = 0; r <= MAX_RED; r++) - { - uint32 r2 = r << 1; - if (r2 > MAX_RED) - r2 = MAX_RED; - for (g = 0; g <= MAX_GREEN; g++) - { - uint32 g2 = g << 1; - if (g2 > MAX_GREEN) - g2 = MAX_GREEN; - for (b = 0; b <= MAX_BLUE; b++) - { - uint32 b2 = b << 1; - if (b2 > MAX_BLUE) - b2 = MAX_BLUE; - GFX.X2 [BUILD_PIXEL2 (r, g, b)] = BUILD_PIXEL2 (r2, g2, b2); - GFX.X2 [BUILD_PIXEL2 (r, g, b) & ~ALPHA_BITS_MASK] = BUILD_PIXEL2 (r2, g2, b2); - } - } - } - ZeroMemory (GFX.ZERO, 0x10000 * sizeof (uint16)); - ZeroMemory (GFX.ZERO_OR_X2, 0x10000 * sizeof (uint16)); - // Build a lookup table that if the top bit of the color value is zero - // then the value is zero, otherwise multiply the value by 2. Used by - // the color subtraction code. - -#if defined(OLD_COLOUR_BLENDING) - for (r = 0; r <= MAX_RED; r++) - { - uint32 r2 = r; - if ((r2 & 0x10) == 0) - r2 = 0; - else - r2 = (r2 << 1) & MAX_RED; - - for (g = 0; g <= MAX_GREEN; g++) - { - uint32 g2 = g; - if ((g2 & GREEN_HI_BIT) == 0) - g2 = 0; - else - g2 = (g2 << 1) & MAX_GREEN; - - for (b = 0; b <= MAX_BLUE; b++) - { - uint32 b2 = b; - if ((b2 & 0x10) == 0) - b2 = 0; - else - b2 = (b2 << 1) & MAX_BLUE; - - GFX.ZERO_OR_X2 [BUILD_PIXEL2 (r, g, b)] = BUILD_PIXEL2 (r2, g2, b2); - GFX.ZERO_OR_X2 [BUILD_PIXEL2 (r, g, b) & ~ALPHA_BITS_MASK] = BUILD_PIXEL2 (r2, g2, b2); - } - } - } -#else - for (r = 0; r <= MAX_RED; r++) - { - uint32 r2 = r; - if ((r2 & 0x10) == 0) - r2 = 0; - else - r2 = (r2 << 1) & MAX_RED; - - if (r2 == 0) - r2 = 1; - for (g = 0; g <= MAX_GREEN; g++) - { - uint32 g2 = g; - if ((g2 & GREEN_HI_BIT) == 0) - g2 = 0; - else - g2 = (g2 << 1) & MAX_GREEN; - - if (g2 == 0) - g2 = 1; - for (b = 0; b <= MAX_BLUE; b++) - { - uint32 b2 = b; - if ((b2 & 0x10) == 0) - b2 = 0; - else - b2 = (b2 << 1) & MAX_BLUE; - - if (b2 == 0) - b2 = 1; - GFX.ZERO_OR_X2 [BUILD_PIXEL2 (r, g, b)] = BUILD_PIXEL2 (r2, g2, b2); - GFX.ZERO_OR_X2 [BUILD_PIXEL2 (r, g, b) & ~ALPHA_BITS_MASK] = BUILD_PIXEL2 (r2, g2, b2); - } - } - } -#endif - - // Build a lookup table that if the top bit of the color value is zero - // then the value is zero, otherwise its just the value. - for (r = 0; r <= MAX_RED; r++) - { - uint32 r2 = r; - if ((r2 & 0x10) == 0) - r2 = 0; - else - r2 &= ~0x10; - - for (g = 0; g <= MAX_GREEN; g++) - { - uint32 g2 = g; - if ((g2 & GREEN_HI_BIT) == 0) - g2 = 0; - else - g2 &= ~GREEN_HI_BIT; - for (b = 0; b <= MAX_BLUE; b++) - { - uint32 b2 = b; - if ((b2 & 0x10) == 0) - b2 = 0; - else - b2 &= ~0x10; - - GFX.ZERO [BUILD_PIXEL2 (r, g, b)] = BUILD_PIXEL2 (r2, g2, b2); - GFX.ZERO [BUILD_PIXEL2 (r, g, b) & ~ALPHA_BITS_MASK] = BUILD_PIXEL2 (r2, g2, b2); - } - } - } - - return (TRUE); -} - -void S9xGraphicsDeinit (void) -{ - // Free any memory allocated in S9xGraphicsInit - if (GFX.X2) - { - free ((char *) GFX.X2); - GFX.X2 = NULL; - } - if (GFX.ZERO_OR_X2) - { - free ((char *) GFX.ZERO_OR_X2); - GFX.ZERO_OR_X2 = NULL; - } - if (GFX.ZERO) - { - free ((char *) GFX.ZERO); - GFX.ZERO = NULL; - } -} - -void S9xBuildDirectColourMaps () -{ - for (uint32 p = 0; p < 8; p++) - { - for (uint32 c = 0; c < 256; c++) - { -// XXX: Brightness - DirectColourMaps [p][c] = BUILD_PIXEL (((c & 7) << 2) | ((p & 1) << 1), - ((c & 0x38) >> 1) | (p & 2), - ((c & 0xc0) >> 3) | (p & 4)); - } - } - IPPU.DirectColourMapsNeedRebuild = FALSE; -} - -void S9xStartScreenRefresh () -{ - if (IPPU.RenderThisFrame) - { - if (!S9xInitUpdate ()) - { - IPPU.RenderThisFrame = FALSE; - return; - } - IPPU.RenderedFramesCount++; - IPPU.PreviousLine = IPPU.CurrentLine = 0; - IPPU.MaxBrightness = PPU.Brightness; - IPPU.LatchedBlanking = PPU.ForcedBlanking; - IPPU.LatchedInterlace = (Memory.FillRAM[0x2133] & 1); - IPPU.RenderedScreenWidth = 256; - IPPU.RenderedScreenHeight = PPU.ScreenHeight; - IPPU.DoubleWidthPixels = FALSE; - - PPU.RecomputeClipWindows = TRUE; - GFX.DepthDelta = GFX.SubZBuffer - GFX.ZBuffer; - GFX.Delta = (GFX.SubScreen - GFX.Screen) >> 1; - - } - if (++IPPU.FrameCount % Memory.ROMFramesPerSecond == 0) - { - IPPU.DisplayedRenderedFrameCount = IPPU.RenderedFramesCount; - IPPU.RenderedFramesCount = 0; - IPPU.FrameCount = 0; - } -} - -void RenderLine (uint8 C) -{ - if (IPPU.RenderThisFrame) - { - - LineData[C].BG[0].VOffset = PPU.BG[0].VOffset + 1; - LineData[C].BG[0].HOffset = PPU.BG[0].HOffset; - LineData[C].BG[1].VOffset = PPU.BG[1].VOffset + 1; - LineData[C].BG[1].HOffset = PPU.BG[1].HOffset; - - if (PPU.BGMode == 7) - { - SLineMatrixData *p = &LineMatrixData [C]; - p->MatrixA = PPU.MatrixA; - p->MatrixB = PPU.MatrixB; - p->MatrixC = PPU.MatrixC; - p->MatrixD = PPU.MatrixD; - p->CentreX = PPU.CentreX; - p->CentreY = PPU.CentreY; - } - else - { - if (Settings.StarfoxHack && PPU.BG[2].VOffset == 0 && - PPU.BG[2].HOffset == 0xe000) - { - LineData[C].BG[2].VOffset = 0xe1; - LineData[C].BG[2].HOffset = 0; - } - else - { - LineData[C].BG[2].VOffset = PPU.BG[2].VOffset + 1; - LineData[C].BG[2].HOffset = PPU.BG[2].HOffset; - LineData[C].BG[3].VOffset = PPU.BG[3].VOffset + 1; - LineData[C].BG[3].HOffset = PPU.BG[3].HOffset; - } - - } - IPPU.CurrentLine = C + 1; - } -} - - -void S9xEndScreenRefresh() -{ - IPPU.HDMAStarted = FALSE; - -//RC - if (IPPU.RenderThisFrame) - { - FLUSH_REDRAW (); - //if (IPPU.ColorsChanged) - //{ - IPPU.ColorsChanged = FALSE; - //} - - - S9xDeinitUpdate (IPPU.RenderedScreenWidth, IPPU.RenderedScreenHeight, - 1); - } -#ifndef RC_OPTIMIZED - S9xApplyCheats (); -#endif - - -#ifdef DEBUGGER - if (CPU.Flags & FRAME_ADVANCE_FLAG) - { - if (ICPU.FrameAdvanceCount) - { - ICPU.FrameAdvanceCount--; - IPPU.RenderThisFrame = TRUE; - IPPU.FrameSkip = 0; - } - else - { - CPU.Flags &= ~FRAME_ADVANCE_FLAG; - CPU.Flags |= DEBUG_MODE_FLAG; - } - } -#endif - -/* - if (CPU.SRAMModified) - { - if (!CPU.AutoSaveTimer) - { - if (!(CPU.AutoSaveTimer = Settings.AutoSaveDelay * Memory.ROMFramesPerSecond)) - CPU.SRAMModified = FALSE; - } - else - { - if (!--CPU.AutoSaveTimer) - { - S9xAutoSaveSRAM (); - CPU.SRAMModified = FALSE; - } - } - } -*/ -} - -void S9xSetInfoString (const char *string) -{ - } - - - -int TileRenderer; -TileRendererSet TileRenderers[] = { - {DrawTile16Add, DrawClippedTile16Add, DrawLargePixel16Add}, // 0 -> GFX.r2131:7 = 0, GFX.r2131:6 = 0, GFX.r2130:1 = 0 - {DrawTile16Add, DrawClippedTile16Add, DrawLargePixel16Add}, // 1 -> GFX.r2131:7 = 0, GFX.r2131:6 = 0, GFX.r2130:1 = 1 - {DrawTile16FixedAdd1_2, DrawClippedTile16FixedAdd1_2, DrawLargePixel16Add1_2}, // 2 -> GFX.r2131:7 = 0, GFX.r2131:6 = 1, GFX.r2130:1 = 0 - {DrawTile16Add1_2, DrawClippedTile16Add1_2, DrawLargePixel16Add1_2}, // 3 -> GFX.r2131:7 = 0, GFX.r2131:6 = 1, GFX.r2130:1 = 1 - {DrawTile16Sub, DrawClippedTile16Sub, DrawLargePixel16Sub}, // 4 -> GFX.r2131:7 = 1, GFX.r2131:6 = 0, GFX.r2130:1 = 0 - {DrawTile16Sub, DrawClippedTile16Sub, DrawLargePixel16Sub}, // 5 -> GFX.r2131:7 = 1, GFX.r2131:6 = 0, GFX.r2130:1 = 1 - {DrawTile16FixedSub1_2, DrawClippedTile16FixedSub1_2, DrawLargePixel16Sub1_2}, // 6 -> GFX.r2131:7 = 1, GFX.r2131:6 = 1, GFX.r2130:1 = 0 - {DrawTile16Sub1_2, DrawClippedTile16Sub1_2, DrawLargePixel16Sub1_2}, // 7 -> GFX.r2131:7 = 1, GFX.r2131:6 = 1, GFX.r2130:1 = 1 - {DrawTile16, DrawClippedTile16, DrawLargePixel16} // 8 -> normal - }; -TileRendererSet TileRenderersNoZ[] = { - {DrawNoZTile16Add, DrawClippedTile16Add, DrawLargePixel16Add}, // 0 -> GFX.r2131:7 = 0, GFX.r2131:6 = 0, GFX.r2130:1 = 0 - {DrawNoZTile16Add, DrawClippedTile16Add, DrawLargePixel16Add}, // 1 -> GFX.r2131:7 = 0, GFX.r2131:6 = 0, GFX.r2130:1 = 1 - {DrawTile16FixedAdd1_2, DrawClippedTile16FixedAdd1_2, DrawLargePixel16Add1_2}, // 2 -> GFX.r2131:7 = 0, GFX.r2131:6 = 1, GFX.r2130:1 = 0 - {DrawNoZTile16Add1_2, DrawClippedTile16Add1_2, DrawLargePixel16Add1_2}, // 3 -> GFX.r2131:7 = 0, GFX.r2131:6 = 1, GFX.r2130:1 = 1 - {DrawNoZTile16Sub, DrawClippedTile16Sub, DrawLargePixel16Sub}, // 4 -> GFX.r2131:7 = 1, GFX.r2131:6 = 0, GFX.r2130:1 = 0 - {DrawNoZTile16Sub, DrawClippedTile16Sub, DrawLargePixel16Sub}, // 5 -> GFX.r2131:7 = 1, GFX.r2131:6 = 0, GFX.r2130:1 = 1 - {DrawTile16FixedSub1_2, DrawClippedTile16FixedSub1_2, DrawLargePixel16Sub1_2}, // 6 -> GFX.r2131:7 = 1, GFX.r2131:6 = 1, GFX.r2130:1 = 0 - {DrawNoZTile16Sub1_2, DrawClippedTile16Sub1_2, DrawLargePixel16Sub1_2}, // 7 -> GFX.r2131:7 = 1, GFX.r2131:6 = 1, GFX.r2130:1 = 1 - {DrawNoZTile16, DrawClippedTile16, DrawLargePixel16} // 8 -> normal - }; -static INLINE void SelectTileRenderer (bool8_32 normal, bool NoZ = false) -{ - if (normal) { - TileRenderer = 8; - } - else { - TileRenderer = (((GFX.r2131 >> 5) & 0x06) | ((GFX.r2130 >> 1) & 1)); - } - -#ifdef __DEBUG__ - char *TRName[] = { - "Add", "Add", "FixedAdd1_2", "Add1_2", - "Sub", "Sub", "FixedSub1_2", "Sub1_2", - "Normal" - }; - printf("SelectTileRenderer: %s\n", TRName[TileRenderer]); -#endif - - if (NoZ) { - DrawTilePtr = TileRenderersNoZ[TileRenderer].Normal; - DrawClippedTilePtr = TileRenderersNoZ[TileRenderer].Clipped; - DrawLargePixelPtr = TileRenderersNoZ[TileRenderer].Large; - } - else { - DrawTilePtr = TileRenderers[TileRenderer].Normal; - DrawClippedTilePtr = TileRenderers[TileRenderer].Clipped; - DrawLargePixelPtr = TileRenderers[TileRenderer].Large; - } -} - -void S9xSetupOBJ () -{ - int SmallSize; - int LargeSize; - - switch (PPU.OBJSizeSelect) - { - case 0: - SmallSize = 8; - LargeSize = 16; - break; - case 1: - SmallSize = 8; - LargeSize = 32; - break; - case 2: - SmallSize = 8; - LargeSize = 64; - break; - case 3: - SmallSize = 16; - LargeSize = 32; - break; - case 4: - SmallSize = 16; - LargeSize = 64; - break; - case 5: - default: - SmallSize = 32; - LargeSize = 64; - break; - } - - int C = 0; - - int FirstSprite = PPU.FirstSprite & 0x7f; - int S = FirstSprite; - do - { - int Size; - if (PPU.OBJ [S].Size) - Size = LargeSize; - else - Size = SmallSize; - - long VPos = PPU.OBJ [S].VPos; - - if (VPos >= PPU.ScreenHeight) - VPos -= 256; - if (PPU.OBJ [S].HPos < 256 && PPU.OBJ [S].HPos > -Size && - VPos < PPU.ScreenHeight && VPos > -Size) - { - int x = 0; - int a, b; - //GFX.OBJList[C++] = S; - // -- Sort objects (from low to high priority) - - while (x < C) { - a = GFX.OBJList[x]; - if (PPU.OBJ[a].Priority >= PPU.OBJ[S].Priority) break; - x++; - } - - GFX.OBJList[x] = S; - x++; C++; - - while (x < C) { - b = GFX.OBJList[x]; - GFX.OBJList[x] = a; - a = b; - x++; - } - // -- - GFX.Sizes[S] = Size; - GFX.VPositions[S] = VPos; - } - S = (S + 1) & 0x7f; - } while (S != FirstSprite); - - // Terminate the list - GFX.OBJList [C] = -1; - IPPU.OBJChanged = FALSE; -} - -void DrawOBJS (bool8_32 OnMain = FALSE, uint8 D = 0) -{ - int bg_ta_ns; - int bg_ta; - uint32 O; - uint32 BaseTile, Tile; - - CHECK_SOUND(); - - BG.BitShift = 4; - SelectConvertTile(); - BG.TileShift = 5; - //BG.TileAddress = PPU.OBJNameBase; - BG.StartPalette = 128; - BG.PaletteShift = 4; - BG.PaletteMask = 7; - BG.Buffer = IPPU.TileCache [TILE_4BIT]; - BG.Buffered = IPPU.TileCached [TILE_4BIT]; - //BG.NameSelect = PPU.OBJNameSelect; - BG.DirectColourMode = FALSE; - - SelectPalette(); - bg_ta = PPU.OBJNameBase; - bg_ta_ns = bg_ta + PPU.OBJNameSelect; - - GFX.Z1 = D + 2; - - int I = 0; - for (int S = GFX.OBJList [I++]; S >= 0; S = GFX.OBJList [I++]) - { - int VPos = GFX.VPositions [S]; - int Size = GFX.Sizes[S]; - int TileInc = 1; - int Offset; - - if (VPos + Size <= (int) GFX.StartY || VPos > (int) GFX.EndY) - continue; - - if (OnMain && SUB_OR_ADD(4)) - { - SelectTileRenderer (!GFX.Pseudo && PPU.OBJ [S].Palette < 4, true); - } - - BaseTile = PPU.OBJ[S].Name | (PPU.OBJ[S].Palette << 10); - - if (PPU.OBJ[S].HFlip) - { - BaseTile += ((Size >> 3) - 1) | H_FLIP; - TileInc = -1; - } - - if (PPU.OBJ[S].VFlip) BaseTile |= V_FLIP; - //BaseTile |= PPU.OBJ[S].VFlip << 15; - - int clipcount = GFX.pCurrentClip->Count [4]; - if (!clipcount) clipcount = 1; - - GFX.Z2 = (PPU.OBJ[S].Priority + 1) * 4 + D; - - for (int clip = 0; clip < clipcount; clip++) - { - int Left; - int Right; - if (!GFX.pCurrentClip->Count [4]) - { - Left = 0; - Right = 256; - } - else - { - Left = GFX.pCurrentClip->Left [clip][4]; - Right = GFX.pCurrentClip->Right [clip][4]; - } - - if (Right <= Left || PPU.OBJ[S].HPos + Size <= Left || - PPU.OBJ[S].HPos >= Right) - continue; - - for (int Y = 0; Y < Size; Y += 8) - { - if (VPos + Y + 7 >= (int) GFX.StartY && VPos + Y <= (int) GFX.EndY) - { - int StartLine; - int TileLine; - int LineCount; - int Last; - - if ((StartLine = VPos + Y) < (int) GFX.StartY) - { - StartLine = GFX.StartY - StartLine; - LineCount = 8 - StartLine; - } - else - { - StartLine = 0; - LineCount = 8; - } - if ((Last = VPos + Y + 7 - GFX.EndY) > 0) - if ((LineCount -= Last) <= 0) - break; - - TileLine = StartLine << 3; - - //-NoZ----- - //CheckNoZ(VPos + Y + StartLine, LineCount); - //-NoZ----- - - O = (VPos + Y + StartLine) * GFX_PPL; - if (!PPU.OBJ[S].VFlip) Tile = BaseTile + (Y << 1); - else Tile = BaseTile + ((Size - Y - 8) << 1); - - if (Tile & 0x100) BG.TileAddress = bg_ta_ns; - else BG.TileAddress = bg_ta; - - int Middle = Size >> 3; - if (PPU.OBJ[S].HPos < Left) - { - Tile += ((Left - PPU.OBJ[S].HPos) >> 3) * TileInc; - Middle -= (Left - PPU.OBJ[S].HPos) >> 3; - O += Left * GFX_PIXSIZE; - if ((Offset = (Left - PPU.OBJ[S].HPos) & 7)) - { - O -= Offset * GFX_PIXSIZE; - int W = 8 - Offset; - int Width = Right - Left; - if (W > Width) W = Width; - //if (Tile & 0x100) BG.TileAddress = bg_ta_ns; - //else BG.TileAddress = bg_ta; - (*DrawClippedTilePtr) (Tile, O, Offset, W, TileLine, LineCount); - - if (W >= Width) - continue; - Tile += TileInc; - Middle--; - O += 8 * GFX_PIXSIZE; - } - } - else - O += PPU.OBJ[S].HPos * GFX_PIXSIZE; - - if (PPU.OBJ[S].HPos + Size >= Right) - { - Middle -= ((PPU.OBJ[S].HPos + Size + 7) - - Right) >> 3; - Offset = (Right - (PPU.OBJ[S].HPos + Size)) & 7; - } - else - Offset = 0; - - for (int X = 0; X < Middle; X++, O += 8 * GFX_PIXSIZE, - Tile += TileInc) - { - //if (Tile & 0x100) BG.TileAddress = bg_ta_ns; - //else BG.TileAddress = bg_ta; - (*DrawTilePtr) (Tile, O, TileLine, LineCount); - } - if (Offset) - { - //if (Tile & 0x100) BG.TileAddress = bg_ta_ns; - //else BG.TileAddress = bg_ta; - (*DrawClippedTilePtr) (Tile, O, 0, Offset, TileLine, LineCount); - } - } - } - } - } -} -void DrawBackgroundMosaic (uint32 BGMode, uint32 bg, uint8 Z1, uint8 Z2) -{ -#ifdef __DEBUG__ - printf("DrawBackgroundMosaic(%i, %i, %i, %i)\n", BGMode, bg, Z1, Z2); -#endif - CHECK_SOUND(); - - uint32 Tile; - uint16 *SC0; - uint16 *SC1; - uint16 *SC2; - uint16 *SC3; - uint8 depths [2] = {Z1, Z2}; - - if (BGMode == 0) - BG.StartPalette = bg << 5; - else - BG.StartPalette = 0; - SelectPalette(); - - SC0 = (uint16 *) &Memory.VRAM[PPU.BG[bg].SCBase << 1]; - - if (PPU.BG[bg].SCSize & 1) - SC1 = SC0 + 1024; - else - SC1 = SC0; - - if(((uint8*)SC1-Memory.VRAM)>=0x10000) - SC1-=0x08000; - - - if (PPU.BG[bg].SCSize & 2) - SC2 = SC1 + 1024; - else - SC2 = SC0; - - if(((uint8*)SC2-Memory.VRAM)>=0x10000) - SC2-=0x08000; - - - if (PPU.BG[bg].SCSize & 1) - SC3 = SC2 + 1024; - else - SC3 = SC2; - - if(((uint8*)SC3-Memory.VRAM)>=0x10000) - SC3-=0x08000; - - uint32 Lines; - uint32 OffsetMask; - uint32 OffsetShift; - - if (BG.TileSize == 16) - { - OffsetMask = 0x3ff; - OffsetShift = 4; - } - else - { - OffsetMask = 0x1ff; - OffsetShift = 3; - } - - for (uint32 Y = GFX.StartY; Y <= GFX.EndY; Y += Lines) - { - uint32 VOffset = LineData [Y].BG[bg].VOffset; - uint32 HOffset = LineData [Y].BG[bg].HOffset; - uint32 MosaicOffset = Y % PPU.Mosaic; - - for (Lines = 1; Lines < PPU.Mosaic - MosaicOffset; Lines++) - if ((VOffset != LineData [Y + Lines].BG[bg].VOffset) || - (HOffset != LineData [Y + Lines].BG[bg].HOffset)) - break; - - uint32 MosaicLine = VOffset + Y - MosaicOffset; - - if (Y + Lines > GFX.EndY) - Lines = GFX.EndY + 1 - Y; - uint32 VirtAlign = (MosaicLine & 7) << 3; - - uint16 *b1; - uint16 *b2; - - uint32 ScreenLine = MosaicLine >> OffsetShift; - uint32 Rem16 = MosaicLine & 15; - - if (ScreenLine & 0x20) - b1 = SC2, b2 = SC3; - else - b1 = SC0, b2 = SC1; - - b1 += (ScreenLine & 0x1f) << 5; - b2 += (ScreenLine & 0x1f) << 5; - uint16 *t; - uint32 Left = 0; - uint32 Right = 256; - - uint32 ClipCount = GFX.pCurrentClip->Count [bg]; - uint32 HPos = HOffset; - uint32 PixWidth = PPU.Mosaic; - - if (!ClipCount) - ClipCount = 1; - - for (uint32 clip = 0; clip < ClipCount; clip++) - { - if (GFX.pCurrentClip->Count [bg]) - { - Left = GFX.pCurrentClip->Left [clip][bg]; - Right = GFX.pCurrentClip->Right [clip][bg]; - uint32 r = Left % PPU.Mosaic; - HPos = HOffset + Left; - PixWidth = PPU.Mosaic - r; - } - uint32 s = Y * GFX_PPL + Left * GFX_PIXSIZE; - for (uint32 x = Left; x < Right; x += PixWidth, - s += PixWidth * GFX_PIXSIZE, - HPos += PixWidth, PixWidth = PPU.Mosaic) - { - uint32 Quot = (HPos & OffsetMask) >> 3; - - if (x + PixWidth >= Right) - PixWidth = Right - x; - - if (BG.TileSize == 8) - { - if (Quot > 31) - t = b2 + (Quot & 0x1f); - else - t = b1 + Quot; - } - else - { - if (Quot > 63) - t = b2 + ((Quot >> 1) & 0x1f); - else - t = b1 + (Quot >> 1); - } - - Tile = READ_2BYTES (t); - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - - // Draw tile... - if (BG.TileSize != 8) - { - if (Tile & H_FLIP) - { - // Horizontal flip, but what about vertical flip ? - if (Tile & V_FLIP) - { - // Both horzontal & vertical flip - if (Rem16 < 8) - { - (*DrawLargePixelPtr) (Tile + 17 - (Quot & 1), s, - HPos & 7, PixWidth, - VirtAlign, Lines); - } - else - { - (*DrawLargePixelPtr) (Tile + 1 - (Quot & 1), s, - HPos & 7, PixWidth, - VirtAlign, Lines); - } - } - else - { - // Horizontal flip only - if (Rem16 > 7) - { - (*DrawLargePixelPtr) (Tile + 17 - (Quot & 1), s, - HPos & 7, PixWidth, - VirtAlign, Lines); - } - else - { - (*DrawLargePixelPtr) (Tile + 1 - (Quot & 1), s, - HPos & 7, PixWidth, - VirtAlign, Lines); - } - } - } - else - { - // No horizontal flip, but is there a vertical flip ? - if (Tile & V_FLIP) - { - // Vertical flip only - if (Rem16 < 8) - { - (*DrawLargePixelPtr) (Tile + 16 + (Quot & 1), s, - HPos & 7, PixWidth, - VirtAlign, Lines); - } - else - { - (*DrawLargePixelPtr) (Tile + (Quot & 1), s, - HPos & 7, PixWidth, - VirtAlign, Lines); - } - } - else - { - // Normal unflipped - if (Rem16 > 7) - { - (*DrawLargePixelPtr) (Tile + 16 + (Quot & 1), s, - HPos & 7, PixWidth, - VirtAlign, Lines); - } - else - { - (*DrawLargePixelPtr) (Tile + (Quot & 1), s, - HPos & 7, PixWidth, - VirtAlign, Lines); - } - } - } - } - else - (*DrawLargePixelPtr) (Tile, s, HPos & 7, PixWidth, - VirtAlign, Lines); - } - } - } -} - -void DrawBackgroundOffset (uint32 BGMode, uint32 bg, uint8 Z1, uint8 Z2) -{ -#ifdef __DEBUG__ - printf("DrawBackgroundOffse(%i, %i, %i, %i)\n", BGMode, bg, Z1, Z2); -#endif - - CHECK_SOUND(); - - uint32 Tile; - uint16 *SC0; - uint16 *SC1; - uint16 *SC2; - uint16 *SC3; - uint16 *BPS0; - uint16 *BPS1; - uint16 *BPS2; - uint16 *BPS3; - uint32 Width; - int VOffsetOffset = BGMode == 4 ? 0 : 32; - uint8 depths [2] = {Z1, Z2}; - - BG.StartPalette = 0; - SelectPalette(); - - BPS0 = (uint16 *) &Memory.VRAM[PPU.BG[2].SCBase << 1]; - - if (PPU.BG[2].SCSize & 1) - BPS1 = BPS0 + 1024; - else - BPS1 = BPS0; - - if (PPU.BG[2].SCSize & 2) - BPS2 = BPS1 + 1024; - else - BPS2 = BPS0; - - if (PPU.BG[2].SCSize & 1) - BPS3 = BPS2 + 1024; - else - BPS3 = BPS2; - - SC0 = (uint16 *) &Memory.VRAM[PPU.BG[bg].SCBase << 1]; - - if (PPU.BG[bg].SCSize & 1) - SC1 = SC0 + 1024; - else - SC1 = SC0; - - if(((uint8*)SC1-Memory.VRAM)>=0x10000) - SC1-=0x08000; - - - if (PPU.BG[bg].SCSize & 2) - SC2 = SC1 + 1024; - else - SC2 = SC0; - - if(((uint8*)SC2-Memory.VRAM)>=0x10000) - SC2-=0x08000; - - - if (PPU.BG[bg].SCSize & 1) - SC3 = SC2 + 1024; - else - SC3 = SC2; - - if(((uint8*)SC3-Memory.VRAM)>=0x10000) - SC3-=0x08000; - - static const int Lines = 1; - int OffsetMask; - int OffsetShift; - int OffsetEnableMask = 1 << (bg + 13); - - if (BG.TileSize == 16) - { - OffsetMask = 0x3ff; - OffsetShift = 4; - } - else - { - OffsetMask = 0x1ff; - OffsetShift = 3; - } - - TileBlank = 0xFFFFFFFF; - for (uint32 Y = GFX.StartY; Y <= GFX.EndY; Y++) - { - uint32 VOff = LineData [Y].BG[2].VOffset - 1; - uint32 HOff = LineData [Y].BG[2].HOffset; - int VirtAlign; - int ScreenLine = VOff >> 3; - uint16 *s0; - uint16 *s1; - uint16 *s2; - - if (ScreenLine & 0x20) - s1 = BPS2, s2 = BPS3; - else - s1 = BPS0, s2 = BPS1; - - s1 += (ScreenLine & 0x1f) << 5; - s2 += (ScreenLine & 0x1f) << 5; - - if(BGMode != 4) - { - if((ScreenLine & 0x1f) == 0x1f) - { - if(ScreenLine & 0x20) - VOffsetOffset = BPS0 - BPS2 - 0x1f*32; - else - VOffsetOffset = BPS2 - BPS0 - 0x1f*32; - } - else - { - VOffsetOffset = 32; - } - } - int clipcount = GFX.pCurrentClip->Count [bg]; - if (!clipcount) - clipcount = 1; - - for (int clip = 0; clip < clipcount; clip++) - { - uint32 Left; - uint32 Right; - - if (!GFX.pCurrentClip->Count [bg]) - { - Left = 0; - Right = 256; - } - else - { - Left = GFX.pCurrentClip->Left [clip][bg]; - Right = GFX.pCurrentClip->Right [clip][bg]; - - if (Right <= Left) - continue; - } - - uint32 VOffset; - uint32 HOffset; - uint32 LineHOffset=LineData [Y].BG[bg].HOffset; - uint32 Offset; - uint32 HPos; - uint32 Quot; - uint32 Count; - uint16 *t; - uint32 Quot2; - uint32 VCellOffset; - uint32 HCellOffset; - uint16 *b1; - uint16 *b2; - uint32 TotalCount = 0; - uint32 MaxCount = 8; - - uint32 s = Left * GFX_PIXSIZE + Y * GFX_PPL; - bool8_32 left_hand_edge = (Left == 0); - Width = Right - Left; - - if (Left & 7) - MaxCount = 8 - (Left & 7); - - while (Left < Right) - { - if (left_hand_edge) - { - // The SNES offset-per-tile background mode has a - // hardware limitation that the offsets cannot be set - // for the tile at the left-hand edge of the screen. - VOffset = LineData [Y].BG[bg].VOffset; - HOffset = LineHOffset; - left_hand_edge = FALSE; - } - else - { - // All subsequent offset tile data is shifted left by one, - // hence the - 1 below. - Quot2 = ((HOff + Left - 1) & OffsetMask) >> 3; - - if (Quot2 > 31) - s0 = s2 + (Quot2 & 0x1f); - else - s0 = s1 + Quot2; - - HCellOffset = READ_2BYTES (s0); - - if (BGMode == 4) - { - VOffset = LineData [Y].BG[bg].VOffset; - HOffset=LineHOffset; - if ((HCellOffset & OffsetEnableMask)) - { - if (HCellOffset & 0x8000) - VOffset = HCellOffset + 1; - else - HOffset = HCellOffset; - } - } - else - { - VCellOffset = READ_2BYTES (s0 + VOffsetOffset); - if ((VCellOffset & OffsetEnableMask)) - VOffset = VCellOffset + 1; - else - VOffset = LineData [Y].BG[bg].VOffset; - - if ((HCellOffset & OffsetEnableMask)) - HOffset = (HCellOffset & ~7)|(LineHOffset&7); - else - HOffset=LineHOffset; - } - } - VirtAlign = ((Y + VOffset) & 7) << 3; - ScreenLine = (VOffset + Y) >> OffsetShift; - - int tx_index; - tx_index = ( ((VOffset + Y) & 15) <= 7 ) << 3; - - if (ScreenLine & 0x20) - b1 = SC2, b2 = SC3; - else - b1 = SC0, b2 = SC1; - - b1 += (ScreenLine & 0x1f) << 5; - b2 += (ScreenLine & 0x1f) << 5; - - HPos = (HOffset + Left) & OffsetMask; - - Quot = HPos >> 3; - - if (BG.TileSize == 8) - { - if (Quot > 31) - t = b2 + (Quot & 0x1f); - else - t = b1 + Quot; - } - else - { - if (Quot > 63) - t = b2 + ((Quot >> 1) & 0x1f); - else - t = b1 + (Quot >> 1); - } - - if (MaxCount + TotalCount > Width) - MaxCount = Width - TotalCount; - - Offset = HPos & 7; - - Count = 8 - Offset; - if (Count > MaxCount) - Count = MaxCount; - - s -= Offset * GFX_PIXSIZE; - Tile = READ_2BYTES(t); - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - - if (Tile != TileBlank) - if (BG.TileSize == 8) - (*DrawClippedTilePtr) (Tile, s, Offset, Count, VirtAlign, Lines); - else - { - Tile += tx_table[tx_index + ((Tile & (H_FLIP | V_FLIP)) >> 13) + (Quot & 1)]; - if (Tile != TileBlank){ - (*DrawClippedTilePtr) (Tile, s, Offset, Count, VirtAlign, Lines); - } - } - - Left += Count; - TotalCount += Count; - s += (Offset + Count) * GFX_PIXSIZE; - MaxCount = 8; - } - } - } -} - -void DrawBackgroundMode5 (uint32 /* BGMODE */, uint32 bg, uint8 Z1, uint8 Z2) -{ -#ifdef __DEBUG__ - printf("DrawBackgroundMode5(?, %i, %i, %i)\n", bg, Z1, Z2); -#endif - - CHECK_SOUND(); - - uint8 depths [2] = {Z1, Z2}; - - uint32 Tile; - uint16 *SC0; - uint16 *SC1; - uint16 *SC2; - uint16 *SC3; - uint32 Width; - - BG.StartPalette = 0; - SelectPalette(); - - SC0 = (uint16 *) &Memory.VRAM[PPU.BG[bg].SCBase << 1]; - - if ((PPU.BG[bg].SCSize & 1)) - SC1 = SC0 + 1024; - else - SC1 = SC0; - - if((SC1-(unsigned short*)Memory.VRAM)>0x10000) - SC1=(uint16*)&Memory.VRAM[(((uint8*)SC1)-Memory.VRAM)%0x10000]; - - if ((PPU.BG[bg].SCSize & 2)) - SC2 = SC1 + 1024; - else SC2 = SC0; - - if(((uint8*)SC2-Memory.VRAM)>=0x10000) - SC2-=0x08000; - - if ((PPU.BG[bg].SCSize & 1)) - SC3 = SC2 + 1024; - else - SC3 = SC2; - - if(((uint8*)SC3-Memory.VRAM)>=0x10000) - SC3-=0x08000; - int Lines; - int VOffsetMask; - int VOffsetShift; - - if (BG.TileSize == 16) - { - VOffsetMask = 0x3ff; - VOffsetShift = 4; - } - else - { - VOffsetMask = 0x1ff; - VOffsetShift = 3; - } - int endy = GFX.EndY; - - for (int Y = GFX.StartY; Y <= endy; Y += Lines) - { - //int y = Y; - uint32 VOffset = LineData [Y].BG[bg].VOffset; - uint32 HOffset = LineData [Y].BG[bg].HOffset; - int VirtAlign = (Y + VOffset) & 7; - - for (Lines = 1; Lines < 8 - VirtAlign; Lines++) - if ((VOffset != LineData [Y + Lines].BG[bg].VOffset) || - (HOffset != LineData [Y + Lines].BG[bg].HOffset)) - break; - - HOffset <<= 1; - if (Y + Lines > endy) - Lines = endy + 1 - Y; - - int ScreenLine = (VOffset + Y) >> VOffsetShift; - int t1; - int t2; - if (((VOffset + Y) & 15) > 7) - { - t1 = 16; - t2 = 0; - } - else - { - t1 = 0; - t2 = 16; - } - uint16 *b1; - uint16 *b2; - - if (ScreenLine & 0x20) - b1 = SC2, b2 = SC3; - else - b1 = SC0, b2 = SC1; - - b1 += (ScreenLine & 0x1f) << 5; - b2 += (ScreenLine & 0x1f) << 5; - - int clipcount = GFX.pCurrentClip->Count [bg]; - if (!clipcount) - clipcount = 1; - for (int clip = 0; clip < clipcount; clip++) - { - int Left; - int Right; - - if (!GFX.pCurrentClip->Count [bg]) - { - Left = 0; - Right = 512; - } - else - { - Left = GFX.pCurrentClip->Left [clip][bg] * 2; - Right = GFX.pCurrentClip->Right [clip][bg] * 2; - - if (Right <= Left) - continue; - } - - uint32 s = (Left>>1) * GFX_PIXSIZE + Y * GFX_PPL; - uint32 HPos = (HOffset + Left * GFX_PIXSIZE) & 0x3ff; - - uint32 Quot = HPos >> 3; - uint32 Count = 0; - - uint16 *t; - if (Quot > 63) - t = b2 + ((Quot >> 1) & 0x1f); - else - t = b1 + (Quot >> 1); - - Width = Right - Left; - // Left hand edge clipped tile - if (HPos & 7) - { - int Offset = (HPos & 7); - Count = 8 - Offset; - if (Count > Width) - Count = Width; - s -= (Offset>>1); - Tile = READ_2BYTES (t); - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - - if (BG.TileSize == 8) - { - if (!(Tile & H_FLIP)) - { - // Normal, unflipped - (*DrawHiResClippedTilePtr) (Tile + (Quot & 1), - s, Offset, Count, VirtAlign, Lines); - } - else - { - // H flip - (*DrawHiResClippedTilePtr) (Tile + 1 - (Quot & 1), - s, Offset, Count, VirtAlign, Lines); - } - } - else - { - if (!(Tile & (V_FLIP | H_FLIP))) - { - // Normal, unflipped - (*DrawHiResClippedTilePtr) (Tile + t1 + (Quot & 1), - s, Offset, Count, VirtAlign, Lines); - } - else - if (Tile & H_FLIP) - { - if (Tile & V_FLIP) - { - // H & V flip - (*DrawHiResClippedTilePtr) (Tile + t2 + 1 - (Quot & 1), - s, Offset, Count, VirtAlign, Lines); - } - else - { - // H flip only - (*DrawHiResClippedTilePtr) (Tile + t1 + 1 - (Quot & 1), - s, Offset, Count, VirtAlign, Lines); - } - } - else - { - // V flip only - (*DrawHiResClippedTilePtr) (Tile + t2 + (Quot & 1), - s, Offset, Count, VirtAlign, Lines); - } - } - - t += Quot & 1; - if (Quot == 63) - t = b2; - else if (Quot == 127) - t = b1; - Quot++; - s += 4; - } - - // Middle, unclipped tiles - Count = Width - Count; - int Middle = Count >> 3; - Count &= 7; - for (int C = Middle; C > 0; s += 4, Quot++, C--) - { - Tile = READ_2BYTES(t); - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - if (BG.TileSize == 8) - { - if (!(Tile & H_FLIP)) - { - // Normal, unflipped - (*DrawHiResTilePtr) (Tile + (Quot & 1), - s, VirtAlign, Lines); - } - else - { - // H flip - (*DrawHiResTilePtr) (Tile + 1 - (Quot & 1), - s, VirtAlign, Lines); - } - } - else - { - if (!(Tile & (V_FLIP | H_FLIP))) - { - // Normal, unflipped - (*DrawHiResTilePtr) (Tile + t1 + (Quot & 1), - s, VirtAlign, Lines); - } - else - if (Tile & H_FLIP) - { - if (Tile & V_FLIP) - { - // H & V flip - (*DrawHiResTilePtr) (Tile + t2 + 1 - (Quot & 1), - s, VirtAlign, Lines); - } - else - { - // H flip only - (*DrawHiResTilePtr) (Tile + t1 + 1 - (Quot & 1), - s, VirtAlign, Lines); - } - } - else - { - // V flip only - (*DrawHiResTilePtr) (Tile + t2 + (Quot & 1), - s, VirtAlign, Lines); - } - } - - t += Quot & 1; - if (Quot == 63) - t = b2; - else - if (Quot == 127) - t = b1; - } - - // Right-hand edge clipped tiles - if (Count) - { - Tile = READ_2BYTES(t); - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - if (BG.TileSize == 8) - { - if (!(Tile & H_FLIP)) - { - // Normal, unflipped - (*DrawHiResClippedTilePtr) (Tile + (Quot & 1), - s, 0, Count, VirtAlign, Lines); - } - else - { - // H flip - (*DrawHiResClippedTilePtr) (Tile + 1 - (Quot & 1), - s, 0, Count, VirtAlign, Lines); - } - } - else - { - if (!(Tile & (V_FLIP | H_FLIP))) - { - // Normal, unflipped - (*DrawHiResClippedTilePtr) (Tile + t1 + (Quot & 1), - s, 0, Count, VirtAlign, Lines); - } - else - if (Tile & H_FLIP) - { - if (Tile & V_FLIP) - { - // H & V flip - (*DrawHiResClippedTilePtr) (Tile + t2 + 1 - (Quot & 1), - s, 0, Count, VirtAlign, Lines); - } - else - { - // H flip only - (*DrawHiResClippedTilePtr) (Tile + t1 + 1 - (Quot & 1), - s, 0, Count, VirtAlign, Lines); - } - } - else - { - // V flip only - (*DrawHiResClippedTilePtr) (Tile + t2 + (Quot & 1), - s, 0, Count, VirtAlign, Lines); - } - } - } - } - } -} - -void DrawBackground_8 (uint32 BGMode, uint32 bg, uint8 Z1, uint8 Z2) -{ -#ifdef __DEBUG__ - printf("DrawBackground_8(%i, %i, %i, %i)\n", BGMode, bg, Z1, Z2); -#endif - //uint32 Tile; - uint16 *SC0; - uint16 *SC1; - uint16 *SC2; - uint16 *SC3; - uint32 depths [2] = {Z1, Z2}; - - SC0 = (uint16 *) &Memory.VRAM[PPU.BG[bg].SCBase << 1]; - - SC1 = (uint16 *) &Memory.VRAM[((PPU.BG[bg].SCBase << 1) + ((PPU.BG[bg].SCSize & 1) << 10)) & 0xffff]; - //SC1 = SC0 + ((PPU.BG[bg].SCSize & 1) << 10); - - //if(SC1 >= (unsigned short*)(Memory.VRAM+0x10000)) SC1 = (uint16*)&Memory.VRAM[((uint8*)SC1-&Memory.VRAM[0]) & 0xffff]; - - if (PPU.BG[bg].SCSize & 2) - SC2 = SC1 + 1024; - else - SC2 = SC0; - - if(((uint8*)SC2-Memory.VRAM)>=0x10000) SC2 -= 0x08000; - - SC3 = SC2 + ((PPU.BG[bg].SCSize & 1) << 10); - - if(((uint8*)SC3-Memory.VRAM)>=0x10000) SC3 -= 0x08000; - - int Lines; - - TileBlank = 0xFFFFFFFF; - for (uint32 Y = GFX.StartY; Y <= GFX.EndY; Y += Lines){ - int y_ppl = Y * GFX_PPL; - uint32 VOffset = LineData [Y].BG[bg].VOffset; - uint32 HOffset = LineData [Y].BG[bg].HOffset; - int VirtAlign = (Y + VOffset) & 7; - - int maxLines = GFX.EndY - Y + 1; - if ((8 - VirtAlign) < maxLines) maxLines = (8 - VirtAlign); - - for (Lines = 1; Lines < maxLines; Lines++) - if ((VOffset != LineData [Y + Lines].BG[bg].VOffset) || - (HOffset != LineData [Y + Lines].BG[bg].HOffset)) - break; - - - VirtAlign <<= 3; - - uint32 ScreenLine = (VOffset + Y) >> 3; - uint16 *b1; - uint16 *b2; - - if (ScreenLine & 0x20) - b1 = SC2, b2 = SC3; - else - b1 = SC0, b2 = SC1; - - b1 += (ScreenLine & 0x1f) << 5; - b2 += (ScreenLine & 0x1f) << 5; - - uint32 Left; - uint32 Right; - int clip = 0; - int clipcount = GFX.pCurrentClip->Count [bg]; - if (!clipcount) { - Left = 0; - Right = 256; - } - - do { - if (clipcount) { - Left = GFX.pCurrentClip->Left [clip][bg]; - Right = GFX.pCurrentClip->Right [clip][bg]; - - if (Right <= Left) {clip++; continue;} - } - - uint32 s = Left + y_ppl; - uint32 HPos = (HOffset + Left) & 0x1ff; - uint32 Quot = HPos >> 3; - uint32 Count = 0; - uint16 *t; - uint16 *b; - - if (Quot > 31) { - t = b2 + (Quot & 0x1f); - b = b1; - Quot -= 32; - } - else { - t = b1 + Quot; - b = b2; - } - - uint32 Width = Right - Left; - - // Left hand edge clipped tile - uint32 Offset = (HPos & 7); - if (Offset){ - Count = 8 - Offset; - if (Count > Width) Count = Width; - s -= Offset; - //Tile = READ_2BYTES(t); - register uint32 Tile = *(t++); - if (Tile != TileBlank){ - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - (*DrawClippedTilePtr) (Tile, s, Offset, Count, VirtAlign, Lines); - } - //t++; - if (Quot == 31) t = b; - //else if (Quot == 63) t = b1; - Quot++; - s += 8; - } - - // Middle, unclipped tiles - Count = Width - Count; - for (int C = Count >> 3; C > 0; s += 8, Quot++, C--){ - //Tile = READ_2BYTES(t); - register uint32 Tile = *(t++); - if (Tile != TileBlank){ - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - (*DrawTilePtr) (Tile, s, VirtAlign, Lines); - } - - //t++; - if (Quot == 31) t = b; - //else if (Quot == 63) t = b1; - } - - // Right-hand edge clipped tiles - if (Count & 7){ - //Tile = READ_2BYTES(t); - register uint32 Tile = *t; - if (Tile != TileBlank){ - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - (*DrawClippedTilePtr) (Tile, s, 0, Count & 7, VirtAlign, Lines); - } - } - clip ++; - } while (clip < clipcount); - } -} - -void DrawBackground_16 (uint32 BGMode, uint32 bg, uint8 Z1, uint8 Z2) -{ -#ifdef __DEBUG__ - printf("DrawBackground_16(%i, %i, %i, %i)\n", BGMode, bg, Z1, Z2); -#endif - //uint32 Tile; - uint16 *SC0; - uint16 *SC1; - uint16 *SC2; - uint16 *SC3; - uint32 depths [2] = {Z1, Z2}; - - SC0 = (uint16 *) &Memory.VRAM[PPU.BG[bg].SCBase << 1]; - - SC1 = (uint16 *) &Memory.VRAM[((PPU.BG[bg].SCBase << 1) + ((PPU.BG[bg].SCSize & 1) << 10)) & 0xffff]; - //SC1 = SC0 + ((PPU.BG[bg].SCSize & 1) << 10); - - //if(SC1 >= (unsigned short*)(Memory.VRAM+0x10000)) SC1 = (uint16*)&Memory.VRAM[((uint8*)SC1-&Memory.VRAM[0]) & 0xffff]; - - if (PPU.BG[bg].SCSize & 2) - SC2 = SC1 + 1024; - else - SC2 = SC0; - - if(((uint8*)SC2-Memory.VRAM)>=0x10000) SC2 -= 0x08000; - - SC3 = SC2 + ((PPU.BG[bg].SCSize & 1) << 10); - - if(((uint8*)SC3-Memory.VRAM)>=0x10000) SC3 -= 0x08000; - - int Lines; - - TileBlank = 0xFFFFFFFF; - for (uint32 Y = GFX.StartY; Y <= GFX.EndY; Y += Lines){ - int y_ppl = Y * GFX_PPL; - uint32 VOffset = LineData [Y].BG[bg].VOffset; - uint32 HOffset = LineData [Y].BG[bg].HOffset; - int VirtAlign = (Y + VOffset) & 7; - - int maxLines = GFX.EndY - Y + 1; - if ((8 - VirtAlign) < maxLines) maxLines = (8 - VirtAlign); - - for (Lines = 1; Lines < maxLines; Lines++) - if ((VOffset != LineData [Y + Lines].BG[bg].VOffset) || - (HOffset != LineData [Y + Lines].BG[bg].HOffset)) - break; - - - VirtAlign <<= 3; - - uint32 ScreenLine = (VOffset + Y) >> 4; - //int tx_index = ( ((VOffset + Y) & 15) <= 7 ) << 3; - int tx_index = ((((VOffset + Y) & 15) <= 7 ) << 4) ^ (16); - uint16 *b1; - uint16 *b2; - - if (ScreenLine & 0x20) - b1 = SC2, b2 = SC3; - else - b1 = SC0, b2 = SC1; - - b1 += (ScreenLine & 0x1f) << 5; - b2 += (ScreenLine & 0x1f) << 5; - - uint32 Left; - uint32 Right; - int clip = 0; - int clipcount = GFX.pCurrentClip->Count [bg]; - if (!clipcount) { - Left = 0; - Right = 256; - } - - do { - if (clipcount) { - Left = GFX.pCurrentClip->Left [clip][bg]; - Right = GFX.pCurrentClip->Right [clip][bg]; - - if (Right <= Left) {clip++; continue;} - } - - uint32 s = Left + y_ppl; - uint32 HPos = (HOffset + Left) & 0x3ff; - uint32 Quot = HPos >> 3; - uint32 Count = 0; - uint16 *t; - uint16 *b; - - if (Quot > 63) { - t = b2 + ((Quot >> 1) & 0x1f); - b = b1; - Quot -= 64; - } - else { - t = b1 + (Quot >> 1); - b = b2; - } - - - uint32 Width = Right - Left; - - // Left hand edge clipped tile - uint32 Offset = (HPos & 7); - if (Offset){ - Count = 8 - Offset; - if (Count > Width) Count = Width; - s -= Offset; - //Tile = READ_2BYTES(t); - uint32 Tile = *(t); - t += Quot & 1; - Tile += (((Tile & H_FLIP) >> 14) ^ (Quot & 1)) + (((Tile & V_FLIP) >> 11) ^ tx_index); - //Tile += tx_table[tx_index + ((Tile & (H_FLIP | V_FLIP)) >> 13) + (Quot & 1)]; - if (Tile != TileBlank){ - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - (*DrawClippedTilePtr) (Tile, s, Offset, Count, VirtAlign, Lines); - } - //t++; - if (Quot == 63) t = b; - Quot++; - s += 8; - } - - - // Middle, unclipped tiles - Count = Width - Count; - for (int C = Count >> 3; C > 0; s += 8, Quot++, C--){ - //Tile = READ_2BYTES(t); - uint32 Tile = *(t); - t += Quot & 1; - Tile += (((Tile & H_FLIP) >> 14) ^ (Quot & 1)) + (((Tile & V_FLIP) >> 11) ^ tx_index); - //Tile += tx_table[tx_index + ((Tile & (H_FLIP | V_FLIP)) >> 13) + (Quot & 1)]; - if (Tile != TileBlank){ - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - (*DrawTilePtr) (Tile, s, VirtAlign, Lines); - } - - //t++; - if (Quot == 63) t = b; - } - - // Right-hand edge clipped tiles - if (Count & 7){ - //Tile = READ_2BYTES(t); - uint32 Tile = *(t); - Tile += (((Tile & H_FLIP) >> 14) ^ (Quot & 1)) + (((Tile & V_FLIP) >> 11) ^ tx_index); - //Tile += tx_table[tx_index + ((Tile & (H_FLIP | V_FLIP)) >> 13) + (Quot & 1)]; - if (Tile != TileBlank){ - GFX.Z1 = GFX.Z2 = depths [(Tile & 0x2000) >> 13]; - (*DrawClippedTilePtr) (Tile, s, 0, Count & 7, VirtAlign, Lines); - } - } - clip ++; - } while (clip < clipcount); - } -} - -inline void DrawBackground (uint32 BGMode, uint32 bg, uint8 Z1, uint8 Z2) -{ -//StartAnalyze(); - - BG.TileSize = BGSizes [PPU.BG[bg].BGSize]; - BG.BitShift = BitShifts[BGMode][bg]; - SelectConvertTile(); - BG.TileShift = TileShifts[BGMode][bg]; - BG.TileAddress = PPU.BG[bg].NameBase << 1; - BG.NameSelect = 0; - BG.Buffer = IPPU.TileCache [Depths [BGMode][bg]]; - BG.Buffered = IPPU.TileCached [Depths [BGMode][bg]]; - BG.PaletteShift = PaletteShifts[BGMode][bg]; - BG.PaletteMask = PaletteMasks[BGMode][bg]; - BG.DirectColourMode = (BGMode == 3 || BGMode == 4) && bg == 0 && (GFX.r2130 & 1); - - if (IPPU.DirectColourMapsNeedRebuild && BG.DirectColourMode) S9xBuildDirectColourMaps (); - - if (PPU.BGMosaic [bg] && PPU.Mosaic > 1){ - DrawBackgroundMosaic (BGMode, bg, Z1, Z2); - return; - - } - switch (BGMode) - { - case 2: - case 4: // Used by Puzzle Bobble - DrawBackgroundOffset (BGMode, bg, Z1, Z2); - break; - - case 5: - case 6: // XXX: is also offset per tile. - DrawBackgroundMode5 (BGMode, bg, Z1, Z2); - break; - case 0: - case 1: - case 3: - CHECK_SOUND(); - - if (BGMode == 0) BG.StartPalette = bg << 5; - else BG.StartPalette = 0; - SelectPalette(); - - if (BG.TileSize == 8) DrawBackground_8 (BGMode, bg, Z1, Z2); - else DrawBackground_16 (BGMode, bg, Z1, Z2); - break; - } -} - -#define _BUILD_SETUP(F) \ -GFX.BuildPixel = BuildPixel##F; \ -GFX.BuildPixel2 = BuildPixel2##F; \ -GFX.DecomposePixel = DecomposePixel##F; \ -RED_LOW_BIT_MASK = RED_LOW_BIT_MASK_##F; \ -GREEN_LOW_BIT_MASK = GREEN_LOW_BIT_MASK_##F; \ -BLUE_LOW_BIT_MASK = BLUE_LOW_BIT_MASK_##F; \ -RED_HI_BIT_MASK = RED_HI_BIT_MASK_##F; \ -GREEN_HI_BIT_MASK = GREEN_HI_BIT_MASK_##F; \ -BLUE_HI_BIT_MASK = BLUE_HI_BIT_MASK_##F; \ -MAX_RED = MAX_RED_##F; \ -MAX_GREEN = MAX_GREEN_##F; \ -MAX_BLUE = MAX_BLUE_##F; \ -GREEN_HI_BIT = ((MAX_GREEN_##F + 1) >> 1); \ -SPARE_RGB_BIT_MASK = SPARE_RGB_BIT_MASK_##F; \ -RGB_LOW_BITS_MASK = (RED_LOW_BIT_MASK_##F | \ - GREEN_LOW_BIT_MASK_##F | \ - BLUE_LOW_BIT_MASK_##F); \ -RGB_HI_BITS_MASK = (RED_HI_BIT_MASK_##F | \ - GREEN_HI_BIT_MASK_##F | \ - BLUE_HI_BIT_MASK_##F); \ -RGB_HI_BITS_MASKx2 = ((RED_HI_BIT_MASK_##F | \ - GREEN_HI_BIT_MASK_##F | \ - BLUE_HI_BIT_MASK_##F) << 1); \ -RGB_REMOVE_LOW_BITS_MASK = ~RGB_LOW_BITS_MASK; \ -FIRST_COLOR_MASK = FIRST_COLOR_MASK_##F; \ -SECOND_COLOR_MASK = SECOND_COLOR_MASK_##F; \ -THIRD_COLOR_MASK = THIRD_COLOR_MASK_##F; \ -ALPHA_BITS_MASK = ALPHA_BITS_MASK_##F; \ -FIRST_THIRD_COLOR_MASK = FIRST_COLOR_MASK | THIRD_COLOR_MASK; \ -TWO_LOW_BITS_MASK = RGB_LOW_BITS_MASK | (RGB_LOW_BITS_MASK << 1); \ -HIGH_BITS_SHIFTED_TWO_MASK = (( (FIRST_COLOR_MASK | SECOND_COLOR_MASK | THIRD_COLOR_MASK) & \ - ~TWO_LOW_BITS_MASK ) >> 2); - -void RenderScreen (uint8 *Screen, bool8_32 sub, bool8_32 force_no_add, uint8 D) -{ - bool8_32 BG0; - bool8_32 BG1; - bool8_32 BG2; - bool8_32 BG3; - bool8_32 OB; - - GFX.S = Screen; - - if (!sub) - { - GFX.pCurrentClip = &IPPU.Clip [0]; - BG0 = ON_MAIN (0) && !(Settings.os9x_hack & GFX_IGNORE_BG0); - BG1 = ON_MAIN (1) && !(Settings.os9x_hack & GFX_IGNORE_BG1); - BG2 = ON_MAIN (2) && !(Settings.os9x_hack & GFX_IGNORE_BG2); - BG3 = ON_MAIN (3) && !(Settings.os9x_hack & GFX_IGNORE_BG3); - OB = ON_MAIN (4) && !(Settings.os9x_hack & GFX_IGNORE_OBJ); - } - else - { - GFX.pCurrentClip = &IPPU.Clip [1]; - BG0 = ON_SUB (0) && !(Settings.os9x_hack & GFX_IGNORE_BG0); - BG1 = ON_SUB (1) && !(Settings.os9x_hack & GFX_IGNORE_BG1); - BG2 = ON_SUB (2) && !(Settings.os9x_hack & GFX_IGNORE_BG2); - BG3 = ON_SUB (3) && !(Settings.os9x_hack & GFX_IGNORE_BG3); - OB = ON_SUB (4) && !(Settings.os9x_hack & GFX_IGNORE_OBJ); - } - -#ifdef __DEBUG__ - printf("Screen[y1,y2]:[%i,%i],Mode:%i, BG0:%i,BG1:%i,BG2:%i,BG3:%i,OBJ:%i\n", GFX.StartY, GFX.EndY, PPU.BGMode, BG0, BG1, BG2, BG3, OB); -#endif - - sub |= force_no_add; - - if (PPU.BGMode <= 1) - { - if (OB) - { - SelectTileRenderer (sub || !SUB_OR_ADD(4), true); - DrawOBJS (!sub, D); - } - if (BG0) - { - SelectTileRenderer (sub || !SUB_OR_ADD(0), false); - DrawBackground (PPU.BGMode, 0, D + 10, D + 14); - } - if (BG1) - { - SelectTileRenderer (sub || !SUB_OR_ADD(1), false); - DrawBackground (PPU.BGMode, 1, D + 9, D + 13); - } - if (BG2) - { - SelectTileRenderer (sub || !SUB_OR_ADD(2), false); - DrawBackground (PPU.BGMode, 2, D + 3, - PPU.BG3Priority ? D + 17 : D + 6); - } - if (BG3 && PPU.BGMode == 0) - { - SelectTileRenderer (sub || !SUB_OR_ADD(3), false); - DrawBackground (PPU.BGMode, 3, D + 2, D + 5); - } - } - else if (PPU.BGMode != 7) - { - if (OB) - { - SelectTileRenderer (sub || !SUB_OR_ADD(4), true); - DrawOBJS (!sub, D); - } - if (BG0) - { - SelectTileRenderer (sub || !SUB_OR_ADD(0), false); - DrawBackground (PPU.BGMode, 0, D + 5, D + 13); - } - if (PPU.BGMode != 6 && BG1) - { - SelectTileRenderer (sub || !SUB_OR_ADD(1), false); - DrawBackground (PPU.BGMode, 1, D + 2, D + 9); - } - } - else - { - if (OB && ((SNESGameFixes.Mode7Hack && D) || !SNESGameFixes.Mode7Hack)) - { - SelectTileRenderer (sub || !SUB_OR_ADD(4), true); - DrawOBJS (!sub, D); - } - if (BG0 || ((Memory.FillRAM [0x2133] & 0x40) && BG1)) - { - int bg; - - if ((Memory.FillRAM [0x2133] & 0x40)&&BG1) - { - Mode7Depths [0] = (BG0?5:1) + D; - Mode7Depths [1] = 9 + D; - bg = 1; - if (sub || !SUB_OR_ADD(0)) - { - DrawBGMode7Background16Prio (Screen, bg); - } - else - { - if (GFX.r2131 & 0x80) - { - if (GFX.r2131 & 0x40) - { - DrawBGMode7Background16PrioSub1_2 (Screen, bg); - } - else - { - DrawBGMode7Background16PrioSub (Screen, bg); - } - } - else - { - if (GFX.r2131 & 0x40) - { - DrawBGMode7Background16PrioAdd1_2 (Screen, bg); - } - else - { - DrawBGMode7Background16PrioAdd (Screen, bg); - } - } - } - } - else - { - bg = 0; - if (sub || !SUB_OR_ADD(0)) - { - if (D || !SNESGameFixes.Mode7Hack) DrawBGMode7Background16 (Screen, bg, D+5); - else DrawBGMode7Background16New (Screen); - } - else - { - if (GFX.r2131 & 0x80) - { - if (GFX.r2131 & 0x40) - { - DrawBGMode7Background16Sub1_2 (Screen, bg, D+5); - } - else - { - DrawBGMode7Background16Sub (Screen, bg, D+5); - } - } - else - { - if (GFX.r2131 & 0x40) - { - DrawBGMode7Background16Add1_2 (Screen, bg, D+5); - } - else - { - DrawBGMode7Background16Add (Screen, bg, D+5); - } - } - } - } - } - if (OB && SNESGameFixes.Mode7Hack && D==0) - { - SelectTileRenderer (sub || !SUB_OR_ADD(4), true); - DrawOBJS (!sub, D); - } - } -} - -#include "font.h" - -void DisplayChar (uint8 *Screen, uint8 c) -{ - int line = (((c & 0x7f) - 32) >> 4) * font_height; - int offset = (((c & 0x7f) - 32) & 15) * font_width; - int h, w; - uint16 *s = (uint16 *) Screen; - for (h = 0; h < font_height; h++, line++, - s += GFX_PPL - font_width) - { - for (w = 0; w < font_width; w++, s++) - { - uint8 p = font [line][offset + w]; - - if (p == '#') - *s = 0xffff; - else - if (p == '.') - *s = BLACK; - } - } -} - -static void S9xDisplayFrameRate () -{ - uint8 *Screen = GFX.Screen + 2 + - (IPPU.RenderedScreenHeight - font_height - 1) * GFX_PITCH; - char string [10]; - int len = 5; - - sprintf (string, "%02d/%02d", IPPU.DisplayedRenderedFrameCount, - (int) Memory.ROMFramesPerSecond); - - int i; - for (i = 0; i < len; i++) - { - DisplayChar (Screen, string [i]); - Screen += (font_width - 1) * sizeof (uint16); - } -} - -static void S9xDisplayString (const char *string) -{ - uint8 *Screen = GFX.Screen + 2 + - (IPPU.RenderedScreenHeight - font_height * 5) * GFX_PITCH; - int len = strlen (string); - int max_chars = IPPU.RenderedScreenWidth / (font_width - 1); - int char_count = 0; - int i; - - for (i = 0; i < len; i++, char_count++) - { - if (char_count >= max_chars || string [i] < 32) - { - Screen -= (font_width - 1) * sizeof (uint16) * max_chars; - Screen += font_height * GFX_PITCH; - if (Screen >= GFX.Screen + GFX_PITCH * IPPU.RenderedScreenHeight) - break; - char_count -= max_chars; - } - if (string [i] < 32) - continue; - DisplayChar (Screen, string [i]); - Screen += (font_width - 1) * sizeof (uint16); - } -} - - -void S9xUpdateScreen () // ~30-50ms! (called from FLUSH_REDRAW()) -{ - GFX.S = GFX.Screen; - - unsigned char *memoryfillram = Memory.FillRAM; - - // get local copies of vid registers to be used later - GFX.r2131 = memoryfillram [0x2131]; // ADDITION/SUBTRACTION & SUBTRACTION DESIGNATION FOR EACH SCREEN - GFX.r212c = memoryfillram [0x212c]; // MAIN SCREEN, DESIGNATION - used to enable BGS - GFX.r212d = memoryfillram [0x212d]; // SUB SCREEN DESIGNATION - used to enable sub BGS - GFX.r2130 = memoryfillram [0x2130]; // INITIAL SETTINGS FOR FIXED COLOR ADDITION OR SCREEN ADDITION - - // If external sync is off and - // main screens have not been configured the same as the sub screen and - // color addition and subtraction has been diabled then - // Pseudo is 1 - // anything else it is 0 - GFX.Pseudo = (memoryfillram [0x2133] & 8) != 0 && // Use EXTERNAL SYNCHRONIZATION? - (GFX.r212c & 15) != (GFX.r212d & 15) && // Are the main screens different from the sub screens? - (GFX.r2131 & 0x3f) == 0; // Is colour data addition/subtraction disabled on all BGS? - - // If sprite data has been changed then go through and - // refresh the sprites. - if (IPPU.OBJChanged) S9xSetupOBJ (); - - if (PPU.RecomputeClipWindows) ComputeClipWindows (); - - GFX.StartY = IPPU.PreviousLine; - if ((GFX.EndY = IPPU.CurrentLine - 1) >= PPU.ScreenHeight) - GFX.EndY = PPU.ScreenHeight - 1; - - uint32 starty = GFX.StartY; - uint32 endy = GFX.EndY; - uint32 black = BLACK | (BLACK << 16); - - - if (GFX.Pseudo) - { - GFX.r2131 = 0x5f; //0101 1111 - enable addition/subtraction on all BGS and sprites and "1/2 OF COLOR DATA" DESIGNATION - GFX.r212c &= (Memory.FillRAM [0x212d] | 0xf0); - GFX.r212d |= (Memory.FillRAM [0x212c] & 0x0f); - GFX.r2130 |= 2; // enable ADDITION/SUBTRACTION FOR SUB SCREEN - } - - // Check to see if any transparency effects are currently in use - if (!PPU.ForcedBlanking && ADD_OR_SUB_ON_ANYTHING && - (GFX.r2130 & 0x30) != 0x30 && - !((GFX.r2130 & 0x30) == 0x10 && IPPU.Clip[1].Count[5] == 0)) - { - // transparency effects in use, so lets get busy! - ClipData *pClip; - uint32 fixedColour; - GFX.FixedColour = BUILD_PIXEL (IPPU.XB [PPU.FixedColourRed], - IPPU.XB [PPU.FixedColourGreen], - IPPU.XB [PPU.FixedColourBlue]); - fixedColour = (GFX.FixedColour<<16|GFX.FixedColour); - // Clear the z-buffer, marking areas 'covered' by the fixed - // colour as depth 1. - pClip = &IPPU.Clip [1]; - - // Clear the z-buffer - - if (pClip->Count [5]) - { - - // Colour window enabled. - // loop around all of the lines being updated - for (uint32 y = starty; y <= endy; y++) - { - // Clear the subZbuffer - memset32 ((uint32_t*)(GFX.SubZBuffer + y * GFX_ZPITCH),0, (256>>2)); - // Clear the Zbuffer - memset32 ((uint32_t*)(GFX.ZBuffer + y * GFX_ZPITCH),0, (256>>2)); - if (IPPU.Clip[0].Count [5]) { - // if there is clipping then clear subscreen to a black color - memset32 ((uint32_t*)(GFX.SubScreen + y * GFX_PITCH), black, (256>>1)); - } - - // loop through all window clippings - for (uint32 c = 0; c < pClip->Count [5]; c++) - { - if (pClip->Right [c][5] > pClip->Left [c][5]) - { - memset (GFX.SubZBuffer + y * GFX_ZPITCH + pClip->Left [c][5], - 1, pClip->Right [c][5] - pClip->Left [c][5]); - - if (IPPU.Clip [0].Count [5]) - { - // Blast, have to clear the sub-screen to the fixed-colour - // because there is a colour window in effect clipping - // the main screen that will allow the sub-screen - // 'underneath' to show through. - - register unsigned int width = pClip->Right [c][5] - pClip->Left [c][5]; - if (width > 0) { - __asm__ volatile ( - " mov r0, %[fixedcolour] \n" - " subs %[width], %[width], #4 \n" - " bmi 2f \n" - - "1: \n" - " subs %[width], %[width], #4 \n" - " stmia %[p]!, {r0, %[fixedcolour]}\n" - " bpl 1b \n" - - "2: \n" - " tst %[width], #1 \n" - " strneh %[fixedcolour], [%[p]], #2 \n" - - " tst %[width], #2 \n" - " strne %[fixedcolour], [%[p]], #4 \n" - - : [width] "+r" (width) - : [fixedcolour] "r" (fixedColour), - [p] "r" (((uint16 *) (GFX.SubScreen + y * GFX_PITCH)) + pClip->Left [c][5]) - : "r0", "cc" - ); - } - } - } - } - } - - } - else - { - // No windows are clipping the main screen - // this simplifies the screen clearing process - // loop through all of the lines to be updated - for (uint32 y = starty; y <= endy; y++) { - // Clear the Zbuffer - memset32 ((uint32_t*)(GFX.ZBuffer + y * GFX_ZPITCH),0, (256>>2)); - // clear the sub Zbuffer to 1 - memset32 ((uint32_t*)(GFX.SubZBuffer + y * GFX_ZPITCH), 0x01010101, (256>>2)); - - if (IPPU.Clip [0].Count [5]) { - // Blast, have to clear the sub-screen to the fixed-colour - // because there is a colour window in effect clipping - // the main screen that will allow the sub-screen - // 'underneath' to show through. - - memset32 ((uint32_t*)(GFX.SubScreen + y * GFX_PITCH), fixedColour, (256>>1)); - } - } - } - if (ANYTHING_ON_SUB) - { - GFX.DB = GFX.SubZBuffer; - RenderScreen (GFX.SubScreen, TRUE, TRUE, SUB_SCREEN_DEPTH); - } - - if (IPPU.Clip [0].Count [5]) - { - __asm__ volatile ( - "1: \n" - " mov r1, #(256 >> 2) \n" - - "2: \n" - // four pixels at once - " ldrb r0, [%[d]], #1 \n" - " ldrb r4, [%[d]], #1 \n" - - " bics r0, r0, #1 \n" - " ldrneh r0, [%[p], %[delta]] \n" - - " bics r4, r4, #1 \n" - " ldrneh r4, [%[p], %[delta2]] \n" - - " strh r0, [%[p]], #2 \n" - " strh r4, [%[p]], #2 \n" - - " ldrb r0, [%[d]], #1 \n" - " ldrb r4, [%[d]], #1 \n" - - " bics r0, r0, #1 \n" - " ldrneh r0, [%[p], %[delta]] \n" - - " bics r4, r4, #1 \n" - " ldrneh r4, [%[p], %[delta2]] \n" - - " strh r0, [%[p]], #2 \n" - " strh r4, [%[p]], #2 \n" - - " subs r1, r1, #1 \n" - " bne 2b \n" - "3: \n" - " subs %[lines], %[lines], #1 \n" - " add %[p], %[p], #(640 - 512) \n" - " add %[d], %[d], #(320 - 256) \n" - " bne 1b \n" - "4: \n" - - : - : [p] "r" ((uint16 *) (GFX.Screen + starty * GFX_PITCH)), - [d] "r" (GFX.SubZBuffer + starty * GFX_ZPITCH), - [delta] "r" (GFX.Delta << 1), - [delta2] "r" ((GFX.Delta << 1) + 2), - [lines] "r" (endy - starty + 1) - : "r0", "r1", "r3", "r4", "cc" - ); - } - - GFX.DB = GFX.ZBuffer; - RenderScreen (GFX.Screen, FALSE, FALSE, MAIN_SCREEN_DEPTH); - if (SUB_OR_ADD(5)) - { - uint32 back = IPPU.ScreenColors [0]; - uint32 Left = 0; - uint32 Right = 256; - uint32 Count; - - pClip = &IPPU.Clip [0]; - - for (uint32 y = starty; y <= endy; y++) - { - if (!(Count = pClip->Count [5])) - { - Left = 0; - Right = 256; - Count = 1; - } - - for (uint32 b = 0; b < Count; b++) - { - if (pClip->Count [5]) - { - Left = pClip->Left [b][5]; - Right = pClip->Right [b][5]; - if (Right <= Left) - continue; - } -#define SUBSCREEN_BG(rop, half) \ -\ -__asm__ volatile (\ -" ldrb r0, [%[d]], #1 \n"\ -"71: \n"\ -\ -" movs r0, r0 \n"\ -" ldreqb r1, [%[d], %[zdelta]] \n"\ -" bne 72f \n"\ -\ -" cmp r1, #1 \n"\ -" beq 74f \n"\ -" ldrh r1, [%[p], %[delta]] \n"\ -" mov r0, %[back] \n"\ -\ -ROP_##rop##half (r0, r1)\ -\ -" strh r0, [%[p]] \n"\ -"72: \n"\ -" add %[p], %[p], #2 \n"\ -" subs %[c], %[c], #1 \n"\ -" ldrneb r0, [%[d]], #1 \n"\ -" bne 71b \n"\ -" b 75f \n"\ -"74: \n"\ -" streqh %[fixedcolour], [%[p]], #2 \n"\ -" strloh %[back], [%[p]], #2 \n"\ -" subs %[c], %[c], #1 \n"\ -" ldrneb r0, [%[d]], #1 \n"\ -" bne 71b \n"\ -"75: \n"\ -:\ -:[p] "r" ((uint16 *) (GFX.Screen + y * GFX_PITCH) + Left),\ - [d] "r" (GFX.ZBuffer + y * GFX_ZPITCH + Left),\ - [zdelta] "r" (GFX.DepthDelta),\ - [back] "r" (back),\ - [delta] "r" (GFX.Delta << 1),\ - [fixedcolour] "r" (COLOR_##rop (back, GFX.FixedColour)),\ - [c] "r" (Right - Left) \ -: "r0", "r1", "cc"\ -); - if (GFX.r2131 & 0x80) - { - if (GFX.r2131 & 0x40) - { - SUBSCREEN_BG(SUB, 1_2) - } - else - { - SUBSCREEN_BG(SUB, ) - - } - } - else - if (GFX.r2131 & 0x40) - { - SUBSCREEN_BG(ADD, 1_2) - } - else if (back != 0) { - SUBSCREEN_BG(ADD, ) - } - else - { - if (!pClip->Count [5]) - { - // The backdrop has not been cleared yet - so - // copy the sub-screen to the main screen - // or fill it with the back-drop colour if the - // sub-screen is clear. - __asm__ volatile ( - " ldrb r0, [%[d]], #1 \n" - "31: \n" - - " movs r0, r0 \n" - " ldreqb r1, [%[d], %[zdelta]] \n" - " bne 32f \n" - - " cmp r1, #1 \n" - " ldrhih r0, [%[p], %[delta]] \n" - " strloh %[back], [%[p]] \n" - " streqh %[fixedcolour], [%[p]] \n" - " strhih r0, [%[p]] \n" - - "32: \n" - " subs %[c], %[c], #1 \n" - " add %[p], %[p], #2 \n" - " ldrneb r0, [%[d]], #1 \n" - " bne 31b \n" - " \n" - : - :[p] "r" ((uint16 *) (GFX.Screen + y * GFX_PITCH) + Left), - [d] "r" (GFX.ZBuffer + y * GFX_ZPITCH + Left), - [zdelta] "r" (GFX.DepthDelta), - [back] "r" (back), - [delta] "r" (GFX.Delta << 1), - [fixedcolour] "r" (GFX.FixedColour), - [c] "r" (Right - Left) - : "r0", "r1", "cc" - - ); - - } - } - } - } - - } - else - { - // Subscreen not being added to back - uint32 back = IPPU.ScreenColors [0] | (IPPU.ScreenColors [0] << 16); - pClip = &IPPU.Clip [0]; - - if (pClip->Count [5]) - { - for (uint32 y = starty; y <= endy; y++) - { - for (uint32 b = 0; b < pClip->Count [5]; b++) - { - uint32 Left = pClip->Left [b][5]; - uint32 Right = pClip->Right [b][5]; - if (Left >= Right) continue; - __asm__ volatile ( - - " tst %[c], #1 \n" - " bne 21f \n" - - " ldrb r0, [%[d]], #1 \n" - " add %[p], %[p], #2 \n" - " movs r0, r0 \n" - " streqh %[back], [%[p], #-2] \n" - " subs %[c], %[c], #1 \n" - " beq 22f \n" - - "21: \n" - - " ldrb r0, [%[d]], #1 \n" - " ldrb r1, [%[d]], #1 \n" - " add %[p], %[p], #4 \n" - - " movs r0, r0 \n" - " streqh %[back], [%[p], #-4] \n" - - " movs r1, r1 \n" - " streqh %[back], [%[p], #-2] \n" - - " subs %[c], %[c], #2 \n" - " bhi 21b \n" - "22: \n" - : - :[p] "r" ((uint16 *) (GFX.Screen + y * GFX_PITCH) + Left), - [d] "r" (GFX.ZBuffer + y * GFX_ZPITCH + Left), - [back] "r" (back), - [c] "r" (Right - Left) - : "r0", "r1", "cc" - - ); - } - } - } - else - { - __asm__ volatile ( - "@ -- SubScreen clear \n" - "1113: \n" - " mov r1, #(256/8) \n" - "1112: \n" - " ldr r0, [%[d]], #4 \n" - - " add %[p], %[p], #8 \n" - - " tst r0, #0x0ff \n" - " streqh %[back], [%[p], #-8] \n" - - " tst r0, #0x0ff00 \n" - " streqh %[back], [%[p], #-6] \n" - - " tst r0, #0x0ff0000 \n" - " streqh %[back], [%[p], #-4] \n" - - " tst r0, #0x0ff000000 \n" - " streqh %[back], [%[p], #-2] \n" - - " ldr r0, [%[d]], #4 \n" - - " add %[p], %[p], #8 \n" - - " tst r0, #0x0ff \n" - " streqh %[back], [%[p], #-8] \n" - - " tst r0, #0x0ff00 \n" - " streqh %[back], [%[p], #-6] \n" - - " tst r0, #0x0ff0000 \n" - " streqh %[back], [%[p], #-4] \n" - - " tst r0, #0x0ff000000 \n" - " streqh %[back], [%[p], #-2] \n" - - " subs r1, r1, #1 \n" - " bne 1112b \n" - - " subs %[lines], %[lines], #1 \n" - " add %[p], %[p], #(640-512) \n" - " add %[d], %[d], #(320-256) \n" - " bne 1113b \n" - "1114:" - : - :[p] "r" (GFX.Screen + starty * GFX_PITCH), - [d] "r" (GFX.ZBuffer + starty * GFX_ZPITCH), - [back] "r" (back), - [lines] "r" (endy - starty + 1) - : "r0", "r1", "cc" - ); - } - } - } - else - { - // 16bit and transparency but currently no transparency effects in - // operation. - - // get the back colour of the current screen - uint32 back = IPPU.ScreenColors [0] | - (IPPU.ScreenColors [0] << 16); - - // if forceblanking in use then use black instead of the back color - if (PPU.ForcedBlanking) - back = black; - - // not sure what Clip is used for yet - // could be a check to see if there is any clipping present? - if (IPPU.Clip [0].Count[5]) - { - - // loop through all of the lines that are going to be updated as part of this screen update - for (uint32 y = starty; y <= endy; y++) - { - memset32 ((uint32_t*)(GFX.Screen + y * GFX_PITCH), black, - IPPU.RenderedScreenWidth>>1); - - if (black!=back) - { - for (uint32 c = 0; c < IPPU.Clip [0].Count [5]; c++) - { - if (IPPU.Clip [0].Right [c][5] > IPPU.Clip [0].Left [c][5]) - { - register unsigned int width = IPPU.Clip [0].Right [c][5] - IPPU.Clip [0].Left [c][5]; - if (width > 0) { - __asm__ volatile ( - " mov r0, %[back] \n" - " subs %[width], %[width], #4 \n" - " bmi 2f \n" - - "1: \n" - " subs %[width], %[width], #4 \n" - " stmia %[p]!, {r0, %[back]} \n" - " bpl 1b \n" - - "2: \n" - " tst %[width], #1 \n" - " strneh %[back], [%[p]], #2 \n" - - " tst %[width], #2 \n" - " strne %[back], [%[p]], #4 \n" - : [width] "+r" (width) - : [back] "r" (back | (back << 16)), - [p] "r" (((uint16 *) (GFX.SubScreen + y * GFX_PITCH)) + IPPU.Clip [0].Left [c][5]) - : "r0", "cc" - ); - } - - } - } - } - } - } - else - { - // there is no clipping to worry about so just fill with the back colour - for (uint32 y = starty; y <= endy; y++) { - memset32 ((uint32_t*)(GFX.Screen + y * GFX_PITCH), back, (256>>1)); - } - - } - - // If Forced blanking is not in effect - if (!PPU.ForcedBlanking) - { - // Clear the Zbuffer for each of the lines which are going to be updated - for (uint32 y = starty; y <= endy; y++) { - memset32 ((uint32_t*)(GFX.ZBuffer + y * GFX_ZPITCH), 0, (256>>2)); - } - GFX.DB = GFX.ZBuffer; // save pointer to Zbuffer in GFX object - RenderScreen (GFX.Screen, FALSE, TRUE, SUB_SCREEN_DEPTH); - } - } - IPPU.PreviousLine = IPPU.CurrentLine; -} - -// -x- -void S9xUpdateScreenNoTransparency () // ~30-50ms! (called from FLUSH_REDRAW()) -{ - GFX.S = GFX.Screen; - - unsigned char *memoryfillram = Memory.FillRAM; - - // get local copies of vid registers to be used later - GFX.r2131 = memoryfillram [0x2131]; // ADDITION/SUBTRACTION & SUBTRACTION DESIGNATION FOR EACH SCREEN - GFX.r212c = memoryfillram [0x212c]; // MAIN SCREEN, DESIGNATION - used to enable BGS - GFX.r212d = memoryfillram [0x212d]; // SUB SCREEN DESIGNATION - used to enable sub BGS - GFX.r2130 = memoryfillram [0x2130]; // INITIAL SETTINGS FOR FIXED COLOR ADDITION OR SCREEN ADDITION - - // If external sync is off and - // main screens have not been configured the same as the sub screen and - // color addition and subtraction has been diabled then - // Pseudo is 1 - // anything else it is 0 - GFX.Pseudo = (memoryfillram [0x2133] & 8) != 0 && // Use EXTERNAL SYNCHRONIZATION? - (GFX.r212c & 15) != (GFX.r212d & 15) && // Are the main screens different from the sub screens? - (GFX.r2131 & 0x3f) == 0; // Is colour data addition/subtraction disabled on all BGS? - - // If sprite data has been changed then go through and - // refresh the sprites. - if (IPPU.OBJChanged) - { - S9xSetupOBJ (); - } - - if (PPU.RecomputeClipWindows) ComputeClipWindows(); - - GFX.StartY = IPPU.PreviousLine; - if ((GFX.EndY = IPPU.CurrentLine - 1) >= PPU.ScreenHeight) - GFX.EndY = PPU.ScreenHeight - 1; - - uint32 starty = GFX.StartY; - uint32 endy = GFX.EndY; - - uint32 black = BLACK | (BLACK << 16); - - // get back colour to be used in clearing the screen - register uint32 back; - if (!(Memory.FillRAM [0x2131] & 0x80) &&(Memory.FillRAM[0x2131] & 0x20) && - (PPU.FixedColourRed || PPU.FixedColourGreen || PPU.FixedColourBlue)) - { - back = (IPPU.XB[PPU.FixedColourRed]<<11) | - (IPPU.XB[PPU.FixedColourGreen] << 6) | - (IPPU.XB[PPU.FixedColourBlue] << 1) | 1; - back = (back << 16) | back; - } - else - { - back = IPPU.ScreenColors [0] | (IPPU.ScreenColors [0] << 16); - } - - // if Forcedblanking in use then back colour becomes black - if (PPU.ForcedBlanking) - back = black; - else - { - SelectTileRenderer (TRUE); //selects the tile renderers to be used - // TRUE means to use the default - // FALSE means use best renderer based on current - // graphics register settings - } - - // now clear all graphics lines which are being updated using the back colour - for (register uint32 y = starty; y <= endy; y++) - { - memset32 ((uint32_t*)(GFX.Screen + y * GFX_PITCH), back, - IPPU.RenderedScreenWidth>>1); - } - - if (!PPU.ForcedBlanking) - { - // Loop through all lines being updated and clear the - // zbuffer for each of the lines - for (uint32 y = starty; y <= endy; y++) - { - memset32 ((uint32_t*)(GFX.ZBuffer + y * GFX_ZPITCH), 0, - IPPU.RenderedScreenWidth>>2); - } - GFX.DB = GFX.ZBuffer; // save pointer to Zbuffer in GFX object - GFX.pCurrentClip = &IPPU.Clip [0]; - -// Define an inline function to handle clipping -#define FIXCLIP(n) \ -if (GFX.r212c & (1 << (n))) \ - GFX.pCurrentClip = &IPPU.Clip [0]; \ -else \ - GFX.pCurrentClip = &IPPU.Clip [1] - -// Define an inline function to handle which BGs are being displayed -#define DISPLAY(n) ((GFX.r212c & n) || ((GFX.r212d & n) && subadd)) - - uint8 subadd = GFX.r2131 & 0x3f; - - // go through all BGS are check if they need to be displayed - bool8_32 BG0 = DISPLAY(1) && !(Settings.os9x_hack & GFX_IGNORE_BG0); - bool8_32 BG1 = DISPLAY(2) && !(Settings.os9x_hack & GFX_IGNORE_BG1); - bool8_32 BG2 = DISPLAY(4) && !(Settings.os9x_hack & GFX_IGNORE_BG2); - bool8_32 BG3 = DISPLAY(8) && !(Settings.os9x_hack & GFX_IGNORE_BG3); - bool8_32 OB = DISPLAY(16) && !(Settings.os9x_hack & GFX_IGNORE_OBJ); - - if (PPU.BGMode <= 1) - { - // screen modes 0 and 1 - if (OB) - { - FIXCLIP(4); - DrawOBJS (FALSE, 0); - } - if (BG0) - { - FIXCLIP(0); - DrawBackground (PPU.BGMode, 0, 10, 14); - } - if (BG1) - { - FIXCLIP(1); - DrawBackground (PPU.BGMode, 1, 9, 13); - } - if (BG2) - { - FIXCLIP(2); - DrawBackground (PPU.BGMode, 2, 3, - PPU.BG3Priority ? 17 : 6); - } - if (BG3 && PPU.BGMode == 0) - { - FIXCLIP(3); - DrawBackground (PPU.BGMode, 3, 2, 5); - } - } - else if (PPU.BGMode != 7) - { - // screen modes 2 and up but not mode 7 - if (OB) - { - FIXCLIP(4); - DrawOBJS (FALSE, 0); - } - if (BG0) - { - FIXCLIP(0); - DrawBackground (PPU.BGMode, 0, 5, 13); - } - if (BG1 && PPU.BGMode != 6) - { - FIXCLIP(1); - DrawBackground (PPU.BGMode, 1, 2, 9); - } - } - else - { - // screen mode 7 - DrawBGMode7Background16New (GFX.Screen); - if (OB) - { - FIXCLIP(4); - DrawOBJS (FALSE, 0); - } - } - } - IPPU.PreviousLine = IPPU.CurrentLine; -} - -// -x- - -#ifdef GFX_MULTI_FORMAT - -#define _BUILD_PIXEL(F) \ -uint32 BuildPixel##F(uint32 R, uint32 G, uint32 B) \ -{ \ - return (BUILD_PIXEL_##F(R,G,B)); \ -}\ -uint32 BuildPixel2##F(uint32 R, uint32 G, uint32 B) \ -{ \ - return (BUILD_PIXEL2_##F(R,G,B)); \ -} \ -void DecomposePixel##F(uint32 pixel, uint32 &R, uint32 &G, uint32 &B) \ -{ \ - DECOMPOSE_PIXEL_##F(pixel,R,G,B); \ -} - -_BUILD_PIXEL(RGB565) -_BUILD_PIXEL(RGB555) -_BUILD_PIXEL(BGR565) -_BUILD_PIXEL(BGR555) -_BUILD_PIXEL(GBR565) -_BUILD_PIXEL(GBR555) -_BUILD_PIXEL(RGB5551) - -bool8_32 S9xSetRenderPixelFormat (int format) -{ - extern uint32 current_graphic_format; - - current_graphic_format = format; - - switch (format) - { - case RGB565: - _BUILD_SETUP(RGB565) - return (TRUE); - case RGB555: - _BUILD_SETUP(RGB555) - return (TRUE); - case BGR565: - _BUILD_SETUP(BGR565) - return (TRUE); - case BGR555: - _BUILD_SETUP(BGR555) - return (TRUE); - case GBR565: - _BUILD_SETUP(GBR565) - return (TRUE); - case GBR555: - _BUILD_SETUP(GBR555) - return (TRUE); - case RGB5551: - _BUILD_SETUP(RGB5551) - return (TRUE); - default: - break; - } - return (FALSE); -} -#endif diff --git a/old/rel/menu_header.bmp b/old/rel/menu_header.bmp Binary files differdeleted file mode 100644 index 6066978..0000000 --- a/old/rel/menu_header.bmp +++ /dev/null diff --git a/old/rel/readme.txt b/old/rel/readme.txt deleted file mode 100644 index 43e4104..0000000 --- a/old/rel/readme.txt +++ /dev/null @@ -1,347 +0,0 @@ -DrPocketSnes
-Super Nintendo (SNES) Emulator
-by Reesy
-
-DrPocketSnes is a Super Nintendo (SNES) emulator for the GP2X and Gizmondo. I've taken bits from PocketSnes and SquidgeSnes and merged them into another new emulator. I then stuck my menu system on it and called it my own :) you've got to love porting stuff.
-
-So credits for this emulator should really go to.
-
-Snes9x Team for creating the original Snes9x emulator
-http://www.snes9x.com/
-
-Scott Ramsby for PocketSnes port based on Snes9x sources
-http://paqpark.nuclearfallout.net/projects/pocketsnes.php
-
-Yoyofr for OpenSnes9x port based on Snes9x sources
-http://yoyofr.fr.st/
-
-Squidge for the SquidgeSnes port based on OpenSnes9x
-http://squidge2x.com/
-
-Notaz for his fixes and improvements to SquidgeSnes.
-http://notaz.atspace.com/
-
-Rlyeh for his work on the gp2x (not so)minimal sdk
-http://www.retrodev.info/
-
-Reesy for merging everything and sticking a menu on it...the really complicated stuff ;).
-http://reesy.gp32x.de/
-
-====================
-IMPORTANT
-When upgrading from v4 to v5 you will need to manually move the savestate files (*.sv*) from the options directory into the savestate directory and the SRAM files (*.srm) from the root installation directory into the sram directory. See change history for more details.
-====================
-
-==============
-Change History
-==============
-
-___________________________________
-Version 7.1.0 Release Date 28/10/2010
-___________________________________
-Changes by Bitrider
-
-- Added: Tv-Out compatiblity.
- Thanks to XiM for the Ext connector used to make my Tv-Out cable, which made this feature possible.
-- Internal changes:
- Lots of code refactoring, make my life easier.
- A new saner Makefile.
-
-___________________________________
-Version 7.0.1 Release Date ??/09/2010
-___________________________________
-Changes by Bitrider
-
-- Bug-fix release (Mode-7, priorities, sprites, etc)
-
-___________________________________
-Version 7.0.0 Release Date 30/07/2010
-___________________________________
-Changes by Bitrider
-
- Thanks goes to:
- Buba-ho-tep, Rivroner (beta testers)
- Anarchy (GP32Spain webmaster & conding contest promoter)
- Head-On-Heels (v 6.5.0 developer)
- Notaz, Squidge, Little Johnz & all those who contributed to this wonderful emulator.
-
-- Added: deep changes to SPC 700 assembly core, now it is faster.
- - moved a few registers
- - less reads/writes to memory
- - implemented GetByteZ, GetByte, SetByteZ & SetByte in ARM assembly
-- Added: modifications to 65c816 assembly core, a little bit faster.
- - moved several flags from memory to status register.
- - implemented SetPCBase in ARM assembly.
- - SetDSP & GetDSP called directly (S9x_SetDSP & S9x_GetDSP where just wrapper functions with no added value).
- - Assembly CPU code splitted in several files (modularity purposes)
-- Added: 4 different assembly APU (SPC 700) cycle sizes: 13, 14, 15 & 21.
- Now more games are compatible with fast executable & fast mode on compatible executable :
- Human's ones (Firemen, ...), Secret of evermore, Clock Tower (yeah, I know it's also by Human but a special case) that one is for you Buba.
-- Added: 16 bit fast assembly renderers for:
- tile: opaque, add, add 1/2, add fix 1/2, sub, sub 1/2, sub fix 1/2
- tile clipped: opaque, add, add 1/2, add fix 1/2, sub, sub 1/2, sub fix 1/2
- mode 7 just one layer: solid, solid with priority, add, add 1/2, sub, sub 1/2
- mode 7 with priorities (two layers): solid, add, add 1/2, sub, sub 1/2.
- subscreen filling: solid, add, add 1/2, sub, sub 1/2
-- Added: SpeedHacks (rom patching with snesadvance.dat) to fast executable
-- Added: a switch to enable/disable speed hacks, "Apply snesadvance.dat on ROM load".
-- Added: Super FX emulation to fast executable version.
-- Added: last played ROM loading at PocketSNES startup
-- Added: a switch to enable/disable last played ROM loading at startup
-- Added: persistent selector in ROM list selector
- Last selected ROM will continue being focused when you launch a ROM
- and go back to the menu to select another ROM. (idea by Buba-ho-tep, thanks man.)
- It does work only when you are in default PocketSNES ROM directory
-- Added: display ROM file name while loading.
-- Added: on ROM load error display error, pause & show "Push a button to continue".
-- Added: fast version (65c816 assembly emulation) will show as "v 7.0.0 fast"
- compatible version (65c816 C emulation) will show as "v 7.0.0 compatible"
-- Added: the ability to use Fast (assembly SPC-700) or Compatible (C SPC-700), more games playable on fast executable.
- - So "Emulation (Reset Required): Compatible/Fast" switch is now available on fast executable.
-- Fixed: Auto save SRAM should only save when a change occurred
-- Added: "Manual + indicator" to SRAM saving options
- A disk will be displayed on the lower right corner of the screen when SRAM data is awaiting
- Note: disk won't be visible if screen is resized
-- Added: a little bit optimized sound block decode routine.
-
-
-___________________________________
-Version 6.5.0 Release Date 24/10/2009
-___________________________________
-Changes by HeadOverHeels
- 1. Optimizations in mode 7 and other code optimizations
- 2. Horizontal scaler
-
- FAST VERSION
- ------------
- 3. Increased compatibility: star ocean, rendering ranger, etc.
- 4. More games are compatible with audio performance hack
-
- NORMAL VERSION
- --------------
- 5. Full SuperFX and SA-1 emulation
- 6. Snesadvance.dat speedhacks support
- 7. 2 sound emulation modes: compatible and fast
-
-___________________________________
-Version 6.4.5 Release Date 06/06/2009
-___________________________________
-Changes by HeadOverHeels
- 1. Ported to GP2X WIZ
- 2. Optimizations in C4 emulation
-
-___________________________________
-Version 6.4.4 Release Date 16/11/2008
-___________________________________
-Changes by Reesy
- 1. Zipped save states
- 2. Rom Browser code tidied, you can now set the default directory
- from inside the rom browser. The rom browser now also tells
- you the current directory.
-Changes by HeadOverHeels
- 1. Fixed some bugs in layer priority (super ghouls'n ghosts level 4 for example)
- 2. Optimizations in tile rendering code, ppu emulation, ...
- 3. Changes in volume control to be more usable with headphones in firmware 4.0.0 and louder with firmware 4.1.1
- 4. Fixed: some games do not work if you don't restart the emulator
- 5. Menu now sets cpu clock to 66 mhz to save battery
-
-___________________________________
-Version 6.4.3 Release Date 23/02/2008
-___________________________________
-Changes by HeadOverHeels
- 1. USB pads support
- 2. Fixed sky colour for Super Mario World when transparencies are not active.
- 3. Fixed framerate for PAL games (50 fps) and added an option to configure region (AUTO, NTSC, PAL)
- 4. Fixed sound problems with some games (Ilussion of Gaia for exmaple)
- 5. Sound frequencies have been changed (8250,16500) to make GP2X F200 compatible
- 6. 256x240 games resolution problem have been fixed
- 7. C4 chip support (Megaman X2, X3)
- 8. High resolution text support (Seiken Densetsu 3 - Secret of Mana2)
- 9. Added DSP optimizations from snes9xTYL of Yoyofr.
- 10. F200 sound level now is lower
- 11. SDD1 support (Star Ocean & Street Fighter Alpha 2)
- SDD1 decompressed packs are supported. SDD1GFX.DAT & SDD1GFX.IDX must be copied to a subdirectory named socnsdd1 (for Star Ocean) and sfa2sdd1 (for Street Fighter 2 alpha). Create these subdirectories in the roms directory.
- If no packs are found, the emulator uses realtime decompression (slower)
- 12. Other minor fixes and optimizations.
- 13. Added stereo sound.
- 14. New advanced hacks options:
- Audio performance hack
- Ignore palette writes
- Ignore Fixed Colour
- Ignore Windows clipping
- Ignore Add/Sub modes
- Layer desactivation
-
-Changes by Reesy
-___________________________________
-Version 6 Release Date 04/02/2007
-___________________________________
- 1. Fixed a bug on the rom browsing code. Strings were not being terminated correctly.
-___________________________________
-Version 5 Release Date 03/02/2007
-___________________________________
- 1. Changed the way SRAM works. The old versions of PocketSnes used a timer to check if SRAM had changed while the SNES emulator was running. If a change was detected the SRAM was saved straight away. This used to cause glitches in the framerate. SRAM is now saved when you enter the menu as long as you have SRAM saving set to automatic in the options menu.
- 2. Added options to allow you to switch MMU hack on or off
- 3. Added options to allow you to switch Craigx's RAM settings on or off.
- 4. Fixed problems where data was not being saved to SD card correctly, I was missing a few calls to sync()
- 5. I've tidied up the installation directory abit. Most things used to be stored in the options sub directory and somethings were saved to the root installation directory, which was a bit of a mess. So I've now created the following 3 directories in order to make things more logical.
-
- options (*.opt) - used to hold global and individual game settings
- savestate (*.sv*) - used to hold save states for all games
- sram (*.srm) - used to hold SRAM saves for all games
-
- This means that we you upgrade from Version 4 to Version 5 you will need to manually copy the savestates out of the options directory and into the savestate directory in order for PocketSnes to recognise them. You will also have to move the SRAM files out of the root
-installation directory and into the sram directory.
-___________________________________
-Version 4 Release Date 30/01/2007
-___________________________________
- 1. Fixed timer code which was causing the emulator to crash
-___________________________________
-Version 3 Release Date 24/01/2007
-___________________________________
- 1. Scaled display mode added.
- 2. 44K sound mode added.
- 3. Super FX support added - very very buggy and slow
-___________________________________
-Version 2 Release Date 24/01/2007
-___________________________________
- 1. Fixed Diagnals.
- 2. Fixed Volume controls.
- 3. Fixed Reset game function.
- 4. Snes Select button now working.
-___________________________________
-Version 1 Release Date 24/01/2007
-___________________________________
- Initial release
-
-=========================
-Installation Instructions
-=========================
-
-Along with this document you are reading you should have also received the following files
-
-PocketSnes.gpe - PocketSnes emulator
-mmuhack.o - Additional module used to hack MMU and improve performance.
-
-Simply copy these files onto your SD card, the files can go anywhere but both files need to be in the same directory. I recommend putting the in a directory of their own because when the emulator first starts up it will create several subdirectories which are used to store options, savestates and SRAM saves.
-
-So for example create a directory called DrPocketSnes and then copy the PocketSnes.gpe and mmuhack.o files into the DrPocketSnes directory.
-
-Now you need to copy some SNES roms to you SD card. Again you can put your roms anywhere you like on your SD card, you just need to configure DrPocketSnes to point at your rom directory. To do this follow the instructions below
-
-1. Start PocketSnes
-2. Select "Select Rom" from the menu.
-3. This will take you by default to the current working directory (e.g the directory where you installed DrPocketSnes /mnt/sd/DrPocketSnes.
-4. You now need to browse through the file system to find your rom directory.
-5. To do this select ".." to move up and directory or select any entries that start with "+". Entries that start with "+" are directories, so selecting takes you into that directory.
-6. Once you have located your rom directory, you need to save the current directory as your default rom directory.
-7. To do this select the "Back To Main Menu" menu option.
-8. Then select "SNES Options"
-9. Then select "Save Current Rom Directory"
-10. This will store the current rom directory in a text file held in the options directory. So the next time you start PocketSnes and select "Select Rom" you will be taken straight to your rom directory.
-
-============
-Menu Options
-============
-_______________________________________________
-Return To Game
- If you have a rom loaded this will allow to exit the menu and return to the game.
-_______________________________________________
-Select Rom
- Takes you to the Rom Selection screen which allows you load a new game.
-_______________________________________________
-Manage Save States
- Takes you to the save state management screen. Save states allow you to save your current position in the currently loaded game. This means that you can reload a particular position in the game as many times as you want.
-_______________________________________________
-Save Sram
- Allows you save the current contents of SRAM to a file. SRAM is the battery backup ram which used to be on the Snes cartridges. This allowed high scores or game progress, so that the next time you loaded the snes game you could continue where you left off. If you plan to use save states then you don't need to worry about SRAM saves as the save state holds all of this information as well.
-_______________________________________________
-SNES Options
- Takes you into the options screen which allows you to customise how the emulator runs. See "SNES Options - In Detail" for more information on each of the settings.
-_______________________________________________
-Reset Game
- Allows you to reset the current rom, its the same as reloading the rom apart from you don't have to read the rom file from the SD card again.
-_______________________________________________
-Exit Application
- Exits PocketSnes and reloaded the GP2X menu.
-_______________________________________________
-
-========================
-SNES Options - In Detail
-========================
-_______________________________________________
-Sound
- Allows you to turn the sound on or off
-_______________________________________________
-Sound Rate
- Allows you to configure the sample rate of the sound emulation. The high the rate the clearer and more accurate the sound.
-_______________________________________________
-Volumne
- Allows you setup default volume levels. Volume can also be controlled using the volume controls on the GP2X.
-_______________________________________________
-Cpu Speed
- Allows you select the GP2X cpu speed to be used when emulating the Snes. The higher the cpu speed the smoother the emulation is ( plus it drains you battery more)
-_______________________________________________
-FrameSkip
- Allows you to control how many frames are not rendered, this can allow you to keep full speed emulation when at low cpu speeds. AUTO will skip as many frames as needed in order to maintain full speed emulation.
-_______________________________________________
-Action Buttons
- The GP2X has the same button as the snes but the buttons are in the wrong order. This option allows you to have the same button names as the snes, or to have the same button positions as snes.
- NORMAL = same button names as Snes
- SWAPPED = same button positions as Snes
-_______________________________________________
-Show FPS
- This allows you to see how man frames are being rendered per second. This can allow you to see how the emulator is performing.
-_______________________________________________
-Brightness
- This allows you to control the current brightness of the screen. You can make it darker or brighter.
-_______________________________________________
-Transparencies
- The SNES has very complicated graphics hardware which can be quite slow to emulate. Switching off transparencies can improve performce but makes some games unplayable because you can not see all of the information that you need.
-_______________________________________________
-Render Mode
- Allows you to scale the emulated SNES graphics. The normal SNES screen resolution is less than the GP2X's, so when in unscaled mode the graphics appear in a window. If you select the scaled mode then the graphics are stretched to fill the screen.
-_______________________________________________
-RAM Timing
- This allows you select faster ram timings. This can improve performance. If you change this option you need to restart PocketSnes because these settings are only applied as the emulator is first started.
-_______________________________________________
-MMU Hack
- This option allows you to enable the MMU hack developed by Squidge. This option massively improves performance and is recommended. Again if you change this option you need to restart PocketSnes because these settings are only applied as the emulator is first started.
-_______________________________________________
-Saving SRAM
- This option allows you to control how the SRAM is saved to you SD card. If you select automatic then SRAM will be saved automatically everytime you return to the menu if it has been modified during the last run of emulation. If you select the manual option then SRAM will only be saved when you select the Save SRAM menu option from the main menu.
-_______________________________________________
-Load Global Settings
- This option will reload the global settings. Global Settings affect all games as long as the games does not have a setting file of its own ( See Load Settings for current game).
-_______________________________________________
-Save Global Settings
- This option allows you to save the current settings to the SD card. Everytime you load a new rom these settings will be reloaded, so basically they become you default settings. This can be overwritten using the "Save Settings For Current Game" option which allows you to save a config file for a particular rom. So each time you load the rom these settings will automatically be loaded.
-_______________________________________________
-Delete Global Settings
- Deletes any global setting file that has been created. If you have no global setting file then PocketSnes will use its own internal default settings when loading a new rom.
-_______________________________________________
-Load Settings For Current Game
- This option will load any setting file associated with the currently loaded rom.
-_______________________________________________
-Save Settings For Current Game
- This option allows you to save a config file for the currently loaded rom. So each time you load this rom these settings will automatically be loaded instead of the global settings.
-_______________________________________________
-Delete Settings For Current Game
- Deletes any config file for the currently loaded rom.
-_______________________________________________
-Save Current Rom Directory
- This option allows you to save the current rom directory as you default rom directory.
-_______________________________________________
-
-
-
-
-
-
-
-
-
-
-
-
-
diff --git a/old/rel/snesadvance.dat b/old/rel/snesadvance.dat deleted file mode 100644 index a75bfe6..0000000 --- a/old/rel/snesadvance.dat +++ /dev/null @@ -1,641 +0,0 @@ -10000004|0|7E0147|0|1E|2A|18EC3|0|18EC3=EAEA,18E52=EAEA,18E70=EAEA,18E79=EAEA,185CC=EAEA,18612=EAEA,1865E=EAEA,186A5=EAEA,1871D=EAEA,18762=EAEA,184F1=EAEA,18531=EAEA,18560=EAEA,1858D=EAEA,656=42FC,18ED5=42D2,18EDC=EAEA,189F1=EAEA,18A0A=EAEA,18A44=EAEA,18A81=EAEA,18AC7=EAEA,18AF4=EAEA,18803=EAEA,1884A=EAEA,18896=EAEA,188DB=EAEA,188DD=EAEA,18955=EAEA,1899A=EAEA,18B20=EAEA,18B7E=EAEA,18BCA=EAEA,18C11=EAEA,18C89=EAEA,18CD0=EAEA,18D3C=EAEA,18D5A=EAEA,18D85=EAEA,15943=42FA,18EF7=42DB,18E00=42DB,18E2C=EAEA,15811=42FA,18DAE=EAEA,18DD7=80,189D3=EAEA,87=42FA,1534F=42F6
-FBF3C0FF|3x3 Eyes - Seima Korin Den (J)|4|40044804|0|0|0|0|214=42D8
-B3ABDDE6|7th Saga (U)|1320005|40800|0|0|0|0|3F2EB=42DA,FAC0=42F7
-68D7819A|7thsaga|5|C00|0|0|0|C
-27FF5BA1|AAAHH! Real Monsters (U)|10000000|44C00|0|0|0|0|39F37=EAEA,39F5D=EAEA,39F68=EAEA,39F6D=EAEA,39F9C=EAEA,39FA4=EAEA,39FE9=EAEA,39FFE=EAEA,3A00A=EAEA,3A01A=EAEA,3A054=EAEA,3A067=EAEA,3A096=EAEA,3A0A7=EAEA,3A0B3=EAEA,3A0C3=EAEA,3A0F9=EAEA,3A10C=EAEA,3A13C=EAEA,3A16D=EAEA,3A18E=EAEA,3A1A1=EAEA,3A1A6=EAEA,3A214=EAEA,3A22A=EAEA,3A23D=EAEA,3A242=EAEA,3A2AE=EAEA,3A2BC=EAEA,3A2C7=EAEA,3A33A=EAEA,3A34F=EAEA,3A3A7=EAEA,3A3D6=EAEA,3A3F0=EAEA,3A3F8=EAEA,3A411=EAEA,3A425=EAEA,6CAF=429B,8A8C=42,EDD0=42D9,1A6D0E=DB
-E0DC8AD7|ABC Monday Night Football (U)|4|0|0|0|0|0
-0DA18A10|Acrobat Mission (U)|0|0|0|0|0|0|5DE=42FB
-EAC3358D|Act Raiser|4|0|0|0|0|A|3248=EAEA,1367C=EAEA,12868=EAEA,9296=421B,422=421B,1B017=421A
-4901F718|Act Raiser 2 (U)|14000001|4040|0|0|0|0
-3CBC264F|ActRaiser 2 - Chinmoku he no S|1|400800|0|0|0|0|BEC2=421A
-C752F5DF|Action Pachio (J)|4000000|44808|0|0|0|0|23C=42F6,2D9=42D4
-20143571|AD&D - Eye of the Beholder|8000004|40000|0|0|0|0|E81FD=EAEA,E8246=EAEA,E8271=EAEA,E828A=EAEA,E8420=EAEA,E844E=EAEA,E8459=EAEA,E845E=EAEA,E84C4=EAEA,E84D9=EAEA,E84ED=EAEA
-779F89C6|Addams Family|0|0|0|0|0|0
-2E8034AB|Addams Family (U)|0|0|0|0|0|0|14E9=EAEA,7870=EAEA,789D=EAEA
-153A00A7|Addams Family - Pugsley's Scave|0|44C40|0|0|0|0|14C5=EAEA,14CE=EAEA,532A2=EAEA
-98B07DB8|Addams Family Values (U)|0|0|0|0|0|0|19071B=4280,82CD6=EAEA,1E00FB=EAEA,1E0249=EAEA,1E0260=EAEA,1E0270=EAEA,1E0288=EAEA,1E0293=EAEA,1E0298=EAEA
-CFAB3BBA|Adventures of Dr Franken (U)|0|40C00|0|0|0|0|53D7=EAEA
-1664AE48|Adventures of Kid Kleets (U)|0|0|0|0|0|0|7B74=EAEA,50DA6=EAEA,51A9C=EAEA,51AD6=EAEA,51AE5=EAEA,51B1B=EAEA,51B4D=EAEA,51B6D=EAEA,51B7E=EAEA
-DC8F5734|Adventures of Rocky & Bullwinkl|0|0|0|0|0|0|F756F=EAEA
-F194D00A|Aero Fighters (U)|0|0|0|0|0|0|FD=42D7,19D=428E,26D=42
-919F23CB|Aero the Acro-Bat (U)|0|40C00|0|0|0|0|E1C87=EAEA,E1CAC=EAEA
-8C05ED51|Aero the Acro-Bat 2 (U)|0|0|0|0|0|0|1F9B44=EAEA,1F9B69=EAEA,1F9918=EAEA,1F99F2=EAEA,1F9A10=EAEA
-54302A46|Aerobiz (U)|4|0|0|0|0|0|14EB=EAEA
-EFAFAB12|Aerobiz Supersonic (U)|4|0|0|0|0|0|469F=EAEA,46CB=EAEA,46D6=EAEA,46DB=EAEA,1596=428B,EE024=DBF1
-6B452801|Air Cavalry (U)|10000000|4040|0|0|0|0
-05C0DA54|Air Strike Patrol (U)|4|0|0|0|0|0|781FD=EAEA,78246=EAEA,78271=EAEA,7828A=EAEA,78420=EAEA,7844E=EAEA,78459=EAEA,7845E=EAEA,784C4=EAEA,784D9=EAEA,784F3=EAEA,78513=EAEA,88B9A=EAEA,31D=DB,337=42D9,D1B=42,212E=42,215F=42,219C=42,3AFC=4219,3BC2=DB,3C30=42,3C62=42,3C88=42,3CC8=42,3D0B=42,40AD=42,40D5=42,4971=42,49A2=42,49C8=42,4C46=DB,10026=423A,187FA=4280,18818=42DD,CF9B3=DB6A
-EEF47B5E|Akazukin Cha Cha (J)|5|840000|0|0|0|0|16047E=EAEA,160456=EAEA,30F7=42DC
-0AA75FA8|Akumajo Dracula XX|0|0|0|0|0|0|CA=4284,2B02=EAEA,29A2=EAEA
-124D8E4D|Aladdin|0|0|7E08EA|0|1E|5|BC89=DBE2
-46CA01A9|Albert Odyssey (J)|4|0|0|0|0|0
-1B6ADD7B|Albert Odyssey 2 (J)|4000005|0|0|0|0|0
-05798DA8|Alice in Wonderland (J)|8000001|4040|0|0|0|0
-7E28C2D4|Alien 3 (E) [T-Port]|0|0|0|0|0|0|F80A1=EAEA,F814E=EAEA,F8123=EAEA,F8166=EAEA,F80A6=EAEA,F81A8=EAEA,BAD8=42DB,A629=42F8,A5E5=42FB
-98E2AC15|Alien 3 (U)|0|0|0|0|0|0|F80A1=EAEA,F814E=EAEA,F8123=EAEA,F8166=EAEA,F80A6=EAEA,F81A8=EAEA,A5E5=42FB,A629=42F8,BAD8=42DB
-A31D1F58|Alien Vs. Predator (E) [!]|2|0|0|0|0|0|60626=EAEA,6062E=EAEA,6063F=EAEA,60644=EAEA,60653=EAEA,3FCE=421B,3FDC=421B
-1803CF20|Alien Vs. Predator (U)|0|0|0|0|0|0|60626=EAEA,6062E=EAEA,6063F=EAEA,60644=EAEA,60653=EAEA,3FCE=421B,3FDC=421B
-2D5876FF|Aliens Vs Predator (J)|0|0|0|0|0|0|60426=EAEA,6042E=EAEA,6043F=EAEA,60444=EAEA,60453=EAEA,4245=421B,4253=421B
-EBEFBDE2|All-American Championship Footb|2|0|0|0|0|0|825=DB,16C9=DB69,2DF7=4282,4015=4215,40A9=DB,4173=4210,4260=DB,37580=EAEA,375F0=EAEA,3760B=EAEA,37627=EAEA,37691=EAEA,3769C=EAEA,376A1=EAEA,376CC=EAEA,376D2=EAEA,3787D=EAEA,37883=EAEA,37898=EAEA,378A3=EAEA,378B0=EAEA,378BD=EAEA,378CC=EAEA,37C48=EAEA,37C4E=EAEA,37C63=EAEA,37C8A=EAEA
-61753981|American Battle Dome (J)|0|0|0|0|0|0|D807E=EAEA,DA11D=EAEA,DA164=EAEA,2BF9=42DC,3081=421B
-EEA38AED|An American Tale - Fievel Goes |1|0|0|0|0|0|F236=EAEA
-D5B09EEF|Ancient Magic - Bazoo! Mahou Se|4|0|0|0|0|0
-D1AE87BE|Andre Agassi Tennis (U)|0|0|0|0|0|0
-EA6AE8A9|Angelic Voice Fantasy (J)|10000005|4040|0|0|0|0
-CF0F14D2|Animaniacs|0|0|0|0|0|0|364C=EAEA,34EE=EAEA,139=4284,570=EAEA
-83B40AF2|Another World (E)|10000002|0|0|0|0|0|658D=EAEA,65A0=EAEA,65B7=EAEA,65CC=EAEA,65D4=EAEA,65E1=EAEA,65E6=EAEA,65FB=EAEA,6605=EAEA,6617=EAEA,662A=EAEA,66B5=EAEA,66C5=EAEA,1D997=4251,234C9=DB6D
-4CA1696F|Aqutallion (J)|4|0|0|0|0|0
-B6DBF57B|Arabian Nights - Sabaku no Seir|5|44000|0|0|0|0|114C=EAEA,1177=EAEA,1156=EAEA,573A=EAEA,58B3=EAEA,4FBA=EAEA,4F90=EAEA,5387=EAEA,538C=EAEA,4C45=42FB
-02394F36|Arcade's Greatest Hits - The At|0|0|0|0|0|0|155=421B,D5F=421B
-C891B297|Arcana (U)|4|0|0|0|0|0|1C1A=EAEA,1C3D=EAEA,5128=EAEA,516C=EAEA,51FB=EAEA,5208=EAEA,52BA=EAEA,52D0=EAEA,52DD=EAEA,5303=EAEA,5330=EAEA,533B=EAEA,5340=EAEA,5372=EAEA,E8160=EAEA,3A6=42,8FA=423A,900=421A,300EC=423F,30564=423F,EA2B9=4219
-E1CCCE49|Archer MacLean's Dropzone (E) [|2|0|0|0|0|0|F840C=EAEA
-C9067671|Arcus Spirits (J)|0|0|0|0|0|0
-51A5F489|Ardy Lightfoot (U)|0|44C00|0|0|0|0|D008F=EAEA,D04A7=EAEA,7D6A=EAEA
-06388F71|Area 88 (J)|8000000|44400|0|0|0|0|61=EAEA,129=42FC,65C4=42D5
-395BADE3|Aretha (J)|10000004|40840840|0|0|0|0|2367D=42D9,103D=423B
-FF63EC26|Aretha II - Ariel no Fushigi na|4|0|0|0|0|0|10C68=EAEA,10C7D=EAEA,10C90=EAEA,10CA8=EAEA,10CEE=EAEA,10DA3=EAEA,10C4C=EAEA,10AF1=EAEA,9052=EAEA,1112A=42D9,189C=423B,13204=4289,114DE=42DB,268E=42D5
-B50503A0|Arkanoid - Doh it Again (U)|10000000|4000|0|0|0|C|100F0=EAEA,5D=4282
-9FA74067|Art of Fighting (U)|1|0|0|0|0|0
-24FE792F|Asameshimae Nyanko (J)|8000000|40440C00|0|0|0|0
-6B54BE97|Ashita no Joe (J)|10000000|4040|0|0|0|0|94B1=EAEA,A802=EAEA,A81A=EAEA,A825=EAEA,A82A=EAEA,A870=EAEA,A8A4=EAEA,A8BC=EAEA,A8C7=EAEA,A8CC=EAEA,B75C=EAEA
-A5F63557|Assault Suits Valken (J)|0|4000|0|0|0|0
-EF85860E|Asterix & Obelix (E) [f1]|10000002|0|0|0|0|32|1803A=EAEA,1804A=EAEA,1B8AE=42FA
-5DDEDC28|Asterix (E) [!]|2|0|0|0|0|0|B42B=EAEA,7D5B=EAEA,7D9B=EAEA,A4C=42DB
-E87BD7EC|Astral Bout (J)|0|0|0|0|0|0
-AC212C51|Astral Bout 2, Sougou Kakutougi|0|0|0|0|0|0
-3F09A8D9|Astral Bout 3, RINGS (J)|0|0|0|0|0|0
-19E09C6B|Atlas, The - Renaissance Voyage|4|44C00|0|0|0|0
-B0A02734|Axelay (J)|0|44400|0|0|0|0|609=42DB
-F812B533|Axelay (U)|0|0|0|0|0|0|C45=42D3,12A2=4219,12AA=4239,12B1=4219,12F6=DB,1DE5=42BA,D370E=4215,127=DB0D
-1B83C440|Bahamut Lagoon (J)|5|0|0|0|0|3007|3007E=EAEA,1A0072=42FA,1580B4=42FC,1A67FB=EAEAEAEA
-726B6C5A|Barkley Shut Up and Jam (U)|0|0|0|0|0|0|163B3=EAEA,163D7=EAEA,14D40=EAEA,14C8E=EAEA
-832A27C2|Bass Masters Classic (U)|0|0|0|0|0|0
-C5058634|Bass Masters Classic Pro Editio|0|0|0|0|0|0|8CE7=EAEA,8D13=EAEA,8EE4=EAEA,8F12=EAEA,8C09=EAEA
-7DC5B7B3|Bassins' Black Bass Fishing wit|4|0|0|0|0|0|13AF=EAEA,13BB=EAEA,13BF=EAEA
-6742D51C|Bastard!! - Ankoku no Hakaishin|0|0|0|0|0|0
-E87DFDF6|Batman Returns|0|0|32C|0|1E|0|10D=653A85984280
-99A1F158|Battle Dodgeball - Tokyu Gekito|4|0|0|0|0|0|8B3=DBC4
-43D3F2B2|Battle Dodgeball 2 (J)|1|0|0|0|0|0|713=42DC
-190FF436|Battle Grand Prix (U)|0|0|0|0|0|0|1AAB9=EAEA
-B72BF1F2|Battle Robot Retsuden (J)|5|44040|0|0|0|0|836A=4282,83AD=42BA,BF02A=425B,BF0D2=425B,BF16F=425B,BF18C=425B,BF19D=425B,2C3CEB=42
-3733B1B1|Battle Soccer - Field no Hasya|4|0|0|0|0|0
-92AFAB02|Battle Tycoon (V1.1) (J)|5|0|0|0|0|0
-56C7EB66|Battletech 3050 (J)|8000001|400000|0|0|0|0|166CB4=EAEA,166CE0=EAEA,166EB1=EAEA,166EDF=EAEA,166BD6=EAEA,696=42DC,101C=42DC,154362=42DC,15464C=42DC,154960=42DC,154D80=42DC,154E70=42DC,13D77B=42DC,13D822=42DC,141973=42DC,141BAE=42DC,78EB=42DC,7815=42DC,13E727=42DC
-8B18AC01|Battletoads & Double Dragon - T|14000000|40000|0|0|0|0|753E=EAEA,7706=EAEA,FFA3=EAEA,A800B=EAEA,A801D=EAEA,A802F=EAEA,A803E=EAEA,A80BD=EAEA,BC9CD=EAEA,BC9E5=EAEA,178=42D8,377=428E,808D=4280,AAB5A=DB,AF2A6=421C,B544D=DBF1,B8106=427D,B8C9D=DBF2,B9568=DB,B9EBA=42DA,BB2B4=DB,BB685=DBF2,BC569=4210,BFE99=428D,BFFF4=428D
-1783E3A2|Battletoads in Battlemaniacs (U|0|4000|0|0|0|0|E7E0A=EAEA,E7E1C=EAEA,E7E2E=EAEA,E7E3D=EAEA,E7FDC=EAEA,7B08=428D,A785F=42D9,ED1EF=421C
-956E183C|Beauty and the Beast (U)|0|40C00|0|0|0|0|3A622=EAEA,3A59F=EAEA,3A5BC=EAEA,C0052=42FB
-15CF4BD5|Beavis and Butthead (U)|0|0|0|0|0|0|52BF=EAEA,5456=EAEA,6272=42FC
-BDA2E412|Bebe's Kids (U)|0|0|0|0|0|0|5D07=42
-4E8B2ECB|Biker Mice From Mars (U)|0|0|0|0|0|0|185B=EAEA,16FC=EAEA,1A7=DB,501=4211,5A0=DB,91A=42BA,131F2=423B,164A0=4290
-53D8410E|Bio Metal (U)|0|4A0F|0|0|0|0|231=42FB
-4229F61D|Bishoujo Sailor Moon R (trans)|1|0|0|0|0|0|CF3A=019C,FF92=019C,CBF6=42FC,D468=DB0B
-4AEE5ABB|Bishoujo Senshi Sailormoon R (|8000001|44800|0|0|0|0|1E00FF=EAEA,1E0104=EAEA,1E011D=EAEA,8BE7=42FC,9C8D=42D8
-31092C4D|Bisyoujyo Senshi Sailor Moon -|8000005|44800|0|0|0|0|1E00FF=EAEA,1E0104=EAEA,1E011D=EAEA,8BE7=42FC,9C8D=42D8
-AD2EFFC3|Blaze On (J)|0|0|7E1100|0|1E|0|4A0=DB
-3B01D0A3|Blazeon (U)|0|0|0|0|0|5|4A0=42FC
-4A62057D|Blues Brothers, The (E) [!]|2|40000|0|0|0|0|3EA=EAEA,418=EAEA,145F=EAEA,1C76=EAEA,343=42FA
-82B97464|Blues Brothers, The (U)|0|40000|0|0|0|0|3F0=EAEA,41E=EAEA,349=42FA
-18BBEE33|Bobby's World (U)|0|0|0|0|0|0
-597AA981|Bonkers|0|0|7E0406|0|1E|0|FED=42
-1899AAFF|Boogerman - A Pick and Flick Ad|1|0|0|0|0|0|67=42DB,26A0=42F9,37C8=421A,28=42DB
-F3DDF35F|Bounty Sword (J)|10000005|4000|0|0|0|0|2F5AA=EAEA,2F5AE=EAEA,2F5BE=EAEA,2F5BA=42DA
-AC443D87|Brain Lord (U)|5|0|0|0|0|0|3065=EAEA,3080=EAEA,1D8FF=42,F8FA=42
-718CB0DF|Brainies, The (U)|0|0|0|0|0|0|3065=EAEA,3080=EAEA
-5CECE690|Bram Stoker's Dracula (U)|0|0|0|0|0|0|F8099=EAEA,F8146=EAEA,F811B=EAEA,F815E=EAEA,F809E=EAEA
-74F70A0B|Brandish (U)|5|0|0|0|0|0|140555=EAEA,14071A=EAEA,140742=EAEA,140819=EAEA,140E74=EAEA,140E90=EAEA,140EA8=EAEA,14C11D=EAEA,815E=42,8175=42D8,817D=42,81C4=42,81D2=42D8,81DA=42,8210=DB,854E=42B9,152737=DB,152B1E=421F
-BB89E67E|Brandish 2 - The Planet Buster|5|0|0|0|0|0|1BF89C=EAEA,290631=EAEA,290CBC=EAEA,290CD8=EAEA,2C8E1F=EAEA
-E822065C|Brawl Brothers (U)|0|0|0|0|0|0|56D8=EAEA,5707=EAEA,5716=EAEA,51FF=EAEA,29462=EAEA,2E5C5=EAEA
-C788B696|Breath of Fire (U)|1300004|0|0|0|0|0|32E=421B,9AB=42D9,A6957=42D9
-67CDACC5|Breath of Fire II (U)|5|0|0|0|0|0|FAF=421B,5E0D=42D7
-9EBFE809|Brett Hull Hockey '95|18000000|4C00|0|0|0|0|F88C=EAEA,F8C0=EAEA,FAEF=EAEA,FCA1=EAEA,FCB9=EAEA,FCC4=EAEA,FCC9=EAEA,FCF7=EAEA,FD18=EAEA,FD1F=EAEA,FD2F=EAEA,FD40=EAEA,FD58=EAEA,FDE1=EAEA,FDF9=EAEA,FE04=EAEA,FE09=EAEA,FE37=EAEA,FE58=EAEA,FE5F=EAEA,FE6F=EAEA,FE80=EAEA,FE98=EAEA,1D66FB=EAEA,1D672D=EAEA,1D694C=EAEA,1D6B16=EAEA,1D6B2E=EAEA,1D6B39=EAEA,1D6B3E=EAEA,1D6B6C=EAEA,1D6B8D=EAEA,1D6B94=EAEA,1D6BA4=EAEA,1D6BB5=EAEA,1D6BCD=EAEA,1D6C5A=EAEA,1D6C72=EAEA,
-FBE35998|Brett Hull Hockey (U)|0|0|0|0|0|0
-8FE49F80|Brutal - Paws of Fury (U)|0|40000|0|0|0|0|F84DC=EAEA,F8275=EAEA,6DF4=42
-21CB8FD4|BS Kirby no Omotya Bako Basebal|0|0|0|0|0|0
-29B7CF34|BS Spriggan Powered - BS Versi|8000000|4040|0|0|0|0|8DF=42FB
-267A5348|BS Super Famicom Wars (V1|2|0|0|0|0|0|B0D=EAEA,B18=EAEA,B46=EAEA,B51=EAEA,BB1=EAEA,BBC=EAEA,BC1=EAEA,BF3=EAEA,C02=EAEA,C4A=EAEA,C5C=EAEA,CE8=EAEA,CF6=EAEA,D16=EAEA,121=42,81558=421E
-444A52C1|Bubsy Bobcat (U)|0|400000|0|0|0|0|75F8=EAEA,176=4297
-D0D172FA|Bubsy II (U)|1|0|0|0|0|0
-832C0CB6|Bugs Bunny in Rabbit Rampage (U|0|0|0|0|0|0|6DF1=42FC,7017=42FC,70A8=42FC,726E=42FC,7429=42FC,64E9=42FC,423=42FC
-62D31295|Bushi Seiryuden (J)|4|0|0|0|0|0
-3266FD23|Bust-a-Move (U)|0|80444C00|0|0|0|0|28B1C=EAEA,28B34=EAEA,28B3F=EAEA,28B44=EAEA,2B8AA=EAEA,2B927=EAEA,2B96F=EAEA,2B979=EAEA,2B98B=EAEA,2B9B3=EAEA,2B9C9=EAEA,2B9F4=EAEA,2BA06=EAEA,2BA31=EAEA,2BA3E=EAEA,2BA50=EAEA,2FEF1=EAEA,2824A=423B,2824F=421B,638C8=DBF2,64556=DB
-A95C1FFF|Cameltry (J)|0|0|0|0|0|0|3A=421B
-F3B5CBB1|Cannon Fodder (E)|2|0|0|0|0|0|D286=EAEA,D376=EAEA,E8D01=EAEA,F953F=EAEA,B9CE4=4289,C6B15=DB,12421B=42B6
-B95FE0A0|Cannondale Cup (U)|4|0|0|0|0|0|3857C=EAEA
-456AB5C8|Captain America & the Avengers |0|0|0|0|0|0|3478=EAEA,354D=EAEA,3C7C=42
-81DB73C7|Captain Commando (U)|1D|0|0|0|0|0|6FC=42DA
-9FD460A4|Captain Novolin (US)|18000000|844C00|0|0|0|0|49=42DB,380F5=42FC,380FE=42FC,183=42DB,1B45=42FB,1B50=42FB,19F0=42F8,272A=42F8
-A3B745BC|Casper (U)|0|0|0|0|0|0|578CC=EAEA,578F1=EAEA,572A8=42FC
-7C4887E1|Castlevania - Dracula X|10000018|0|1D48|1DB6|1E|0|CE=4284,2B12=EAEA,29B2=EAEA
-4EE9EE99|Castlevania - Vampire's Kiss (E|2|0|0|0|0|0|CE=4284,28E=42BA,336=42BA,B09=42D9,B46=42BA,71BCD=421D,1CE665=4212,1D705E=DB62
-B76714F8|Castlevania IV|4000010|0|54E|0|1E|A|187=4286
-2905C3DD|Championship Pool (E)|2|0|0|0|0|0|410A=EAEA,412F=EAEA,40A0=EAEA,40EB=EAEA,40C5=EAEA
-98EF8414|Championship Pool (U)|0|0|0|0|0|0|410A=EAEA,412F=EAEA,40A0=EAEA,40EB=EAEA,40C5=EAEA
-6B953095|Championship Soccer '94 (U)|10000004|40C00|0|0|0|0|3DC2=EAEA,3EA4=EAEA,4AB=42D9,58DCB=42
-76E01CCB|Chaos Seed - Fuusui Kairoki (J|4000005|4040|0|0|0|0|AB37=EAEA,AB3C=EAEA,AB55=EAEA,AE1E=EAEA,9752=42D4,9845=42D4,982C=421A
-BC671E15|Chessmaster, The (U)|0|0|0|0|0|0|2A50=EAEA
-557FE962|Chester Cheetah - Wild Wild Que|0|0|0|0|0|0|73C=EAEA,743=EAEA,74A=EAEA,77C=EAEA,783=EAEA,78A=EAEA
-9E1CF43F|Cho Mahou Tairyku Wozz (J) [T-E|4|0|0|0|0|0|64D7=42FB,61C2=429B,5C0CF=42FB
-788E42C9|Choplifter 3 (E)|2|44800|0|0|0|0|1B99=42F5
-1D2EAE52|Choplifter 3 (U)(30545)|0|44800|0|0|0|0|1B99=42F5
-227E2D1F|Choplifter 3 (U)(54553)|0|44800|0|0|0|0|1B99=42F5
-AD26CC9E|Choplifter III - Rescue Surviv|0|44800|0|0|0|0|1B99=42F5
-B3258F38|Chou Mahou Tairiku WOZZ (J)|4|0|0|0|0|0|64D7=42FB,61C2=429B,5C0CF=42FB
-A5DB02E9|Choujikuu Yousai Macross - Scra|10000001|40C00|7E0A7A|0|1E|0|63752=42BD,BBD53=4250
-2D206BF7|Chrono Trigger (U)|5|0|0|0|5|0|2034A=42FC,EC74=42DB,3DEAEF=42FC,D3E47=DBAB,D3B98=42D8,11C47=42D3
-AE93B9CA|CHRONO~1|5|0|0|0|5|0|703E5=80,7042A=80,70478=80,704EE=EAEAEA,704FA=EAEAEA,705D9=80,31A12=80,31343=EAEA,30720=EAEAEA,307B8=EAEAEA,307C7=EAEA,28D7E=EAEAEA
-E237EC45|Chuck Rock (U)|0|0|0|0|0|0|E00B9=EAEA,E0083=EAEA,E00D0=EAEA,E00F3=EAEA,E0111=EAEA
-41FDBA82|Civilization (U)|5|4000|0|0|0|0|2F1=EAEA,309=EAEA,314=EAEA,319=EAEA
-12F8A26C|Cliffhanger (U)|0|0|0|0|0|0|1193E=EAEA,40F=42DB
-A27940C1|College Football USA '97 - The|4|0|0|0|0|0
-5E2C24F6|Combatribes, The (J)|0|44800|0|0|0|0|32D=42FC
-9304044A|Combatribes, The (U)|0|44800|0|0|0|0|2D4=42FC,32D=42FC
-8A24FBA8|Congo's Caper (U)|0|0|0|0|0|0|53F=42FC
-84DA7CFE|Contra III - The Alien Wars|8000010|0|22A|0|14|5|16A=428A
-44E60E58|Cool Spot (U) [!]|0|840000|0|0|0|0|9EE=42FB,7313=DB68,F3038=42F0
-4DFA05B3|Cybernator (U)|0|0|0|0|0|0|5F3=42FB
-4A5263DB|Cyborg 009 (J)|10000000|40004008|0|0|0|0|E00BB=EAEA,E00E0=EAEA,E0105=EAEA,E010F=EAEA,E011B=EAEA,E0127=EAEA,CA572=42FB,CC17D=42FB,CB323=42DB,CB2E6=42DB,CA563=42DB,CAE35=42DB,CAEEF=42DB,CAA30=42DB,CABA1=42DB,CAC1C=42DB,CE5B2=42DB,CE5BC=42,CE6B6=42DB,C82E3=42DB,C82F2=42,C834C=42DB,C8E63=42DB,C8E70=42,C9282=42DB,CEABC=42DB,CEAC9=42,CEC1C=42DB,4D7C=42DB,2159=42
-5F02A044|Daffy Duck - The Marvin Mission|0|4000|0|0|0|0|20E=42FB
-C5341764|Darius Twin (U)|0|0|7E13D8|0|1E|5|77=428E,17A=4210,E0D47=4211
-7B9793B1|Dark Half (J)|5|0|0|0|0|0|75C=EAEA,12FF3C=EAEA,13F845=EAEA,1AFABB=EAEA,2A0508=EAEA,2A058D=EAEA,1BF=42B9,164604=428C,198B77=423B,2B5E4B=421C,2B66EC=DB
-46F1F4A9|Dark Kingdom (J)|4|0|0|0|0|0|7521=EAEA,7552=EAEA,7583=EAEA,75E5=EAEA,BFE24=EAEA,C0F21=EAEA,C0F39=EAEA,C0F44=EAEA,C0F49=EAEA,C7B8F=EAEA,FC74B=EAEA,1101BB=EAEA,22F13=42,29924=DB,4065B=42,40693=42,406CE=4280,41F43=42D9,45F24=42D9,46DF6=42D9,47628=42D7,B3240=DB,BFEA5=42,BFEED=42,BFF53=4210,C0133=42D9,100490=42D9,100577=42D9,105E71=42D9,105E88=42D9,105EE3=42D9,11FF48=423F
-125A0C22|Dark Law - Meaning of Death (J)|10000005|44000|0|0|0|0|BCBF=EAEA,BCCB=EAEA,BD2E=EAEA,BCE6=EAEA,BCFC=EAEA,BD3D=EAEA,BD44=EAEA,BD4B=EAEA,BD52=EAEA,BD59=EAEA,BD60=EAEA,BD9F=EAEA,BDA6=EAEA,BDAD=EAEA,BDB4=EAEA,BDBB=EAEA,BDC2=EAEA,BDD9=EAEA,BE06=EAEA,2D1=42FC
-A3558177|DBZ - Saiyan Den. (J) [T+Eng]|4|40000|0|0|0|17
-A567957C|Death and Return of Superman, T|0|0|0|0|0|0
-E8236AD2|Demon's Crest|0|0|7E1034|0|1E|A|1A1=DB
-8EE7FAA5|Dennis the Menace (U)|0|0|0|0|0|0|7702=EAEA
-5608C71F|Der Langrisser (J) (V1|2000004|24000000|0|0|0|0|1B035C=EAEA,1B0364=EAEA,1B036C=EAEA,1B0374=EAEA,1B004F=EAEA,2008=EAEA,2023=42DC,1607B=42D4,12DE9=42D4
-35F9EECC|Der Langrisser (V1.1) (J)|4|0|0|0|0|0|1B035C=EAEA,1B0364=EAEA,1B036C=EAEA,1B0374=EAEA,1B004F=EAEA,2008=EAEA,2023=42DC,1607B=42D4,12DE9=42D4
-006364DB|Diddy's Kong Quest (V1.0) (U)|5|0|0|0|0|0|8431=EAEA,8429=EAEA,8434=EAEA,842D=EAEA,8505=EAEA,8411=EAEA,850F=EAEA,8586=EAEA
-2D3B9662|Donald Duck - Maui Mallard in C|0|0|0|0|0|0|1CB=EAEA
-C946DCA0|Donkey Kong Country (V1.0) (U)|10000005|40C00|7E0215|0|A|FFFFFFF1|AB209=EAEA
-3EAA5697|Donkey Kong Country (V1.1) (U)|10000005|40C00|7E0215|0|A|FFFFFFF1|AB209=EAEA
-0E204FBD|Donkey Kong Country - Competiti|10000005|40C00|0|0|0|0|AB0F8=EAEA,AB10A=EAEA,AB11C=EAEA,AB12B=EAEA,AB1B9=EAEA,AB1F9=EAEA,AB20E=EAEA,AB51C=EAEA
-4E2D90F4|Donkey Kong Country 2 - Version|10000005|40C00|0|0|A|FFFFFFF1|358246=EAEA,358414=EAEA,2E8093=EAEA,2E8455=EAEA,302401=EAEA,30A18D=EAEA,32035F=EAEA,358205=EAEA,35822F=EAEA,358241=EAEA,358250=EAEA,358426=EAEA,358431=EAEA,35843E=EAEA,358449=EAEA
-448EEC19|Donkey Kong Country 3 - Dixie K|10000005|40C00|0|0|0|FFFFFFF1|32848C=EAEA,3B8A3A=EAEA
-0551FE84|Donkey Kong Country 3 - Dixie K|10000007|40C00|0|0|0|0|32848C=EAEA,3B8A3A=EAEA
-1889FEEF|Doom Troopers (U)|0|0|0|0|0|0|1AAB9=EAEA
-CEEB7C32|Doomsday Warrior (U)|0|0|0|0|0|0|126=42DA
-98A96AE8|Double Dragon V (U)|1|40000|0|0|0|FFFFFFFB|80C1=42D9,4D9D8=4299,4AEC7=42DB,4DAE4=4299,287C1=42FC,4DD20=42F2,4AD5D=42DB,4DE77=42F9,4AF05=42FB,4AEE6=42FB,49C4A=42F9,4821F=42F9
-63CE5132|Dr. Mario (J) (NP)|4|0|0|0|0|19|255C=EAEA,5C8=4218
-407C5C24|Dragon - Bruce Lee Story (U)|1|0|0|0|0|0|C569=EAEA,C56F=EAEA,C5B5=EAEA,C607=EAEA,C645=EAEA,C64A=EAEA,C667=EAEA,C680=EAEA,C68C=EAEA,C692=EAEA,C696=EAEA,C6BE=EAEA,C6C4=EAEA,C6C6=EAEA,1C0=421A
-57A7072B|Dragon Ball Z - Hyper Dimension|4|840000|0|0|0|0|5872=EAEA,58ED=EAEA,59D5=EAEA,59ED=EAEA
-8C7780BD|Dragon Ball Z - Super Butoden (|0|0|0|0|0|0|73B3=EAEA,73B7=EAEA,74AD=EAEA,80=EAEA,8C=EAEA
-081FDE86|Dragon Ball Z - Super Butoden 2|8000000|40808040|0|0|0|0|B0=EAEA,2934=EAEA,2949=EAEA,295F=EAEA,2973=EAEA,298D=EAEA,29A9=EAEA,29E9=EAEA,2A8B=EAEA,2C35=EAEA,2C9D=EAEA,2CCD=EAEA,2CE4=EAEA,2CFE=EAEA,25C52=EAEA,31088=EAEA,310A3=EAEA,44A93=EAEA,44AA9=EAEA,16E26C=EAEA,1BFEBF=EAEA,1F8C0E=EAEA,194=4294,9228=429A,922E=42BA,55D57=42B4,571D8=42,152A67=421E,1896D7=DB
-D531289B|Dragon Ball Z - Super Goku Den|4|40040800|0|0|0|0|1B809D=EAEA,147=42DC,670=42DC
-67BD2296|Dragon Ball Z - Super Gokuuden|4|44040|0|0|0|28|1809D=EAEA,242=42DC,8E1=42DC
-63D4E96A|Dragon Ball Z - Super Gokuuden|4|40040800|0|0|0|0|1B809D=EAEA,147=42DC,670=42DC
-ADE7B968|Dragon Ball Z - Super Saiya Den|4|40000|0|0|0|20615|20615=EAEA,20620=EAEA,295E=421B,2D8=42BA,DC=4210,1035=EAEA
-52FC7228|Dragon Knight 4 (J)|1000004|440800|0|0|0|0|105=42DC,113D=42DC,135=42DC
-80C078FF|Dragon Quest 1 & 2 (T)|2230004|0|0|0|0|0|0=D87818FB,78FA=EAEA,7901=EAEA,7908=EAEA,790F=EAEA,5BD=42DC
-13836BD2|Dragon Quest 3 (J)|5|0|0|0|0|0|1E119=EAEA,1E125=EAEA,1E131=EAEA,1DD93=EAEA,1DDC0=EAEA,1DDFF=EAEA,1DFC3=EAEA,27AA=DBE9
-BC955F3B|Dragon Quest 5 (J)|4|44804|0|0|0|0|127E20=EAEA,127E25=EAEA,127E20=EAEA,127E25=EAEA,15C37C=EAEA,15C0F8=EAEA,15C37C=EAEA,15C33E=EAEA,FD2D1=EAEA,15C100=EAEA,15C102=EAEA,15BEE1=EAEA,15C1A0=EAEA,360F9=EAEA,15C1A6=EAEA,127FA4=EAEA,127F9F=EAEA,23D6=EAEA,15BCA2=EAEA,1D407=EAEA,1D409=EAEA,1D40B=EAEA,1D410=EAEA,1D411=EAEA,1D4A1=EAEA,1D4AD=EAEA,1D46C=EAEA,15C195=EAEA,90396=EAEA,90351=EAEA,15C09B=42,C02=42,FD2D4=EAEA,FD2B2=EAEA,FD2B4=EAEA,FD2B8=EAEA,FD2BE=EAEA,FD2C1=EAEA,FD2C3=EAEA,15C049=EAEA
-E1924A15|Dragon Quest 6 (J) [T-Eng0|10000005|440000|0|0|0|0|1F0F7=EAEA,1F0FB=EAEA,1F103=EAEA,1F107=EAEA,1F10F=EAEA,1F113=EAEA,1ED70=EAEA,1ED9D=EAEA,1EDDC=EAEA,1EFA0=EAEA,1EE51=EAEA,2223=4288
-B5AE1E89|Dragon Quest I & II|10000004|0|0|0|0|0|0=D87818FB,5BD=42DC,754B=EAEA,7584=EAEA,76D3=EAEA,7701=EAEA,78FA=EAEA,7901=EAEA,7908=EAEA,790F=EAEA,7943=EAEA,795B=EAEA,7966=EAEA,796B=EAEA,12A3D3=EAEA
-33304519|Dragon Quest VI - Maboroshi no|10000005|440000|0|0|0|0|1F0F7=EAEA,1F0FB=EAEA,1F103=EAEA,1F107=EAEA,1F10F=EAEA,1F113=EAEA,1ED70=EAEA,1ED9D=EAEA,1EDDC=EAEA,1EFA0=EAEA,1EE51=EAEA,2223=4288
-81BF8718|Dragon's Earth (J)|8000000|404800|0|0|0|0|6E41=42D8
-24FFE7FD|Dragon's Lair (U)|0|0|0|0|0|0|4DF6=EAEA
-AB5A9E40|Dream TV (U)|0|0|0|0|0|0|301=EAEA
-EBCC121C|Dynamic Stadium (J)|0|0|0|0|0|0|7F=42FC
-DD49911E|E.V.O. Search for Eden (U)|4|0|0|0|0|0|130406=EAEA,13031A=EAEA,130429=EAEA
-DC9BB451|Earthbound (U)|5|0|0|0|0|FFFFFFF6|AB93=EAEA,281D=EAEA,83A2=800E1A8FF07F32CFF07F3080,A12D=80,1FFE7=EAA90000,3FDD6=EAA9000080,8762=42FB
-3A4A47EB|Earthworm Jim|4000001|0|5114|0|32|0|30169=DB
-393DE197|Earthworm Jim 2 (U)|1|0|0|0|0|0|EB99=EAEA,EBC5=EAEA,ED96=EAEA,EDC4=EAEA,EABB=EAEA,E2B4=EAEA,582A=42FC
-F0AEAD80|Edo No Kiba (J)|14000001|44800|0|0|0|0|E00A8=EAEA,759=42FC
-EEC5A5B1|Edono Kiba (J)|14000001|44800|0|0|0|0|E00A8=EAEA,759=42FC
-41E9CD70|Eien no Filena (J)|4|0|0|0|0|0|14DB62=EAEA,14DB96=EAEA,14DBB1=EAEA,14DBB9=EAEA,14DCC4=EAEA,14DFFC=EAEA,14E00E=EAEA,14E02B=EAEA,14E036=EAEA,14E058=EAEA,14E067=EAEA,14E078=EAEA,14E084=EAEA,14E0C4=EAEA,14E0DB=EAEA,14E0E6=EAEA,11A=423B,11F=421B,137=42D7,2296=42D9,2408=42D7,681F=42D9,1276B=42BA,12D63=42BA,1577D4=4251
-F70F2A95|Energy Breaker (J)|4000004|0|0|0|0|0
-BDBF64B3|Energy Breaker (J) [T-Eng]|4|0|0|0|0|0|17F2E8=428A,1813F3=42,1B64E0=4270,1BA050=42D0,1BA3AE=42BA,1BEE5F=42,1C17A0=DB,30D24D=DBF6,30E115=4210,766E=EAEA,7930=EAEA,7985=EAEA,7A94=EAEA,7C2E=EAEA,7C46=EAEA,7C51=EAEA,7C56=EAEA,20C291=EAEA,20F33F=EAEA
-634344A0|Esparks - Ijigen kara no Houmon|5|0|0|0|0|0|DC819=EAEA,DC827=EAEA,DC83D=EAEA,DC849=EAEA,DC857=EAEA,DC86D=EAEA,DC888=EAEA,DC8BB=EAEA,DCA08=EAEA,DCA3B=EAEA,DCA64=EAEA,DCA9D=EAEA,DCAAD=EAEA,DCAC2=EAEA,DCADE=EAEA,DCB1C=EAEA,DCB2F=EAEA,DCB55=EAEA,DCB81=EAEA,DCB90=EAEA,DCBA8=EAEA,DCBB9=EAEA,DCBD4=EAEA,DCBEC=EAEA,DCBF7=EAEA,DCBFC=EAEA,DCC3D=EAEA,9AFD=42D9,966DC=42,DE559=4251,ECBDA=42D1
-26849F90|ESPN Sunday Night NFL (U)|4|0|0|0|0|0|1EAE57=EAEA,1EAE7C=EAEA
-D9665BBC|Estpolis Denki II (J)|8000004|4044C00|0|0|0|0|69350=42FC,86=42DC,19010=42FC,69F11=42FC
-2C6EB470|Euro Football Champ (E)|2|0|0|0|0|0|54=428E
-440A4250|Extra Innings (U)|4|0|0|0|0|0|407=EA
-AA0E31DE|F-Zero (U)|4|0|0|0|0|0|7819=EAEA,7831=EAEA,783C=EAEA,7841=EAEA,619=425B
-7049AAE8|F1 Pole Position (u)|4|0|0|0|0|0|298=EAEA
-2CE70B92|Famicom Tantei Club Part II (J)|4|0|0|0|0|0|219=4218
-1E327BD9|Far East of Eden Zero (J)|2|0|0|0|0|0|3157=EAEA,3197=EAEA,31AE=EAEA,31CA=EAEA,34EE=EAEA,34FA=EAEA,3506=EAEA,3518=EAEA,37F9=EAEA,3816=EAEA,3857=EAEA,385D=EAEA,398B=EAEA,3997=EAEA,39CA=EAEA,3A17=EAEA,3A38=EAEA,6FB6B=EAEA,6FBB1=EAEA,1DA793=EAEA,297691=EAEA,3F2F31=EAEA,46FBA3=EAEA,49CAD3=EAEA,4A5170=EAEA,4B1786=EAEA,F25A=42,F2A7=DB,F732=42,F8CD=42,FADC=42,10381=42D9,164A58=DB,47F43D=421E,4AB668=DB
-0ED3DCF2|Farland Story (J)|5|0|0|0|0|0|1D129A=EAEA,1D0192=EAEA,4153F=42FB,413B2=42FB,4C9=42FB,40C00=42DC,1D12C3=42DB
-1CF58DE9|Farland Story 2 (J)|5|800|0|0|0|0|2D01F3=EAEA,2D0196=EAEA,390=42FB,2D021C=42DB
-C67257D0|Fatal Fury (U)|0|0|0|0|0|0|37C=42D8
-A26EBFEF|Fatal Fury 2 (U)|1|0|0|0|0|0|578CC=EAEA,578F1=EAEA,572A8=42FC
-93935BEE|Fatal Fury Special (U)|1|0|0|0|0|0|C2A=42FB
-EDA70F8A|Feda - Emblem of Justice (J)|5|0|0|0|0|0|5057B=EAEA,503B0=EAEA,503EC=EAEA,50423=EAEA,50453=EAEA,5047C=EAEA,504B0=EAEA,E9E=42DC,23A8=42D4,1017C=42D8,218C7=42D1,10401=42D1,503B4=42D2,F62=42D4,90385=42D4,19DE=42D4,11E67=42D4
-7D36ECD7|Feda - The Emblem of Justice (J|5|0|0|0|0|0|5057B=EAEA,503B0=EAEA,503EC=EAEA,50423=EAEA,50453=EAEA,5047C=EAEA,504B0=EAEA,E9E=42DC,23A8=42D4,1017C=42D8,218C7=42D1,10401=42D1,503B4=42D2,F62=42D4,90385=42D4,19DE=42D4,11E67=42D4
-65D0A825|ff2|10000004|0|0|0|0|0|F24=42DC,F15=42DC,BED=42,10524=42,20033=EAEA,20063=EAEA,20077=EAEA,200AA=EAEA,20235=EAEA,202D6=EAEA,202FA=EAEA,20311=EAEA,20374=EAEA,20385=EAEA,203A1=EAEA,204AB=EAEA,20547=EAEA,2056F=EAEA,205C7=EAEA,205D8=EAEA,205FA=EAEA,20610=EAEA
-CAA15E97|FF4 (J)|4|0|0|0|0|0|F24=42DC,F15=42DC,BED=42,10524=42,20033=EAEA,20063=EAEA,20077=EAEA,200AA=EAEA,20235=EAEA,202D6=EAEA,202FA=EAEA,20311=EAEA,20374=EAEA,20385=EAEA,203A1=EAEA,204AB=EAEA,20547=EAEA,2056F=EAEA,205C7=EAEA,205D8=EAEA,205FA=EAEA,20610=EAEA
-D5CC300E|ff4e|4|0|0|0|0|0|F24=42DC,F15=42DC,BED=42,10524=42,20033=EAEA,20063=EAEA,20077=EAEA,200AA=EAEA,20235=EAEA,202D6=EAEA,202FA=EAEA,20311=EAEA,20374=EAEA,20385=EAEA,203A1=EAEA,204AB=EAEA,20547=EAEA,2056F=EAEA,205C7=EAEA,205D8=EAEA,205FA=EAEA,20610=EAEA
-C1BC267D|FF5 (J)|10000005|0|0|0|0|0
-170778FA|ff6e|5|0|0|0|0|0
-250B44BA|FFMISTIC|10000004|40C00|0|0|0|0|68047=EAEA,68068=EAEA,6807A=EAEA,680CD=EAEA,680FD=EAEA,68114=EAEA,68121=EAEA,6819B=EAEA,681A3=EAEA,681B9=EAEA,681C1=EAEA,681CB=EAEA,681DC=EAEA,681E4=EAEA,68214=EAEA,6821C=EAEA,6822F=EAEA,6828C=EAEA,6839E=EAEA,683C7=EAEA,683DD=EAEA,68437=EAEA,684CA=EAEA,6855F=EAEA,685D0=EAEA,685D6=EAEA,685F0=EAEA
-A27F1C7A|Final Fantasy 3 (V1.0) (U)|10000005|44C00|0|0|0|0|28236=42DC,B7A3=EAEA,568=42FC,B80A=EAEA,109B9=EAEA,50055=EAEA,500A6=EAEA,500D6=EAEA,500ED=EAEA,500FA=EAEA,501B8=EAEA,5027C=EAEA,50391=EAEA,503E1=EAEA,5044C=EAEA,50489=EAEA,504B0=EAEA,504CB=EAEA,504F2=EAEA,50521=EAEA,5059B=EAEA,505C5=EAEA,5064A=EAEA,50662=EAEA,506A4=EAEA,506B2=EAEA,71796=EAEA,83440=EAEA,25F824=EAEA,25F855=EAEA,25F8D0=EAEA,295AF6=EAEA,2E1889=EAEA,11A28=42DC
-C0FA0464|Final Fantasy III (U) (V1|10000005|44C00|0|0|0|0|28236=42DC,B7A3=EAEA,568=42FC,B80A=EAEA,11A28=42DC
-892E44BE|Final Fantasy 5|5|0|0|0|0|0
-17444605|Final Fantasy 5 (Translated)|10000005|0|0|0|0|0|387BB=42DC,4E45=42FC,422=EAEAEA
-8D66F796|Final Fantasy 5 (Translated)|10000005|40C00|0|0|0|0|422=EAEAEA,10397=421A,11A88=42D5,1EA6C=421A,1F77A=421A,2A10D=423A,2A113=421A,4CE48=42,4F07A=DBFE,1BF7CC=DB,387BB=42DC,4E45=42FC
-45EF5AC8|Final Fantasy 6 (J)|10000005|44C00|0|0|0|0|B6D8=421B,B6D8=EAEA,B73F=421B,B73F=EAEA,568=42FC
-23084FCD|Final Fantasy II|0|0|0|0|0|FFFFFFE7|F24=42DC,F15=42DC,BED=42,10524=42,20033=EAEA,20063=EAEA,20077=EAEA,200AA=EAEA,20235=EAEA,202D6=EAEA,202FA=EAEA,20311=EAEA,20374=EAEA,20385=EAEA,203A1=EAEA,204AB=EAEA,20547=EAEA,2056F=EAEA,205C7=EAEA,205D8=EAEA,205FA=EAEA,20610=EAEA
-D19F6CB5|Final Fantasy V (J) [T+Eng1|10000005|0|0|0|0|0|B7D8=EAEA,B7E0=EAEA,3FE4A=EAEA,3FE6E=EAEA,3FE81=EAEA,3FED2=EAEA,3FF02=EAEA,3FF19=EAEA,3FF26=EAEA,3FFA0=EAEA,3FFA8=EAEA,3FFB2=EAEA,3FFC3=EAEA,3FFCB=EAEA,3FFF3=EAEA,3FFFB=EAEA
-87C13675|Final Fantasy V (J) [T+Eng1|10000006|0|0|0|0|0|387BB=42DC,4E45=42FC,422=EAEAEA
-4CAB21DB|Final Fight|0|0|7E0D0A|0|1E|0|81F5=EAEA,8231=EAEA,FA=421C
-8C37FF55|Final Fight 2 (U)|0|0|7E1019|0|1E|0|966=42DB
-A916E708|Final Fight 3 (U)|1|0|0|0|0|0|66F3=42F4
-BC1AE3C2|Final Fight Guy (US)|0|0|0|0|0|0|8456=EAEA,8312=EAEA,836C=EAEA
-25D214F4|Fire Emblem - Monsyo no Nazo (V|4|0|0|0|0|0|3969=EAEA,3977=EAEA,39CC=EAEA,39DD=EAEA,39F0=EAEA,3A24=EAEA,3A56=EAEA,3A5B=EAEA,3A8A=EAEA,3AA2=EAEA,3AAD=EAEA,3AB2=EAEA,3CA5=EAEA,3CBE=EAEA,1C9A35=EAEA
-DC0D8CF9|Fire Emblem 4 - Seisen no Keifu|5|0|0|0|0|0
-BC6162AE|Fire Emblem 5 Trachia 776 (J) (|4|0|0|0|0|0
-FC519952|Fire Emblem 5 Trachia 776 (Rom|4|0|0|0|0|0
-E500C7BA|Fire Striker (U)|0|0|0|0|0|0|96=42D9
-1E6ACEBA|Flashback - The Quest for Ident|1|0|0|0|0|0|190098=EAEA,1900B0=EAEA,1900BB=EAEA,1900C0=EAEA,1900EE=EAEA,1900FD=EAEA,190497=EAEA,1904C6=EAEA,1904F5=EAEA,19052C=EAEA,190560=EAEA,190588=EAEA,80A2=42D9,8183=42,15974=42,15991=42,159CF=42,159EC=42,15B60=42,16220=42,1628E4=4259
-3E7B51E0|Flintstones, The (U)|0|0|0|0|0|0
-5FA4D051|Foreman For Real (U)|0|0|0|0|0|0|11791=42F2
-21239DDA|Frank Thomas' Big Hurt Basebal|4|0|0|0|0|0|44F4=42FC,44D9=42FC,39104=42FC,39159=42FC,1E445=42FC,1E4AC=42FC,1F4F7=42FC,1F6CC=42FC,12126=42FC
-FFA8D1FF|Frantic Flea (U)|0|0|0|0|0|0|1A424=EAEA,1A547=EAEA,1A4EF=EAEA,1A3FB=EAEA,1A4C4=EAEA,1A399=EAEA,1A45E=EAEA,1A49B=EAEA,8138=42FB
-2488B8F2|Frogger (U)|0|0|0|0|0|0|7F353=EAEA,7F378=EAEA,7ED2F=42FC
-2B4CD5A3|Front Mission (J) (V1.0)|5|40800|0|0|0|0|2A0A1B=EAEA,258A=42FB
-5847D80F|Front Mission - Gun Hazard (J)|18000005|840C00|0|0|0|0|2A005B=EAEA,2A07E2=EAEA,2A0664=EAEA,2A0659=EAEA,1006B=42F7,10093=42F7,59B=42FB,6FB=42D0
-FD3FDBAC|Front Mission 2 - Gun Hazard (J|18000005|840C00|0|0|0|0|2A005B=EAEA,2A07E2=EAEA,2A0664=EAEA,2A0659=EAEA,1006B=42F7,10093=42F7,59B=42FB,6FB=42D0
-AF5703EE|Fushigi no Dungeon 2 - Furai n|5|40000084|0|0|0|0|18133=428E
-79114FD0|G Gundam|1320001|0|0|0|0|0|8B3=42DB
-B344E9A0|Gaia Gensouki (J)|28176=421A,2A116=EA,2A865=EA,39D4F=EA,497BA=EA,581D4=EA,5D931=EA,6913F=EA,8D7E2=EA,8E471=EA,8E8AB=EA
-6CD62399|Ganbare Goemon - Yukihime Kyusy|10000000|840000|0|0|0|0|C2=4280
-CA4C0219|Ganbare Goemon 2 (J)|4|0|0|0|0|0|3A5A=EAEA,DB=4284
-7E5929E8|Ganbare Goemon 3 (J)|4|0|0|0|0|0|F3=4280,249C3=EAEA,24865=EAEA,1B0=4230
-BB9D8E56|Ganbare Goemon 4 - KiraKira Dot|4|0|0|0|0|0|704=EAEA,70B=EAEA,712=EAEA,744=EAEA,74B=EAEA,752=EAEA
-EE801A54|Gemfire|6|0|0|0|0|0|1583=42DB,14C2=42D9,1155=42D9,1290=42D9,1539=42D9,1274=42D9,1217=42D9
-C8E8853E|Genghis Khan II - Clan of the G|4|0|0|0|0|0|3778=EAEA,37A4=EAEA,37AF=EAEA,37B4=EAEA,4E4=DB,10E9=42BA,38C0=42D9,3CE2=42D9
-EA16B5A2|Ghoul Patrol (U)|0|40C04|0|0|0|0|CFF4=EAEA,D00C=EAEA,D017=EAEA,D01C=EAEA,D061=EAEA,D068=EAEA,D082=EAEA,D0BC=EAEA,D0D3=EAEA,D0E6=EAEA,D113=EAEA,D135=EAEA,EE890=EAEA,256=42BA
-019309A2|Ginga Eiyu Densetsu (J)|0|44800|0|0|0|0|407=42FC
-04EE98ED|Gokujyou Parodius (J)|0|840000|7E0BCE|0|23|0|346A=EAEA,330B=EAEA,12C=4280
-426881A3|Gon (J)|0|0|0|0|0|0
-CD973979|Gradius 3|4000000|0|20E|0|32|0|1C7=428A
-1903EA89|Great Circus Mystery Starring M|1|0|0|0|0|0|19D9=4290,1A64=42D9,1DB5=428E
-1F73C832|GT Racing (J)|4|0|0|0|0|0
-6F5C5DC0|Gun Force|0|40000|9004|0|1E|5
-8E0A7034|Hagane (U)|1|0|0|0|0|0|D1E3=EAEA,D36E=EAEA,D394=EAEA,D32B=EAEA,D2C5=EAEA,D292=EAEA,D297=EAEA,D256=EAEA,D25B=EAEA,D398=EAEA,D086=EAEA,D08E=EAEA,D092=EAEA,3238=421B
-58752BAF|HAL's Hole in One Golf|0|40C00|0|0|0|0|4F41=EAEA,5DF7=EAEA,5E39=EAEA,844E=EAEA,8546=EAEA,865C=EAEA,8826=EAEA,89C8=EAEA,9A12=EAEA,9A20=EAEA,B2FE=EAEA,D08F=EAEA,D27A=EAEA,FDA8=EAEA,FE04=EAEA,5EB46=EAEA,5EBE4=EAEA
-B78F76BF|Hanjuku Eiyuu - Aah Sekai yo Ha|4|0|0|0|0|0
-D191AD46|Hanjuku Eiyuu - Aah Sekai yo Ha|4|0|0|0|0|0
-D54E1452|Harvest Moon (E) [!]|6|0|7E0147|0|1E|2A|18EC3=EAEA,18E52=EAEA,18E70=EAEA,18E79=EAEA,185CC=EAEA,18612=EAEA,1865E=EAEA,186A5=EAEA,1871D=EAEA,18762=EAEA,184F1=EAEA,18531=EAEA,18560=EAEA,1858D=EAEA,656=42FC,18ED5=42D2,18EDC=EAEA,189F1=EAEA,18A0A=EAEA,18A44=EAEA,18A81=EAEA,18AC7=EAEA,18AF4=EAEA,18803=EAEA,1884A=EAEA,18896=EAEA,188DB=EAEA,188DD=EAEA,18955=EAEA,1899A=EAEA,18B20=EAEA,18B7E=EAEA,18BCA=EAEA,18C11=EAEA,18C89=EAEA,18CD0=EAEA,18D3C=EAEA,18D5A=EAEA,18D85=EAEA,15943=42FA,18EF7=42DB,18E00=42DB,18E2C=EAEA,15811=42FA,18DAE=EAEA,18DD7=80,189D3=EAEA,87=42FA,1534F=42F6
-F829129E|Harvest Moon (U)|4|0|7E0147|0|1E|2A|18EC3=EAEA,18E52=EAEA,18E70=EAEA,18E79=EAEA,185CC=EAEA,18612=EAEA,1865E=EAEA,186A5=EAEA,1871D=EAEA,18762=EAEA,184F1=EAEA,18531=EAEA,18560=EAEA,1858D=EAEA,656=42FC,18ED5=42D2,18EDC=EAEA,189F1=EAEA,18A0A=EAEA,18A44=EAEA,18A81=EAEA,18AC7=EAEA,18AF4=EAEA,18803=EAEA,1884A=EAEA,18896=EAEA,188DB=EAEA,188DD=EAEA,18955=EAEA,1899A=EAEA,18B20=EAEA,18B7E=EAEA,18BCA=EAEA,18C11=EAEA,18C89=EAEA,18CD0=EAEA,18D3C=EAEA,18D5A=EAEA,18D85=EAEA,15943=42FA,18EF7=42DB,18E00=42DB,18E2C=EAEA,15811=42FA,18DAE=EAEA,18DD7=80,189D3=EAEA,87=42FA,1534F=42F6
-DD792499|Hashire Hebereke (J)|4|0|0|0|0|0|902=421A,938=421A,946=421A,9C3=421A,BCB=42BA
-46ACFC84|Holy Striker (J)|0|0|0|0|0|0
-07C494B1|Home Alone|0|0|0|0|0|0|1C1=EAEA,3D9=EAEA,3FB=EAEA,40D=EAEA,429=EAEA,443=EAEA,44E=EAEA,453=EAEA,48E=EAEA,499=EAEA,4AE=EAEA,4C5=EAEA,4DC=EAEA,4E9=EAEA,4F9=EAEA
-D19165D9|Home Alone 2 - Lost in New York|10000000|4000|0|0|0|0|72630=EAEA,7263B=EAEA,72650=EAEA,72695=EAEA,7269A=EAEA,726AB=EAEA,726B0=EAEA,726D3=EAEA,726F0=EAEA,7270A=EAEA,72715=EAEA,7271A=EAEA,72752=EAEA,72763=EAEA,72771=EAEA,7282B=EAEA,72836=EAEA,7284D=EAEA,72879=EAEA,7289F=EAEA,7237A=42
-FA698C31|Home Improvement (U)|0|0|0|0|0|0|5FAE1=EAEA,64911=EAEA,6492B=EAEA,64936=EAEA,6493B=EAEA,64A15=EAEA,64A33=EAEA,64AE9=EAEA,64B04=EAEA,64B16=EAEA,64B29=EAEA,64B38=EAEA,64B48=EAEA,64B67=EAEA,64B79=EAEA,64B8C=EAEA,64B9B=EAEA,64BB8=EAEA,64BE0=EAEA,1D0E8=DB,414E4=42,6083D=4210,60EE3=DBFC
-82FF23BC|Hook (U) (29252)|0|0|0|0|0|0|19093=42DB,6B54=42DC,22FC=42D7,190C7=42DC,18D28=42DC,19DE0=EAEA
-D2AF01D4|Humans, The|2|0|0|0|0|0|24F6=EAEA,2521=EAEA,252C=EAEA,2531=EAEA,256A=EAEA,2585=EAEA,2590=EAEA,C646=EAEA,C6FC=EAEA,CD78=EAEA,1F39=423A,1FA5=42
-C796E830|Hunt for Red October (U)|0|0|0|0|0|0
-7D179E21|Hyper V-Ball (U)|0|0|0|0|0|0|E5=EAEA,D1=EAEA,CE27=EAEA,305=423C
-EE441564|Ignition Factor (U)|1|0|0|0|0|0|9639=42D9,96B9=4237,96C2=4217,C000=42D9,C137=42D9,F408=423B,F40D=421B,F42C=42DD,ABCFC=DB,F31C6=4230,F8713=421F
-1C3848C0|Illusion of Gaia (U)|5|0|0|0|5|0|3C75E=EAEA,28051=EAEA,8359=42BA,281CE=42D9,86541=DB,A6B23=DB64,B1BD9=42,DF223=4212,122D21=42BD
-9D104C99|Illusion of Time (E)|6|0|0|0|0|0|38F=EAEA,10BA8=EAEA,10BAF=EAEA,110B5=EAEA,1113B=EAEA,11146=EAEA,1114B=EAEA,11183=EAEA,111A7=EAEA,111BF=EAEA,111CA=EAEA,111CF=EAEA,111FC=EAEA,120AA=EAEA,1E21F=EAEA,219B1=EAEA,2D27E=EAEA,3125C=EAEA,46FB8=EAEA,4C5C8=EAEA,5E6E6=EAEA,90EE2=EAEA,99340=EAEA,C0ACB=EAEA,F20CA=EAEA,106D87=EAEA,113C93=EAEA,1512B0=EAEA,156523=EAEA,15889E=EAEA,177B32=EAEA,186AFA=EAEA,188AC7=EAEA,35C=42BA,101CE=42D9,6F223=4212,146541=DB,1552ED=DB64,1583CC=42,192154=42BD
-2624F8BD|Imperium (U)|18000000|40404|0|0|0|0|B8426=EAEA,B842E=EAEA,B843F=EAEA,B8444=EAEA,3362=421B,3354=4219,33C2=42D3
-D0FF7E9F|Incantation (U)|0|0|0|0|0|0
-0B6209BA|Incredible Crash Dummies, The (|0|0|0|0|0|0
-36B5A429|Incredible Hulk, The (U)|0|0|0|0|0|0
-70DA6BB8|Indiana Jones - Trilogy (US)|10000000|40844000|0|0|0|0|2E9=423C,1FD23C=42FC,E3A=42F8,1FAD4F=42F8,1FD17E=42DC,1FD1B8=42DC,1FF77C=42DC,1FF794=42D1,1FD316=42D5,1FF763=42
-0A20E602|International Superstar Soccer|0|440404|0|0|0|0|4337=EAEA,41D7=EAEA,DE=4284
-49627238|International Superstar Soccer|0|40000|0|0|0|0|2ABC=EAEA,294D=EAEA,295B=EAEA,F9=4284
-CBA724BA|International Superstar Soccer|2|440404|0|0|0|0|4337=EAEA,41D7=EAEA,DE=4284
-CD2150C8|J.R.R|0|0|0|0|0|0|8EF3=EAEA,8EF9=EAEA,8F37=EAEA,8F5B=EAEA,8F6E=EAEA,83A1=EAEA,83BC=EAEA,F4=42DB,7C=42DB,C6=42DB,E2E=42,83C2=42D4,19D1=421A,188D=421A
-66F00725|James Pond's Crazy Sports (E)|2|0|0|0|0|0|170B0=EAEA,F55C=EAEA
-3E3073CE|Jetsons (U)|10000000|4040|0|0|0|0|E0048=EAEA,E03D6=EAEA,1ED=42F9
-3A2B6167|Joe & Mac (U) [!]|0|0|0|0|0|0|1622=42FC
-3511EFB3|Jungle Book, The (U)|0|840000|0|0|0|0
-8A926D1A|Jurassic Park II - The Chaos Co|10000002|44800|0|0|0|0|1180F6=EAEA,11811D=EAEA,118125=EAEA,11814C=EAEA,118154=EAEA,11817B=EAEA,118183=EAEA,1181AA=EAEA,149A0F=EAEA,149A36=EAEA,118420=EAEA,118447=EAEA,1C32F1=EAEA,1C3481=EAEA,1C348E=EAEA,1C34C4=EAEA,1C394C=EAEA,1C56C8=EAEA,1C3D0A=EAEA,1C3D40=EAEA,1C5774=EAEA,1C6C5B=EAEA,1C6C97=EAEA,1C6CBE=EAEA,1C42E7=EAEA,1C5216=EAEA,1C524C=EAEA,1C533D=EAEA,1C4A43=EAEA,1C4A79=EAEA,1C371E=EAEA,1C3754=EAEA,1C75F6=EAEA,1C45AF=EAEA,1C45E5=EAEA,1C461B=EAEA,1C1D16=EAEA,1C25E7=EAEA,1499B5=EAEA,1499BD=EAEA,1499E4=EAEA,F03E2=EAEA,F0409=EAEA,1498F2=EAEA,149919=EAEA,118465=EAEA,11848C=EAEA,1C2086=EAEA,14998E=EAEA,149921=EAEA,149948=EAEA,149950=EAEA,149977=EAEA,149850=EAEA,149877=EAEA,14987F=EAEA,1498A6=EAEA,F042C=EAEA,F0453=EAEA,E27B6=EAEA,E27DD=EAEA,E2A99=EAEA,E2AC0=EAEA,E2F11=EAEA,E2B28=EAEA,E2B4F=EAEA,E2CDD=EAEA,E2F38=EAEA,F0CC5=EAEA,E2D04=EAEA,F0CEC=EAEA,149779=EAEA,1497A0=EAEA,F15D9=EAEA,F1600=EAEA,F1702=EAEA,F1729=EAEA,F1738=EAEA,F175E=EAEA,506=EAEA,52D=EAEA,E3298=EAEA,E32BF=EAEA,E2D89=EAEA,E2DB0=EAEA,E2EDD=EAEA,E2F04=EAEA,149530=EAEA,E2F45=EAEA,1180DF=42FC,118383=42FC,118345=42FC,1C00E0=42FB,1C6425=42DB,7D2=42FC
-836EE990|Jurassic Park Part 2 -The Chao|0|440800|0|0|0|0|1180F6=EAEA,11811D=EAEA,118125=EAEA,11814C=EAEA,118154=EAEA,11817B=EAEA,118183=EAEA,1181AA=EAEA,149A0F=EAEA,149A36=EAEA,118420=EAEA,118447=EAEA,1C81BE=EAEA,1C81E5=EAEA,1C7322=EAEA,1C734B=EAEA,1C75E8=EAEA,1C32F1=EAEA,1C3489=EAEA,1C34BF=EAEA,1C3947=EAEA,1C56BA=EAEA,1C3D05=EAEA,1C3D3B=EAEA,1C6417=EAEA,1C5766=EAEA,1C57AE=EAEA,1C6C4D=EAEA,1C6C89=EAEA,1C6CB0=EAEA,1C42E2=EAEA,1C4318=EAEA,1C4357=EAEA,1C5208=EAEA,1C532F=EAEA,1C52B9=EAEA,1C4A35=EAEA,1C4A6B=EAEA,1C3719=EAEA,1C45AA=EAEA,1C45E0=EAEA,1C4616=EAEA,1C252C=EAEA,1C25E7=EAEA,1C2086=EAEA,14998E=EAEA,118465=EAEA,11848C=EAEA,1C72FB=EAEA,1C1D16=EAEA,1499B5=EAEA,1499BD=EAEA,1499E4=EAEA,F03E2=EAEA,F0409=EAEA,1498F2=EAEA,149919=EAEA,149921=EAEA,149948=EAEA,149950=EAEA,149977=EAEA,149850=EAEA,149877=EAEA,14987F=EAEA,1498A6=EAEA,F042C=EAEA,F0453=EAEA,E27F1=EAEA,E2818=EAEA,E2F4C=EAEA,E2F73=EAEA,E2AD4=EAEA,E2AFB=EAEA,E2B63=EAEA,E2B8A=EAEA,E2D18=EAEA,F0CC5=EAEA,E2D3F=EAEA,F0CEC=EAEA,149779=EAEA,1497A0=EAEA,F15D9=EAEA,F1600=EAEA,F1702=EAEA,F1729=EAEA,F1738=EAEA,F175E=EAEA,4FB=EAEA,5FC=EAEA,522=EAEA,6B0=EAEA,623=EAEA,6D7=EAEA,E32D3=EAEA,E32FA=EAEA,E2DC4=EAEA,E2DEB=EAEA,E2F18=EAEA,E2F3F=EAEA,149530=EAEA,149557=EAEA,1C6CF7=EAEA,1C6D1E=EAEA,1C6D45=EAEA,1180DF=42FC,118383=42FC,118345=42FC,1C00E0=42FB,7C7=42FC
-1D151D45|Jyutei Senki (J)|5|0|0|0|0|0
-457F32B5|Jyutei Senki (J) [t-eng]|10000005|4040|0|0|0|0
-B2592EAE|Kablooey (U)|0|0|0|0|0|0
-AD324F9D|Kabuki Rocks (J)|4|0|0|0|0|0
-8BF2B589|Ken Griffey Jr's. Baseball (U)|4|40C00|0|0|0|0|1A15=EAEA,1A57=EAEA,1AD6=EAEA,1AE6=EAEA,253FB=EAEA,25525=EAEA,2555C=EAEA,25583=EAEA,2559E=EAEA,1E8B12=EAEA
-BD6C8AB1|Kid Klown in Crazy Chase (U)|0|0|0|0|0|0
-252C1DA7|Killer Instinct (V1.0) (U)|10000001|0|0|0|0|0|1F2A0=EAEA,F2B4=42
-09E9A04E|Killer Instinct (V1.1) (U) [!]|10000001|44040|0|0|0|0|1F25B=EAEA,F26C=42
-DD505DF7|King of Dragons, The (U)|1|0|0|0|0|0|41F60=EAEA,420E3=EAEA
-B41AECCC|King of the Monsters 2(J)|1000001|0|0|0|0|0|14026D=EAEA,140189=EAEA,14018E=EAEA,1B0=42DC
-0B677A37|King of the Monsters 2(U)|1|0|0|0|0|0|140285=EAEA,14028A=EAEA,1401A6=EAEA,1401AB=EAEA,1EE=42DC
-5C869CA5|Kinnikuman - Dirty Challenger |0|44C00|0|0|0|0|F54=42D7,4993=42DA,F62=42DA,F85=42FB
-2A24FC9B|Kirby Bowl (J) [!]|10000004|44C00|0|0|0|0|2C32=EAEA,2C3D=EAEA,2C42=EAEA,2C74=EAEA,3805=EAEA,389E=EAEA,38B4=EAEA,38E4=EAEA,38F5=EAEA,3903=EAEA,1C5=42DD,47E=423A,484=421A,89A21=DB
-21E658B8|Kirby's Avalanche (U) [!]|10000000|840000|0|0|0|0|FF1=EAEA,106E=EAEA,1010=EAEA,103C=EAEA,CF=42FC,2407B=42DB,5AA=42
-995CC0A3|Kirby's Dream Course|18000004|40C00|0|0|0|0|2A95=EAEA,3716=EAEA,3724=EAEA,36D5=EAEA,36BF=EAEA,3705=EAEA,474=42
-DF8153D9|Kirby's Dream Course (U)|18000004|40C00|0|0|0|0|2A95=EAEA,3716=EAEA,3724=EAEA,36D5=EAEA,36BF=EAEA,3705=EAEA,474=42
-134DB760|Kirby's Dream Course (U)|18000004|40C00|0|0|0|0|2A95=EAEA,3716=EAEA,3724=EAEA,36D5=EAEA,36BF=EAEA,3705=EAEA,474=42
-EC8A48F6|Kirby's Dream Land 3 (U)|0|0|0|0|0|0|149B=42
-81079934|Kishin Korinden ONI (J)(44230)|8000005|0|0|0|0|0
-AAA82126|Knights of the Round (U)|0|40000|0|0|0|0|71=42
-4390D719|Lady Stalker - Kako Kara no Ch|5|800|0|0|0|0|26041D=EAEA,2603D0=EAEA,2603E7=EAEA,2603FA=EAEA,2603A5=EAEA,2C623=EAEA,1EE0=423C,1F0C=423C
-D2554270|Lagoon (U)|4|0|0|0|0|0|14B=EAEA,20E=42D9,4E6=42DB,3BB=42DA,9B1=42D9
-91633D95|Last Action Hero (E)|2|0|0|0|0|0|6F2=42FA,D1DAB=42FB,D1DFD=42FB,D1DD6=42FB,D04A4=42FB,D1D8A=421A,37DB8=42DB,5F8=421B
-8254A32E|Last Fighter Twin (J)|4000000|400808|0|0|0|0|1103=42D7,BB5=42D8
-42E3774E|Legend (U)|0|0|0|0|0|0|38022=EAEAEAEA,D9=42FC
-82479D6A|Legend of the Mystical Ninja|16000000|840000|0|0|0|0|C2=4280
-777AAC2F|Legend of Zelda, The - A Link t|4|0|0|0|0|0|36=42,E7=EAEA,894=EAEA,8B6=EAEA,8C1=EAEA,8C6=EAEA,BF1B=EAEA,BF5F=EAEA,C15C=EAEA,1056E=EAEA
-B28B2F77|Legend of Zelda, The - Zelda no|4|0|0|0|0|0|36=42,E7=EAEA,894=EAEA,8B6=EAEA,8C1=EAEA,8C6=EAEA,BF1B=EAEA,BF5F=EAEA,C15C=EAEA,1056E=EAEA
-51E3D566|Lemmings (V1.1) (U) [!]|0|0|0|0|0|0|42058=423C,B58F=423C,A201=42FC
-C68BE22A|Lennus II - Fuuin no Shito (J)|5|400800|0|0|0|0|CAA0=EAEA,CAA4=EAEA,CAB0=EAEA,CAB4=EAEA,A626=42DC
-8A46ED37|Lion King, The (E)|3|0|0|0|0|0
-B916334C|Little Master - Niji Iro no Mas|4|0|0|0|0|0|B801=42FC,63D1=42
-1EAFB345|Live A Live (J) [T+Eng V1|5|0|0|0|0|0
-C8FBFAA8|Lion King, The (U)|3|0|0|0|0|0|21A4B=42D8
-8A46ED37|Lion King, The (E)|3|0|0|0|0|0|21A4B=42D8
-6AEF6D1E|Lodoss Tou Senki (J)|4|4040404|0|0|0|0|60030=EAEA,60060=EAEA,60074=EAEA,600A7=EAEA,60168=EAEA,6018A=EAEA,60328=EAEA,603CE=EAEA,603F2=EAEA,60476=EAEA,60487=EAEA,604A3=EAEA,605D4=EAEA,606B9=EAEA,606E5=EAEA,6077A=EAEA,607AD=EAEA,607C2=EAEA,CEDC6=EAEA,24B=4280,41E=42D9,46A=421B,484=42,4C0=42,40174=428E,413EA=42BA,6BEA9=DBFF,C3B58=421B
-6838BE08|Lost Vikings, The (U)|0|0|0|0|5|0|28D83=EAEA,28DF6=EAEA,28E09=EAEA
-5E1AA1A6|Lufia & The Fortress of Doom (U|4|440|0|0|0|0|E00=EAEA,800A=EAEA,A856=EAEA,E57=EAEA,E71=EAEA,ED5=EAEA,EF0=EAEA,1038=EAEA,109B=EAEA,10F5=EAEA,2581=42,852A=42DB,8089=42,BE5E=42DB,4FB3=42,91AF=42DB,9FD8=42DC,4191D=42
-20F2AC29|Lufia II - Rise of the Sinistra|0|0|0|0|0|0|86=EAEA,19010=42FC
-FDB80165|Lufia II - Rise of the Sinistra|6|0|0|0|0|0
-DDF832E8|Macross (J)|0|4000|0|0|0|0|E611=EAEA,E61C=EAEA
-A7D31544|Madden NFL '94 (E) [!]|3|0|0|0|0|0
-27325E4D|Magic Sword (U)|0|40000|0|0|0|0|4166=EAEA,4D8=42DB,44A4=42DB,4251=42DB,1E9=42DB,272=42DB,41E0=42DB,4B53=42DB,214=42DB
-D721EEE0|Marchen Adventure Cotton 100% (|0|0|0|0|0|0|B4C=42F8,4E8FB=42F7,4E93F=4270
-7BC22342|Mario & Wario (J) [h3] (Joypad)|0|0|7E00AB|0|1E|11
-E51A3FCD|Mario is Missing (U)|10000000|40C00|0|0|0|0|255=EAEA
-F64C5AA0|Mario no Super Picross (J)|14000005|40C00|0|0|0|0|E0209=EAEA,E0217=EAEA,E0259=EAEA,E0267=EAEA,E028E=EAEA,E029C=EAEA,E02B1=EAEA,E02BF=EAEA,E0480=EAEA,E0501=EAEA,F23A6=EAEA,91A=42D8,1A3C=42D8,4D9FF=DB
-AAD84250|Mario Paint (JU) [h1] (Joystick|4|4044|7E0227|0|1E|0|3964=EAEA,69AB=EAEA,937D=EAEA,DC1C=EAEA,DC4E=EAEA,DD5C=EAEA,DD78=EAEA,DD83=EAEA,DD88=EAEA,C0AB1=EAEA,E6EEE=EAEA,EEEEE=EAEA,D812=42D9,E0FC=42D8,E54D=42D8,EE0A=42D7,E2EF=42DA,D391=42DB
-480B043A|Mario's Early Years - Fun With|1|0|0|0|0|0
-8C0C37F4|Mario's Early Years - Fun With|1|0|0|0|0|0
-85A6B2A8|Mario's Early Years - Preschool|1|0|0|0|0|0
-5E7397E0|Mario's Time Machine (U)|0|0|0|0|0|0
-AC0F2C23|Marvel Super Heroes - War of th|3|0|0|0|0|0|30076=EAEA,300C0=EAEA
-C0ACC92D|Mechwarrior 3050 (U)|8000001|4800|0|0|0|0|166DBE=EAEA,166DEA=EAEA,166FBB=EAEA,166FE9=EAEA,166CE0=EAEA,7723=42DC,764D=42DC
-44A9DB5C|Mega lo Mania (E)|6|0|6E|0|32|28|2808B=EAEA,17B88=EAEA,280DB=EAEA,17B99=EAEA,17BA7=EAEA,EAE=4298,A8E=4296
-2D947536|Mega Man 7 (U)|4000001|40000|7|0|0|AB|AB=42FB
-DED53C64|Mega Man X|4000018|40000|BB0|B6|1E|0|A4=42,38161=EAEAEAEA
-6F98885D|Mega Man X (DarkCube IPS)|4000018|40000|BB0|B6|1E|0|A4=42,38161=EAEAEAEA
-D47EB040|Mega Man X 2 (E)|4000018|40000|BB0|B6|1E|0|A4=42,38161=EAEAEAEA
-FA0FE671|Mega Man X 3 (E)|4000018|40000|BB0|B6|1E|0|A4=42,38161=EAEAEAEA
-FA9EE2CE|Mega Man's Soccer (U)|0|0|0|0|0|0|C42=42DC
-68DD767A|Megaman Soccer|0|40C00|0|0|0|0
-A079C881|Metal Max Returns (J)|4|0|0|0|0|0|1B9=42F8
-0ADAA9DA|Metal Morph (U)|10000000|800|0|0|0|0|35E=EAEA,31D=EAEA,326=EAEA,332=EAEA,237=EAEA,33C=EAEA,48C9=42FB,2A21=42FB,C596=4298
-856B5F76|Michael Jordan - Chaos in the W|10000001|1000|0|0|0|0|2C749=EAEA,2C8CF=EAEA,19331=42FB,1518B=42DB
-08806B5B|Mickey Mania - The Timeless Adv|0|40004C00|0|0|0|0|109A13=EAEA,109A16=EAEA,1099A8=EAEA,10992B=EAEA,109970=EAEA,1099F8=EAEA,109A04=EAEA,109932=EAEA,10F13E=42FC,1F21F9=42FC,1F4DAE=42FC,1F34EE=42FC,1F0197=42FC,1EDD41=42FB,1F4218=42FC,1DDAF0=42FC,1D5118=42FC,1F8002=42FC,1FD017=42FC,1F6C10=42,1E1847=42,10DA1F=42,1E7544=42,1F71F0=42,1FAB96=42DA,1D57B0=42,1D5242=42,1F632C=42,1D5336=42,1D542A=42,10D6F3=42,10D71D=42,1F7A8E=42,F4B4F=42,1D556A=42,1DC89C=42,1F47F6=42,1E9042=42,1DFC46=42,F53A7=42,1F65FB=42,1F80E8=42,10DC12=42,10D908=42,1D56D3=42,1E6288=DB6E,1F503B=42,1F2773=42,1F20AE=42,1F136F=42
-10874C70|Mickey Mouse - Magical Quest|4000018|0|17F2|1AF5|1E|0|BC89=DBE2
-364E68BB|Micro Machines (U)|0|0|0|0|0|0|F725=EAEA,6801C=EAEA,F76C=EAEA
-1619B619|Micro Machines 2 - Turbo Tourna|2|0|0|0|0|0
-A56EB77A|Mighty Morphin Power Rangers (U|0|0|0|0|0|0|5604=EAEA,38E=42FC
-E3EF6201|Mighty Morphin Power rangers -|0|0|0|0|0|0|668D=EAEA,2D8=42F9
-460B0A60|Mighty Morphin Power Rangers -|0|0|0|0|0|0|4090=EAEA,40B6=EAEA,1415BC=EAEA,1415D4=EAEA,1415DF=EAEA,1415E4=EAEA,141612=EAEA,141637=EAEA,1416DF=EAEA,1417C3=EAEA,141801=EAEA,AD=42
-67B5FB22|Milandra (J)|4|4000|0|0|0|0|8007E=EAEA,800C8=EAEA,80DC=42FB,6E30=42FA,6E4B=42FA,819D=42D4,2D6=4219
-DEF42945|Mortal Kombat (U)|0|0|0|0|0|0|C20F4=EAEA,2687=EAEA,C2ADD=42FC
-4E6AF725|Mortal Kombat 3 (U)|1|0|0|0|0|0
-1C3D3B72|Mortal Kombat II (V1.0) (U)|1|0|0|0|0|0|872A=421B,FED1=42B9,3B866=42BA,3F1A0=421A,94820=DB,EF4B7=42BB,FE55D=429D,127E41=4293,12D02F=427F,13B7D4=4270,22BAC2=4288,48029=EAEA,48052=EAEA,48081=EAEA,480F0=EAEA,4810B=EAEA,48124=EAEA,4818B=EAEA,48196=EAEA,4819B=EAEA,481C3=EAEA,481C9=EAEA,48249=EAEA,4852A=EAEA,48541=EAEA,48570=EAEA,4857F=EAEA,485AC=EAEA,A367B=EAEA,A6E89=EAEA,27D7C2=EAEA,2D1294=EAEA
-70BB5513|Mortal Kombat II (V1.1) (U)|1|0|0|0|0|0|86EA=EAEA,4FD5A=EAEA,5DE20=EAEA,5DE1F=EAEA,5DE21=EAEA,5DE22=EAEA,5DE23=EAEA,5DE25=EAEA,5DE27=EAEA,5DE28=EAEA,5DE2A=EAEA
-1C1025E2|Mr. Do! (U)|4000000|40000|0|0|0|0|301FB=EAEA,30244=EAEA,3026F=EAEA,30288=EAEA,3041E=EAEA,3044C=EAEA,30457=EAEA,3045C=EAEA,304C2=EAEA,304D7=EAEA,304EB=EAEA,718=42BA
-74D210D3|Ms. Pac-Man|0|0|0|0|0|0|185D5=EAEA,1873D=EAEA,18763=EAEA,1876E=EAEA,18773=EAEA,187A2=EAEA,187AA=EAEA,18822=EAEA,18837=EAEA,1884D=EAEA,1888F=EAEA,1889D=EAEA,188A5=EAEA,188F9=EAEA,1890E=EAEA,18924=EAEA,18966=EAEA,18974=EAEA,1897C=EAEA,18996=EAEA,189D7=EAEA,18A03=EAEA,18A1B=EAEA,18A28=EAEA,18A3B=EAEA,18A7D=EAEA,18A95=EAEA,18A9C=EAEA,18B24=EAEA,18B29=EAEA,18B37=EAEA,18B3C=EAEA,18B49=EAEA,18C02=EAEA,18C2C=EAEA,18C3A=EAEA,18C58=EAEA,18C7A=EAEA
-0E984752|Mujintou Monogatari (J)|4|400800|0|0|0|0|209=423C
-011907A4|Musya (U)|0|0|0|0|0|0|54AC=421B,54C8=421B
-1DE544EB|Mystic Ark - 7th Saga 2 (J) [T-|5|4000|0|0|0|0|C04EA=EAEA,C04F0=EAEA,C0503=EAEA,C0507=EAEA,F252=42FA
-68C8B643|NBA Give N Go (U)|0|0|0|0|0|0|2916=EAEA,2A76=EAEA
-262CE76B|NBA Hang Time (U)|5|0|0|0|0|0|5C32F=EAEA,5C358=EAEA,5C3D2=EAEA,5C555=EAEA,5C527=EAEA
-43F1C013|NBA Jam (U)|0|0|0|0|0|0
-1FBC1DDB|NBA Jam Tournament Edition (U)|4|0|0|0|0|0|4F2D5=EAEA
-5115B8E5|NBA Live '97 (U)|4|40C00|0|0|0|0
-514BFCB5|NBA Live '98 (U)|4|40C00|0|0|0|0
-42212A77|NHL '94|0|840400|0|0|0|0|FF4B7=42F1,58A=42FB,E19C8=EAEA,F870A=9BDB
-233FEC8C|Nickelodeon GUTS|0|0|0|0|0|0
-066FE797|Ninja Gaiden Trilogy (U)|0|0|0|0|0|0|2B02=EAEA,29A2=EAEA,4314D=42D7,CA=4284,5B2=4219,1BA=42D1
-5995CF46|Ninja Ryuukenden Tomoe (J)|0|84000000|0|0|0|0|5B2=4219,4B=42DA
-3BC037B6|Ninja Warriors Again, The (J)|0|0|0|0|0|0|240=EAEA,4803=EAEA,C6=42D9,4705=EAEA
-733764D7|Ninja Warriors, The (E)|2|0|0|0|0|0
-7537D8D7|Ninja Warriors, The (U)|0|0|0|0|0|0|240=EAEA,4742=EAEA,475A=EAEA,4765=EAEA,476A=EAEA,4798=EAEA,47E7=EAEA,47FA=EAEA,4863=EAEA,C6=42D9
-ACFDB7B8|Ogre Battle (U)|10000004|44444444|0|0|5|0|2AA9E=EAEA,2AB0B=EAEA,3E78E=EAEA,42D25=EAEA,60050=EAEA,60057=EAEA,600DE=EAEA,600F6=EAEA,60101=EAEA,60106=EAEA,60138=EAEA,60144=EAEA,60166=EAEA,6019C=EAEA,6727D=EAEA
-5F40A869|Out of This World|0|0|0|0|0|0|658D=EAEA,65A0=EAEA,65B7=EAEA,65CC=EAEA,65D4=EAEA,65E1=EAEA,65E6=EAEA,65FB=EAEA,6605=EAEA,6617=EAEA,662A=EAEA,66B5=EAEA,66C5=EAEA,1D997=4251,234C9=DB6D
-191B1A19|Pac-Attack|10000000|44C00|0|0|0|0
-44375368|Pac-In-Time|0|0|0|0|0|0
-9FC62BCC|Pac-Man 2 - The New Adventures|10000000|44C00|0|0|0|0|8297=EAEA,829E=EAEA,82A8=EAEA,82BE=EAEA,82CE=EAEA,82E5=EAEA,832B=EAEA,836B=EAEA,83D3=EAEA,83F5=EAEA,8400=EAEA,8405=EAEA,915D=EAEA,9166=EAEA,917C=EAEA,9190=EAEA,91B1=EAEA,A43D=EAEA,B379=EAEA,13E96=EAEA,1B670=EAEA,1EE81=EAEA,1EEB5=EAEA,1EEBF=EAEA,1EED7=EAEA,1EEDC=EAEA,1EEE6=EAEA,1EEFE=EAEA,1EF03=EAEA,1EF0D=EAEA,142284=EAEA,176F79=EAEA
-26C38EEE|Pagemaster, The|0|40C00|0|0|0|0|F80B8=EAEA,F8135=EAEA,F81E0=EAEA,F824B=EAEA,F8270=EAEA,F8295=EAEA,F82C1=EAEA,F82C6=EAEA,F82EC=EAEA,F82F1=EAEA,F8325=EAEA,F8345=EAEA,F834A=EAEA,F8375=EAEA,F83A8=EAEA,F83FB=EAEA,F8425=EAEA,F8450=EAEA,F8464=EAEA,F848F=EAEA,F849A=EAEA,F849F=EAEA,1CFF87=EAEA,1CFFA0=EAEA
-14D70786|Panel de Pon (J)|0|0|0|0|0|0|1180=EAEA,1185=EAEA,11CB=EAEA,11D0=EAEA,125A=EAEA,125F=EAEA,11E1=EAEA,11DC=EAEA,1275=EAEA,127A=EAEA
-C85AA66A|Paper Boy 2 (U)|0|0|0|0|0|0|6552=EAEA,1731=42D9,6978=42D8
-876DFD97|Parodius Da!|4000000|840000|B8C|0|1E|5|11A=4280
-6FFA308C|Parodius Non-Sense Fantasy (E)|2|0|0|0|0|0
-8071E5DB|Peace Keepers (U)|1|0|0|0|0|0|DCD2=EAEA,807B=EAEA,80EE=DBEB
-DC90A8AB|Phalanx (U)|0|0|0|0|0|0
-561AEB8F|Phalanx - The Enforce Fighter |0|4040|0|0|0|0|11D=EAEA,FEBD9=42FB,348=42DB
-DEF45776|Pilotwings (E)|2|0|0|0|0|0|31F5=EAEA,38D8=EAEA,52B6=EAEA,579D=EAEA,57D2=EAEA,58A0=EAEA,6176=EAEA,6576=EAEA,65B2=EAEA,65CA=EAEA,72A7=EAEA,72BD=EAEA,72C8=EAEA,72CD=EAEA,A76A=EAEA,BD06=EAEA,CE61=EAEA,CFEF=EAEA,716F=4217,728D=42D4
-81107CE2|Pinball Dreams (U)|10000000|0|0|0|0|0|56EB=EAEA,575B=EAEA,578A=EAEA,57AE=EAEA,5685=42DB,1320=42FB,13A5=42FB,3237=42FB,D34=42,953=42B9,1C74=42FA,1E94=42D8
-822AD378|Pinball Fantasies (U)|0|0|0|0|0|0|B0339=EAEA,B0486=EAEA,B0492=EAEA,B0384=EAEA,B0390=EAEA,B03A9=EAEA,B03B5=EAEA,1458=42FB,14DD=42FB,3D8D=42FB
-AF2A3DFE|Pipe Dream (J)|0|40800|0|0|0|F|103B8=42FB,164=42F9,F74=42
-7CA0CA4D|Pirates of Dark Water (U)|0|0|0|0|0|0|297D=42FC
-2B0E7EA3|Pocky & Rocky (U) [!]|0|0|0|0|0|0|5252=EAEA,2299=EAEA,2421=EAEA,1CA=42DB
-892C6765|Pokemon (PD)|4000000|900000|0|0|0|0|4326=EAEA,4353=EAEA,436B=EAEA,4376=EAEA,437B=EAEA,43A9=EAEA,43BA=EAEA,FA3=42,22BA=42D8,1BE60F=DB
-D16810CD|Poko Nyan! - Henpokorin Adventu|0|44000|0|0|0|0|69A4=428E
-EE13E32D|Pop 'N' Twinbee (J)|10000000|840000|0|0|0|0|118=4280
-2DF4AA0F|Populous (U)|0|40C00|0|0|0|0|390D=4280,14F0E=429C,181A8=DB,1F450=DB
-0A0235C0|Populous 2 (J)|0|4040|0|0|0|0
-CB4F87BB|Prehistorik Man (U)|10000000|4F0000|0|0|0|0|1FA18=EAEA,1FA61=EAEA,48314=EAEA,7F68=42FC,4D4=EAEA,181E3=EAEA,1F9CA=EAEA,1F9E2=EAEA,1F9F3=EAEA,1FA0E=EAEA,1FA35=EAEA,1FC6C=EAEA,1FC71=EAEA,1FCA8=EAEA,333E8=EAEA,496E7=EAEA
-320562C3|Prince of Persia (E)|2|0|0|0|0|0
-891BB2BB|Prince of Persia (U)|0|0|0|0|0|0|118C2=EAEA,118D3=EAEA,118DF=EAEA,1190B=EAEA,11999=EAEA,11921=EAEA,1A2C1=42DB,1A2CD=4299
-96BD588B|Puzzle Bobble (J)|0|40C00|0|0|0|0
-694CBFE4|Q-bert 3 (U)|0|0|0|0|0|0|7E56=EAEA,6822=42FC
-642B656B|R-Type 3|0|0|0|0|0|0|7F37=428E,1DE49E=421B
-583FDBFF|Radical Dreamers (SNES) (J) [T+|5|0|0|0|0|0|20F21=EAEA,CFE58=EAEA,CFE5F=EAEA,CFE7D=EAEA,CFEB0=EAEA,CFEE0=EAEA,CFEFB=EAEA,CFF08=EAEA,D0054=EAEA,D0084=EAEA,D00C9=EAEA,D023F=EAEA,D028D=EAEA,D03DB=EAEA,D03FA=EAEA,D040C=EAEA,D0416=EAEA,D0445=EAEA,D0467=EAEA,D050C=EAEA,D0563=EAEA,D05AF=EAEA,D05CB=EAEA,D05D2=EAEA,D05E2=EAEA,D0664=EAEA,D067B=EAEA,D09C2=EAEA,9E41=421A,A1AB=421A,A1BE=421A,A1EA=421A,A1FF=421A,B85B=42BA,F8050=42
-C352D27F|Raiden Densetsu (J) [!]|18000000|0|0|0|0|0|E29=42,E34=42FC,E3A=429A
-02CE6C96|Raiden Trad|18000000|0|0|0|0|0|E29=42,E3A=429A
-9C79C3B8|Ranma RPG - Anime [T+Eng1.00]|4|0|0|0|0|0|456B=42DB
-053B2615|Ranma ½ Bun no 1 - Bakuretsu Ra|1|0|0|0|0|0|FFA0=EAEA,4B1=42FB
-0C552B1F|Ranma ½ Bun no 1 - Chogi Ranbu|1|0|0|0|0|0|32F=42DB,40640=42FB,48AF2=DB03,45E5B=DB91
-9BE46820|Realm (E) [!]|2|0|0|0|0|0|85EF=EAEA,F8263=EAEA,F82AF=EAEA,F82D5=EAEA,85E1=42FC,958=42FC,228=42FC
-C2413BDD|Rejoice - Aretha Oukoku no Kana|4|44800|0|0|0|0|A5831=EAEA,A55F3=EAEA,A55FB=EAEA,A5838=EAEA,A583C=EAEA,A5845=EAEA,A5849=EAEA,A582D=42DA,2D516=42DB,2DAE1=42DB,2D687=42DB,95F6=42DB,226=42DB,4F7=42DB,7C86=42DB,6E74=42DB,72A5=42DB,1425B=42DB,16DF=42DB,9252=42DB,CEFE=42DB,CEB5=42DB,6D06=42DB,AFB6=42DB,92BC=42DB
-CA988F59|Rival Turf (U)|0|0|0|0|0|0|272=EAEA,A6E=EAEA,1A3B=EAEA,1A9F=EAEA,1BB3=EAEA,1BB9=EAEA,632F=EAEA,6343=EAEA,635B=EAEA,6368=EAEA,643A=EAEA,6432=EAEA,6441=EAEA,6456=EAEA,C435=EAEA,11B16=EAEA,F1444=EAEA
-BB2B8E2E|Road Runner (E)|2|0|0|0|0|0|7DD3=EAEA,7DEB=EAEA,7DF6=EAEA,7DFB=EAEA,7E88=EAEA,7E8E=EAEA,28902=EAEA,2A605=EAEA,381FD=EAEA,9FE7E=EAEA,9FE84=EAEA,163B=DB
-F5AB5D91|Robocop Versus The Terminator |14000000|4040|0|0|0|0|94E=42DB,6D=42DB,AE=42DB,141E=EAEA,5FF5=42D9
-7AD4AADC|Robotrek (U)|5|0|0|0|0|0|4800D=421A
-7D06F473|Rock N' Roll Racing (U)|0|0|0|0|0|0|7994=EAEA,AD8F=EAEA,F617=EAEA,3D10=4284
-0ECDC493|Rockman & Forte (J) [T+Eng1.00-|4000001|40000|7|0|0|0|D=42FB
-2DCD95B9|Rockman 7 - Syukumei no Taikets|0|0|0|0|0|0
-F0ECDD92|Roger Clemens' MVP Baseball (U)|0|44808|0|0|0|0|A2E5D=42,A2E68=42,A5F0C=42DA,9=42,A39CB=42DB,683E=42
-8033574A|Romance of the Three Kingdoms I|4|0|0|0|0|0|12C1=EAEA,3115=EAEA,19F3=42DB
-9684526D|Romancing Saga (V1.1) (J)|8000004|84848484|0|0|0|0|20068=EAEA,20098=EAEA,200AC=EAEA,200DF=EAEA,201C3=EAEA,201CB=EAEA,201E1=EAEA,20248=EAEA,202F0=EAEA,20319=EAEA,20330=EAEA,20385=EAEA,2039D=EAEA,2043C=EAEA,204EA=EAEA,2055C=EAEA,20564=EAEA,20589=EAEA,2058F=EAEA,205A9=EAEA,2D4=42D9,962=DB,13D34=4280,CEFBF=4258
-54A585BC|Romancing Saga 2 (J)|5|0|0|0|0|0|370B=EAEA,556F=EAEA,5581=EAEA,321E5=EAEA,4004A=EAEA,4006A=EAEA,40081=EAEA,4008C=EAEA,40095=EAEA,400E6=EAEA,40116=EAEA,4012D=EAEA,4013A=EAEA,40232=EAEA,4023A=EAEA,40257=EAEA,403DA=EAEA,40403=EAEA,40419=EAEA,40501=EAEA,40593=EAEA,405E1=EAEA,40613=EAEA,40619=EAEA,40666=EAEA,4067F=EAEA,406EB=EAEA,40719=EAEA,4072E=EAEA,40779=EAEA,407A7=EAEA,407BC=EAEA,407EA=EAEA,407FF=EAEA,4082D=EAEA,40840=EAEA,4084C=EAEA,14315C=EAEA,32F=4296,572=4210,69A=42D9,3981=42B0,E76B=42D9,204AF=42D9,30176=4280,3AEA7=42DD,3B0CB=42DD,3B3D2=42DD,3DF0A=DB,3E2E3=DB,3E91F=4280,568B5=DB
-5399BDDB|Romancing SaGa 3 (J) (V1.0)|5|4800|0|0|0|0|6063D=EAEA,60643=EAEA,609B0=EAEA,670=42DC,3EC170=42FA,1C42A=42D9,5F957=42FC
-42C664C2|Romancing Saga 3 (V1|5|40444444|0|0|0|0|6063D=EAEA,60643=EAEA,609B0=EAEA,670=42DC,3EC170=42FA,1C42A=42D9,5F957=42FC
-E0BD6C71|RPG Tukool - Super Dante|4|0|0|0|0|0|00C1=EAEA,B74C=EAEA,B757=EAEA,B762=EAEA,B761=EAEA,B74B=EAEA
-E20870EE|RPG Tukool - Super Dante (J)|4|0|0|0|0|0
-5D8CB7AC|Rudra no Hihou (J)|5|0|0|0|0|0|23A5=EAEA,4AA=42FC
-244280AE|Rudra no Hihou (J) [T+Eng|2|0|0|0|0|0|130906=EAEA,26187A=EAEA,2B0022=EAEA,2B00A5=EAEA,2B00C9=EAEA,2B031C=EAEA,2B033E=EAEA,2B0357=EAEA,2B0457=EAEA,2B094B=EAEA,2B0954=EAEA,2B095F=EAEA,2DC5B6=EAEA,4AA=42FC
-8708E5BB|Run Saber (U)|0|0|0|0|0|0|525=421B,9AB=4290
-454D7DCD|Ryuuki Heidan Danzalv (J)|5|44800|0|0|0|0|F8335=42FB,F8345=421B,F73FE=421B,F8340=423B,F8DDA=42DB,88D3A=4215,8C04F=42FC
-CD89020D|Sailor Moon (F)|3|0|0|0|0|0|1B7F8=42FC,1BE5A=42CF,936E=42FC
-2E614A53|Samurai Shodown (U)|1|4040|0|0|0|0|10B4=42
-4C78D5EE|Sangokushi - Eiketsu Den (J)|5|4000|0|0|0|0|2C0BB0=EAEA,898D=42DC,1E29=42DB,850E=42DC,1E8F=42DB,87A4=42DC,8544=42DC,1D8C=42DC
-98D7611E|Scooby Doo (U)|0|C00|0|0|0|0|DDF0D=EAEA,1017D6=EAEA,114DD0=EAEA,114DF2=EAEA,114DFD=EAEA,114E02=EAEA,114FE5=EAEA,114FF4=EAEA,115007=EAEA,115041=EAEA,11506F=EAEA,115077=EAEA,115097=EAEA,1150A2=EAEA,1B5B14=EAEA,1C988F=EAEA,C39=42DB,1A6874=4211
-8BFCB5A3|SD Gundam X (J)|4|44000|0|0|0|0|454F=EAEA,16E91=EAEA,16ECC=EAEA,16EDD=EAEA,16EEB=EAEA,16EF0=EAEA,16F1E=EAEA,2C5F1=EAEA,4D024=EAEA,975E1=EAEA,AE344=4219
-AAE842D2|SD The Great Battle (J)|1230000|0|0|0|0|0|181=EAEA,6A9C=DB6A
-A5C0045E|Secret of Evermore (U)|14000005|0|0|0|0|0
-D0176B24|Secret of Mana (U)|5|4000|7E0604|0|64|A|79773=EAEA,B07B=42DC,694D=421B
-EF968ED1|Secret of the Stars (U)|1320004|0|0|0|0|0|417=421B
-A638BEF1|Seifuku Densetsu Pretty Fighter|1|0|0|0|0|0
-15320173|Seijuu Maden - Beasts & Blades|5|4040|0|0|0|0|800E2=EAEA,801A1=EAEA,30013=EAEA,183C3=42FB,30135=42DC,30118=42DC,30009=42D8
-D0AEA27C|Seijuu Maden - Beasts & Blades|5|4040|0|0|0|0|800E2=EAEA,801A1=EAEA,30013=EAEA,183C3=42FB,30135=42DC,30118=42DC,30009=42D8
-FE1389B5|Seijuu Maden - Beasts & Blades|5|4040|0|0|0|0|800E2=EAEA,801A1=EAEA,30013=EAEA,183C3=42FB,30135=42DC,30118=42DC,30009=42D8
-BEA407DC|Seijuu Maden - Beasts & Blades|5|0|0|0|0|0
-863ED0B8|Seiken Densetsu 3 (J)|5|0|0|0|0|0|5008A=EAEA,3D8350=42FC,3D84D2=421A,3D837E=42FC,4A22=42D2,3D8306=80,340B=4290,33E2=42F8
-7DBDE871|Seiken Densetsu 3 (J) (e101|5|40000|0|0|0|0|5008A=EAEA,3D8350=42FC,3D84D2=421A,3D837E=42FC,4A22=42D2,3D8306=80,340B=4290,33E2=42F8
-B1D82240|SF96soe|4|0|0|0|0|0|337=EAEA,35D=EAEA,365=EAEA,3D6=EAEA,3ED=EAEA,404=EAEA,57A=EAEA,5A3=EAEA,5C9=EAEA,607=EAEA,61E=EAEA,635=EAEA,7A9=EAEA,7D2=EAEA,7F8=EAEA,1D53=EAEA,1E4C=EAEA,1E74=EAEA,1ED1=EAEA,1EFD=EAEA,1F31=EAEA,202B=EAEA,20C0=EAEA,23F574=EAEA,2BA616=EAEA,32FC20=EAEA,4847E4=EAEA,6004FC=EAEA,60050C=EAEA,600524=EAEA,60052F=EAEA,600534=EAEA,600572=EAEA,60080F=EAEA,600858=EAEA,6042FC=EAEA,6044CB=EAEA,6044FC=EAEA,604B46=EAEA,604B6C=EAEA,604C98=EAEA,6050E0=EAEA,605106=EAEA,605112=EAEA,605131=EAEA,605168=EAEA,6051D3=EAEA,6051F9=EAEA,60528A=EAEA,6052B6=EAEA,6CFAAD=EAEA,7AE950=EAEA,7D84EF=EAEA,8038FE=EAEA,834595=EAEA,8A3975=EAEA,8B62E4=EAEA,8F04BD=EAEA,A00337=EAEA,A0035D=EAEA,A00365=EAEA,A003D6=EAEA,A003ED=EAEA,A00404=EAEA,A0057A=EAEA,A005A3=EAEA,A005C9=EAEA,A00607=EAEA,A0061E=EAEA,A00635=EAEA,A007A9=EAEA,A007D2=EAEA,A007F8=EAEA,A01D53=EAEA,A01E4C=EAEA,A01E74=EAEA,A01ED1=EAEA,A01EFD=EAEA,A01F31=EAEA,A0202B=EAEA,A020C0=EAEA,A61D40=EAEA,A9A0AD=EAEA,B1838F=EAEA,BB1907=EAEA,18B=421B,2DB=42DB,76E6=42D9,7702=4280,7E98=42D6,204A1D=42D1,218A6F=42,2211F6=42,2315F6=DB,24D6A7=42D3,24E908=DB,268D19=42,2A157A=42,2BA92D=4230,2BEC66=42,2C0543=42D2,2E4B9D=42,2F166E=421F,2FAE82=DBFB,4C5627=42B8,600065=42D9,6004A1=423B,6004A6=421B,615B3C=423B,615B41=421B,647412=423B,647417=421B,647428=423B,64742D=421B,6E44D4=DBF6,6E4507=DBF7,6E45D1=DBF6,6E460C=42,7B1A92=DB,7BDF2E=427F,7D9F44=DB,816505=DB,829ACC=DB,83C95D=421D,8478B7=DBFA,859D22=4231,A0018B=421B,A002DB=42DB,A076E6=42D9,A07702=4280,A07E98=42D6,A10B55=423A,A10B5B=421A,A10B85=423B,A10B8A=421B,A11231=42D9,A17DFA=423B,A17DFF=421B,A318D4=423B,A318D9=421B,A56D16=423B,A56D1B=421B,A56D67=42D9,A6053B=423B,A60540=421B,A60551=423B,A60556=421B,A7B388=DB,AF4AB4=DB,B8F4EF=42BE,BA988C=421E
-36894CC3|Shadow, The (U)|0|40800|0|0|0|0|714D=EAEA,7174=EAEA,717E=EAEA,71A5=EAEA,128999=EAEA,1289C0=EAEA,1F85E2=EAEA,1F8609=EAEA,1F831F=EAEA,12803C=EAEA,128063=EAEA,12806D=EAEA,128094=EAEA,1F8355=EAEA,1F837C=EAEA,1F8386=EAEA,1F83AD=EAEA,1F8290=EAEA,1F82B7=EAEA,1F8346=EAEA,1F8663=EAEA,1F80B8=EAEA,7222=EAEA,7249=EAEA,7253=EAEA,727A=EAEA,12A104=EAEA,12A12B=EAEA,12A135=EAEA,12A15C=EAEA,1F868A=EAEA,12A40D=EAEA,12A434=EAEA,12A43E=EAEA,1F83FA=EAEA,12A465=EAEA,1F8421=EAEA,1F825E=EAEA,1F8285=EAEA,10055=42FB
-85D4CDA1|Shadowrun (U)(17759)|4|0|0|0|0|0|E16B=EAEA,E4C5=EAEA,B065=42,EE67=42
-3F34DFF0|Shadowrun (U)(63540)|4|4040|0|0|0|0|E17C=EAEA,E4D6=EAEA,B065=42,EE92=42
-4C2BEA69|Shiki Eiyuuden - Jinryuu Denset|4|400C09|0|0|0|0|7094D=EAEA,70756=EAEA,E80EE=42FA,30542=42FA,188AE=42FA,73D7=42FA,28622=42FA,1866E=42DC,408B4=42D4,47355=42FA,18567=42D5,21554=42D4,2127A=42D3
-C0AECDCA|Shin Kidoesenki Gundam Wing - E|0|0|0|0|0|0|38211=EAEA,38133=EAEA,B9=42F9
-67E1756B|Silva Saga II - The Legend of L|4|0|0|0|0|0|2CD=42FB,6029C=42D9
-9D5FEB20|Sim Ant (U)(49046)|4|0|0|0|0|0|781=42FC,10061=4299
-A39FD8D8|Sim City (J)|10000004|40000|0|0|0|0|12DE=42FA
-8AEDD3A1|Sim City (U)|10000004|40000|7E01ED|0|19|8|1315=42FA
-7FA5B218|Sim Earth (U)|4|0|0|0|0|0|17BB8=EAEA
-ED1C03C2|Simpsons, The - Bart's Nightmar|0|0|0|0|0|0|ABCC6=42FC
-AC5116D9|Simpsons, The - Krusty's Super|0|0|0|0|0|0|2DAA=42FA
-1594A363|Sky Blazer (U)(12134)|10000008|F40|7EF101|7EF141|1E|5|1BF9=42F7,746=42F5
-D05114C0|Slam Dunk - SD Heat Up!!|0|0|0|0|0|0|3C58=EAEA,3BCA=EAEA,162=428E,3F4C=EAEA
-2D0B20D0|Smash TV|18000000|40000|B|0|1E|0|521=42DB,74A1A=42
-D68D1AB3|Snow White in Happily Ever Afte|0|0|0|0|0|0
-2A9966C0|Soccer Kid (E)|2|0|0|0|0|0|7BBC=42D9,E4437=DB
-E1701707|Soldiers of Fortune (U)|0|0|0|0|0|0|A1318=EAEA,BDDB6=EAEA,D01A6=EAEA,D0201=EAEA,2F50=423C,C42A1=42,C42A9=42D8,C42BE=42,C42C6=42D8,C42E3=42,C42EB=42D8,C4630=42,C4639=42D7,C4650=42,C4659=42D7,D07E9=42,D07F2=42D7,D0818=42,D0821=42D7,D8815=42,D881E=42D7,D8835=42,D883E=42D7,D885F=42,D8868=42D7,127F56=42,127F5E=42D8,1481AB=42,1481B4=42D7,1486E3=42,1486EC=42D7,148721=42,14872A=42D7,14877F=42,148788=42D7,1489AE=DB
-B907BB27|Solid Runner (J)|4|4800|0|0|0|0|40053=EAEA,5C89=EAEA,40055=EAEA,402C6=EAEA,9A=42F9
-24229A34|Sonic Blastman 2 (U)|1|0|0|0|0|0|9023=EAEA,3F9=42DF,814B=EAEA,8161=EAEA
-80E548A2|Sonic the Hedgehog (Hack)|0|0|0|7E008F|1E|5|B03E1=EAEA,4456=42DC,2D2=42DC
-CFE75BCB|Sonic Wings (J)|4000000|4000|0|0|0|0|544=42DA,3F1=42DB,265=42FB,1EBDD=4285
-5FE69828|Soul & Sword (J)|4|0|0|0|0|0
-31B965DB|Soul Blazer (U)|4|0|0|0|0|0|131C1=421B
-5ABFBE21|Space Funky B.O.B. (J)|0|0|0|0|0|0|24C=42FB
-11202781|Space Megaforce (U)|0|44040|0|0|0|0|146C=EAEA,148B=EAEA,14E3=EAEA,14B5=EAEA,123=42FC,B6C=42FC,417=42FC
-40D11C94|Sparkster (U)|0|0|0|0|0|0|4598=EAEA,45B9=EAEA,45F3=EAEA,4666=EAEA,4686=EAEA,46CB=EAEA,46EE=80,4737=80,473F=EAEA,474D=EAEA,4765=EAEA,4781=EAEA,4790=EAEA,47A2=EAEA,47B1=EAEA,47C1=EAEA,47CC=EAEA,4840=EAEA,488A=EAEA,48A1=EAEA,48AD=EAEA,6E9B=4211,4844=EAEA
-4E1DAFD0|Spawn (U)|1|0|0|0|0|0|C045E=EAEA,C04DF=EAEA,D35D6=EAEA,DE3F1=EAEA
-CB0653D0|Speedy Gonzales (V1.1) (U)|0|0|0|0|0|0
-3DAEA8A1|Spell Craft (U)|0|4040|0|0|0|0|4303=EAEA,53B46=EAEA,CE8A9=EAEA,3BE5=42D9,74D5=42,E92A7=429D
-7EF2BB0C|Spider-Man - Maximum Carnage (U|0|0|0|0|0|0|10AAF=EAEA,12D4B=42F5
-919C509D|Spider-Man - Separation Anxiety|0|0|0|0|0|0|1399B=42F5
-3F83F67C|Spriggan Powered (J)|8000000|4000|0|0|0|0|8F1=42FB
-8FC4E6D0|Star Fox (V1.2) (U)|0|0|0|0|0|0|15965=42DC,15A3E=42FB
-89D0F7DC|Star Kirby Super Deluxe|4|0|0|0|0|0|4D2F=EAEA,4D49=EAEA,4D66=EAEA,4DB1=EAEA,4DC6=EAEA,4E3E=EAEA,4E53=EAEA,4E98=EAEA,4FD8=EAEA,4FE0=EAEA,501E=EAEA,5027=EAEA,53B9=EAEA,53C4=EAEA,53E7=EAEA,53FD=EAEA,540B=EAEA,541B=EAEA,5425=EAEA,542D=EAEA,5458=EAEA,5463=EAEA,5468=EAEA,549A=EAEA,36E258=EAEA,3A007B=EAEA,4B93=42D9,18AD47=4218,1E228D=421D,2CDC70=428F,377365=4214
-6BA9E08D|Star Ocean (English Translation|4|0|0|0|0|0|137=EAEA,15D=EAEA,165=EAEA,1D6=EAEA,1ED=EAEA,204=EAEA,37A=EAEA,3A3=EAEA,3C9=EAEA,407=EAEA,41E=EAEA,435=EAEA,5A9=EAEA,5D2=EAEA,5F8=EAEA,1B53=EAEA,1C4C=EAEA,1C74=EAEA,1CD1=EAEA,1CFD=EAEA,1D31=EAEA,1E2B=EAEA,1EC0=EAEA,82FC=EAEA,830C=EAEA,8324=EAEA,832F=EAEA,8334=EAEA,8372=EAEA,860F=EAEA,8658=EAEA,C0FC=EAEA,C2CB=EAEA,C2FC=EAEA,C946=EAEA,C96C=EAEA,CA98=EAEA,CEE0=EAEA,CF06=EAEA,CF12=EAEA,CF31=EAEA,CF68=EAEA,CFD3=EAEA,CFF9=EAEA,D08A=EAEA,D0B6=EAEA,C1B40=EAEA,131EAD=EAEA,19F8AD=EAEA,23018F=EAEA,35E750=EAEA,361707=EAEA,3B82EF=EAEA,4036FE=EAEA,464395=EAEA,47F374=EAEA,543775=EAEA,5660E4=EAEA,57A416=EAEA,5E02BD=EAEA,DB=42DB,74E6=42D9,7502=4280,7C98=42D6,7E65=42D9,82A1=423B,82A6=421B,20955=423A,2095B=421A,20985=423B,2098A=421B,21031=42D9,27BFA=423B,27BFF=421B,2D93C=423B,2D941=421B,616D4=423B,616D9=421B,8F212=423B,8F217=421B,8F228=423B,8F22D=421B,A6B16=423B,A6B1B=421B,A6B67=42D9,C033B=423B,C0340=421B,C0351=423B,C0356=421B,F3188=DB,1CC2D4=DBF6,1CC307=DBF7,1CC3D1=DBF6,1CC40C=42,1E48B4=DB,3172EF=42BE,35168C=421E,369892=DB,37DD2E=427F,3B9D44=DB,40C81D=42D1,426305=DB,43886F=42,448FF6=42,4518CC=DB,4693F6=DB,47475D=421D,4876B7=DBFA,49D4A7=42D3,49E708=DB,4B1B22=4231,4D8B19=42,54937A=42,57A72D=4230,57EA66=42,588343=42D2,5CC99D=42,5E946E=421F,5FAC82=DBFB
-3DBDFDBF|Star Ocean (J)|4|0|0|0|0|0
-75BFF780|Star Trek - Deep Space Nine - C|2|0|0|0|0|0|C549C=EAEA,FE61=42DC
-2DB38D24|Star Trek Starfleet Academy|0|44000|0|0|0|0|38EB4=EAEA,100D9=4234,10B90=42D8
-BC3DCD9D|Street Fighter II - The World W|14000000|40C00|0|0|0|0|FB=42
-A45CADD6|Street Fighter II Turbo (U)|1320001|0|0|0|0|0|D8=42FB
-7455A7CF|Street Fighter Zero 2 (J)|0|0|0|0|0|0
-52ADA404|Sunset Riders (US)|8000000|4000|0|0|0|0|C2C=EAEA,C39=EAEA,1923=423B,1998=42D7,CEC=42D9
-9A8618D6|Super Adventure Island (E)|2|0|0|0|0|0
-DCD46848|Super Adventure Island (U)|0|0|0|0|0|0|8C=42F7
-5615D5ED|Super BC Kid (E)|3|0|0|0|0|0|C6E1=42DC
-63A8E2C6|Super Bomberman|1|0|0|0|0|0
-3BBAEB19|Super Bomberman 4 (J)|1|0|0|0|0|0|2A6=EAEA,2AA=EAEA,2B2=EAEA,32B=EAEA,34C=EAEA,2E0=EAEA,488=EAEA,48F=EAEA,4B2=EAEA,730=EAEA,656=EAEA,6AF=EAEA,6E9=EAEA,3C4=EAEA,3BD99=EAEA,F0AD=EAEA,43E12=42FB,F162=42FB,358=EAEA,18BB4=4290,43E65=42FB,18649=DB2A
-06B1F0F5|Super Bomberman 5 (J)|5|0|0|0|0|0|BAE6=DBE2
-5688B581|Super Bonk (U)|1|0|0|0|0|0|C6E8=42DB
-9526D1AA|Super Buster Brothers|0|0|0|0|0|8|2E8A=DB87
-C86872D3|Super Buster Brothers (V1|0|0|0|0|0|0|2E46=DB87
-B64FFB12|Super Castlevania IV (U)|10|0|54E|0|1E|A|187=4286
-09ED12A5|Super Double Dragon (U)|0|0|0|0|0|0|3866=42
-3E631524|Super Earth Defense Force (J)|10000000|40404|0|0|0|0|3017A=EAEA,30125=EAEA,30135=EAEA,3013B=EAEA,30187=EAEA,3018C=EAEA,529=421B
-CA8FF946|Super Earth Defense Force (U)|10000000|0|0|0|0|0|30125=EAEA,30135=EAEA,3013B=EAEA,30187=EAEA,3018C=EAEA,51B=421B
-D6EACBEA|Super Famicom Wars (J) (NP)|4|4024400|0|0|0|0|DD4=EAEA,DD9=EAEA,EBA=EAEA,E1C=EAEA,CDF=EAEA,CEA=EAEA,2F3=42FC
-FF33E304|Super Famicom Wars (J) (NP)|5|0|0|0|0|0
-DB71BF4A|Super Fire Pro Wrestling (J)|10000000|40044000|0|0|0|0|64F9=42DB,C8D=42D8,113A=42D5
-6AABA901|Super Ghouls N Ghosts|14000010|4040|45E|0|32|A|1D1=EAEA,A6C4=DB6F
-935EA22C|Super Goal! (U)|4|0|0|0|0|0|E0DF4=EAEA,2854=EAEA
-7E8FE01A|Super Mario All Stars|4|44444444|0|0|0|0|41=EAEA,7D5=EAEA,827=EAEA,BB8=EAEA,BD0=EAEA,BDB=EAEA,BE0=EAEA,189B4=EAEA,1E4E3=EAEA,201B9=EAEA,68755=EAEA,6E439=EAEA,88470=EAEA,8963A=EAEA,A5F2C=EAEA,A5FDB=EAEA,1166CD=EAEA,12F39D=EAEA,393=425B,18522=425B,2C804=42BA,683B5=425B,696AC=42BA,891D7=DB61,89583=425B,A7A9D=42BA,F06DA=42,F06E1=DB,F06E9=42D9,10705F=4256,1070D0=4256,10711B=4256,107142=4256,10718D=4256,1072E7=42D9,107355=425B,1073CF=425B,107443=425B,107498=425B,107504=425B,107538=425B,107562=425B
-8089624C|Super Mario All-Stars & World|10000004|40C00|0|0|0|0|819=EAEA,86B=EAEA,C09=EAEA,C21=EAEA,C2C=EAEA,C31=EAEA,189C1=EAEA,1E4E3=EAEA,201B9=EAEA,68755=EAEA,6E439=EAEA,88494=EAEA,89696=EAEA,A5F2C=EAEA,A5FDB=EAEA,1166CD=EAEA,12F39D=EAEA,180095=EAEA,1800AD=EAEA,1800B8=EAEA,1800BD=EAEA,3D0=425B,18522=425B,2C804=42BA,683B5=425B,696AC=42BA,89233=DB61,895DF=425B,A7A9D=42BA,1072E7=42D9,107355=425B,1073CF=425B,107443=425B,107498=425B,107505=425B,107539=425B,107563=425B,1801D4=4210,18041D=4279
-925637C7|Super Mario All-Stars (U)|4|0|0|0|0|0|181AC=42
-56410E5E|Super Mario Kart (E) [!]|7|0|0|0|0|0|960C=EAEA,9638=EAEA,1F508=EAEA,1F51E=EAEA,1F529=EAEA,1F52E=EAEA,1F55C=EAEA,3BB80=EAEA,61E37=EAEA,805E=42
-CD80DB86|Super Mario Kart (U)|5|820000|0|0|0|0|9625=EAEA,9651=EAEA,1F513=EAEA,1F529=EAEA,1F534=EAEA,1F539=EAEA,1F567=EAEA,3BB72=EAEA,61E37=EAEA,805E=42
-1B8A0625|Super Mario RPG - Legend of the|4|0|0|0|0|0|A41=42,302FF=42,202E9=42DB,9F5=42
-B19ED489|Super Mario World|C|0|96|1C|A|19|6D=42
-B47F5F20|Super Mario World (V1|6|0|0|0|0|0
-AD2CBF9C|Super Metroid (E)|0|0|0|0|0|0|346=42DB,16529=421B,2D1=423B,1606E=423B
-D63ED5F8|Super Metroid (U)|0|0|0|0|0|0|346=42DB,16529=421B,2D1=423B,1606E=423B
-6BCBBA10|Super Ninja Boy (U)|0|0|0|0|0|4FA|4FA=421C,23C70=421B,8276=421B
-E2F92F84|Super Punch-Out!! (U)|4000004|0|0|0|0|0|4C42=42DB,3145=42DC,10B7=42DC
-8B22C830|Super R-Type|4000000|0|1599|0|1E|0|1BE=42
-442C47CB|Super Soccer (E)|2|0|0|0|0|0
-4FD164D8|Super Soccer (U)|0|0|0|0|0|0|4DE=EAEA,179=42F8
-13FC69C5|Super Star Wars (U) [p1][!]|0|0|0|0|0|0|1904=EAEA,22C2=EAEA,1783=42DB
-ACBCAE7C|Super Star Wars (u)(31438)|0|4000|0|0|0|0|1787=42DB
-1E7EA62C|Super Star Wars - Empire Strike|10000000|4040|0|0|0|0|4D0=EAEA,53F=EAEA,55A=EAEA,573=EAEA,5D4=EAEA,5DA=EAEA,5FB=EAEA,62B=EAEA,636=EAEA,63B=EAEA,182EB=EAEA,182F1=EAEA,1830A=EAEA,1833B=EAEA,AD93E=EAEA,17A962=EAEA,17C0BB=EAEA
-F16D5CE9|Super Street Fighter 2 - The Ne|1320001|0|0|0|0|0|DB=42FB
-70F28A6D|Super SWIV (J) (32469)|0|0|0|0|0|0|15C9=EAEA
-8D383776|Super Tennis (U) [!]|0|0|0|0|0|0|47B4=EAEA
-C6B25E62|Super Turrican (U)|0|40400000|4C3|0|3C|18|6020E=EAEA,6021F=EAEA,6022E=EAEA,60241=EAEA,3C1=42DB,5EC86=42,53673=42
-5E550E27|Super Turrican 2 (U)(32515)|0|40400000|0|0|0|0|1FFB20=4299,1FFB2B=42DB,1FF548=DB07,1FF6D2=DB07,1FF55A=42DB,1FF6E4=43DB,1FAD29=DBDA,1FAC12=42DC,1FED44=DB9F,157C=DB4F
-D74570D3|Syndicate (U)|0|0|0|0|0|0|F756F=EAEA
-5DC6B9FE|T2 - The Arcade Game (U)|0|0|0|0|0|0|F80B8=EAEA,F81E8=EAEA,F81BA=EAEA,F8202=EAEA,F80B6=EAEA,F80C4=EAEA
-AB57932F|tactics ogre (v1.2) (j)|4|4849004|0|0|0|0|78073=EAEA,780B2=EAEA,78333=EAEA,78381=EAEA,783A0=EAEA,219D=42FB,78191=EAEA,DF5EC=EAEA
-DAF285A5|Tactics Ogre - Version 1.0 (J)|4|4849004|0|0|0|0|78073=EAEA,780B2=EAEA,78333=EAEA,78381=EAEA,783A0=EAEA,219D=42FB,78191=EAEA,DF5EC=EAEA
-271E1D07|Tactics Ogre - Version 1.1 (J)|4|4849004|0|0|0|0|78073=EAEA,780B2=EAEA,78333=EAEA,78381=EAEA,783A0=EAEA,219D=42FB,78191=EAEA,DF5EC=EAEA
-12F0A699|Tactics Ogre - Version 1.2 (J)|4|4849004|0|0|0|0|78073=EAEA,780B2=EAEA,78333=EAEA,78381=EAEA,783A0=EAEA,219D=42FB,78191=EAEA,DF5EC=EAEA
-93F29DDE|Taekwon-Do (J) (M2)|0|440800|0|0|0|0|618C=42F8,626B=42D3
-8745A442|Tales of Phantasia (J)|5|0|0|0|0|0
-14612848|Tales of Phantasia (J) [T-Eng1|5|0|0|0|0|0
-E302D853|Tecmo Super Baseball (U)|4|0|0|0|0|0|A39E=EAEA,A3C7=EAEA,A400=EAEA,A471=EAEA,A48C=EAEA,A4AC=EAEA,A516=EAEA,A521=EAEA,A526=EAEA,A54F=EAEA,A555=EAEA,A65E=EAEA,A968=EAEA,A97F=EAEA,A9AE=EAEA,A9BD=EAEA,A9EA=EAEA,758B4=EAEA,F23B5=EAEA
-8EF1411F|Tecmo Super Bowl 3 (U)|4|0|0|0|0|0|4E31=EAEA,4E49=EAEA,4E55=EAEA,4E5A=EAEA,4EB2=EAEA,4EEA=EAEA,4F16=EAEA,4FA5=EAEA,4FAA=EAEA,4FD4=EAEA,7E81C=EAEA,351=42D9,4B085=DB,52399=DB,544AA=42BE,1C1897=DB60,1FAEBE=421F
-7E107C35|Tekkaman Blade (J)|0|4444|0|0|0|0|181=42FC
-066687CA|Tekken 2 (PD)|0|44C00|0|0|0|0
-6E030B96|Tenshi no Uta - Shiroki Tsubas|5|400400|0|0|0|0|EECE=EAEA,1001A5=EAEA,2840=421B,10148=421A,283B=423B,429E=42D7
-D71E6C3B|Terminator, The (U)|10000000|0|0|0|0|0|10046=EAEA,100AB=EAEA,100DE=EAEA,101B6=EAEA,330=42,5681=42
-974523FF|Terranigma (E) [!]|7|0|0|0|0|0|6B8F3=EAEA,798CF=8003,6800D=421A,797CE=80
-CE3392B1|Tetris 2 (U) (V1.0)|0|0|0|0|0|0|25E8=421B
-19B69A57|Tetris 2 (E)|0|0|0|0|0|0|25E8=421B
-6C852EF3|Tetris & Dr. Mario (U) [!]|0|0|0|0|0|0|6EA=EAEA,3B3E=EAEA,3B89=EAEA,3B9D=EAEA
-6C128210|Tetris Attack (U)|0|0|0|0|0|0|148B=EAEA,1486=EAEA,14CC=EAEA,1556=EAEA,14DD=EAEA,155B=EAEA,1571=EAEA,1576=EAEA,20168=DBA4
-B8F5F846|Tetris Battle Gaiden (J)|0|0|0|0|0|A|C040=42DB
-B3EF81F5|The Adventures of Batman & Robi|18000000|44000|0|0|0|0|1779=EAEA,161B=EAEA,F3=4288
-CA0E041C|Theme Park (E) [!]|2|0|0|0|0|0|41EDF=EAEA,70073=EAEA,702D5=EAEA,74110=EAEA,744A6=EAEA,36F=4210,3AD=42D9,74A7C=DB
-41A933A6|Thunder Spirits (J)|0|4484|0|0|0|0|810=42DB
-522FE837|Thunder Spirits (U)|0|4444|0|0|0|0|818=42DB
-12AB22A7|Tick, The (U)|0|0|0|0|0|0|723=42F3
-1E079AC0|Tinhead (E) (Beta)|10000002|44400|0|0|0|0|5B5=EAEA,54A=EAEA,4AE=EAEA,45E=EAEA,75C2=42FC,2819=42FC
-AB48D27A|Tiny Toons Adventures - Buster|0|0|0|0|0|0
-F1F8F87A|Tiny Toons Adventures - Buster|0|0|0|0|0|0|1AAF=DBBF
-5940BD99|TMNT 4 - Turtles in Time|1320000|0|7E040C|0|1E|14|162=4280
-5D98C75C|TMNT 4 - Turtles in Time (Alt)|1320000|0|7E040C|0|1E|14|162=4280
-E2FE5DBF|TMNT Tournament Fighters|0|0|0|0|5|0|22DF=EAEA,22E4=EAEA,525=EAEA,21B5=EAEA,21C3=EAEA,21D1=EAEA,16D=4284
-654E1BE4|Torneco no Daibouken (J)|4|400800|0|0|0|0|181BB=EAEA,1AB9F=EAEA,1ABA0=EAEA,1ABA2=EAEA,1AB5F=EAEA,1A924=EAEA,1A92C=EAEA,1A708=428B
-85A21253|Torneco no Daibouken (V1|4|400800|0|0|0|0|181BB=EAEA,1AB9F=EAEA,1ABA0=EAEA,1ABA2=EAEA,1AB5F=EAEA,1A924=EAEA,1A92C=EAEA,1A708=428B
-B5113CCB|Traverse Starlight & Prairie (J|5|0|0|0|0|0|1C3385=421B,104857=42DB,10476C=423B,104771=421B,10486D=42DB,19D2A=EAEA
-3CCEED49|Treasure Hunter G (J)|4|4000|0|0|0|0|40055=EAEA,402C8=EAEA,83=421B,88=423B,95=42F9
-4C9E6827|Treasure Hunter G (J) [T+EngBet|8000004|44C00|0|0|0|0|40055=EAEA,402C8=EAEA,83=421B,88=423B,95=42F9
-40CA49AE|True Lies (U)|0|80408|0|0|0|0|3EB=42D7,8D0A=EAEA,8D11=EAEA,8D4B=EAEA,8D5F=EAEA,8D6C=EAEA,8D90=EAEA,8DA3=EAEA,8DAE=EAEA,8DD2=EAEA,8DDB=EAEA,2AC40=EAEA,41D30=EAEA,6726F=EAEA,7886F=EAEA
-91867AF4|Twinbee - Rainbow Bell Adventu|4000004|40404|0|0|0|FFFFFFFB|2959=EAEA,2967=EAEA,2975=EAEA,2A81=EAEA,10C=4281
-231F0F67|U.N. Squadron (U)|8000000|44400|0|0|0|19|61=EAEA,64=EAEA,65=EAEA,129=42FC
-B380BCD9|Uchuu no Kishi Tekkaman Blade |0|4444|0|0|0|0|181=42FC
-272DFC4B|UFO Kamen Yakisoban (J)|0|800|0|0|0|0|7C7=EAEA,7CE=EAEA,7D5=EAEA,805=EAEA,80C=EAEA,813=EAEA,53DA=EAEA,ACE5=42FB,B25F=42,A1=42
-9277C9F7|Ultima VI - The False Prophet (|4|0|0|0|0|0|237A=4210
-E790F52F|Ultima VII - The Black Gate (U)|4|0|0|0|0|0|3FC=EAEA,436=EAEA,441=EAEA,446=EAEA,474=EAEA,49E=EAEA,4B1=EAEA,4BD=EAEA,4C8=EAEA,4D5=EAEA,4EA=EAEA,F329D=DBFE,93295=DB
-F5BFE41E|Ultimate Mortal Kombat 3 (U)|1|40444040|0|0|0|0|4E9BD=EAEA,4EA1B=EAEA,4EA32=EAEA,4EA4E=EAEA,4EA66=EAEA,4EA72=EAEA,4EA77=EAEA,4EAA5=EAEA,4EAD2=EAEA,4EADF=EAEA,4EAF9=EAEA,4EB17=EAEA,4EB1D=EAEA,4EB47=EAEA,4EB74=EAEA,4F95A=EAEA,4F985=EAEA,4F9B3=EAEA,4F9E1=EAEA,4FA0F=EAEA,4FA45=EAEA,4FA5F=EAEA,4FA82=EAEA,4FA95=EAEA,4FAB8=EAEA,4FACB=EAEA,4FAEE=EAEA,4FB01=EAEA,4FB28=EAEA,1121C5=EAEA,876F=42,FDCA=42B9,4EC17=428D,84B91=DB,F92C9=42BB,33D253=428F,39F773=DBF0,3B9DAC=DBF0
-0B108549|Ultra Baseball Jitsumei Ban 2 |4|0|0|0|0|0|7AF=421C
-393CCCA2|Umi Hara Kawa Se (J)|40C0004|0|0|0|0|0|F0=42
-3C3C63E6|Uncharted Waters - New Horizons|5|0|0|0|0|0|9E98=42D9,9F5F=42DB
-B574C939|Undercover Cops (J)|1|0|0|0|0|0|1C0520=EAEA,1C011D=EAEA,1C04C6=EAEA,1C04E3=EAEA,1C02E2=EAEA,1C02FF=EAEA,1C00D0=EAEA,1C00ED=EAEA,8128=42
-59180F1C|Universal Soldier (U) (Beta)|0|44C00|0|0|0|0|4A68=EAEA,4423=42FB,43F1=42F7,43A4=42D9,6033=42D8
-B9BF7990|Urban Strike (U) [!]|0|0|0|0|0|0
-2D1004F1|Wario's Woods (U)|4|0|0|0|0|0|58195=EAEA,5824E=EAEA,32F=42DC
-A47884D0|Warlock (U)|4000000|0|0|0|0|0|676E=EAEA,6786=EAEA,6791=EAEA,6796=EAEA,67DB=EAEA,67E2=EAEA,6804=EAEA,683D=EAEA,6854=EAEA,6867=EAEA,68E0=EAEA,68F7=EAEA,690A=EAEA,694C=EAEA,69ED=429B,E905=42D9,1680FA=DB6E
-8B477300|WCW Super Brawl (U)|0|0|0|0|0|0|13FFD=42FC,BBD9=42DB
-7379E3B3|Whirlo (E)|2|0|0|0|0|0|CD3=42DC
-1637D1A5|Wings 2 (U)|0|0|0|0|0|0|78103=EAEA,78116=EAEA,78119=EAEA
-D5CE2DB5|Wizard of Oz, The (U)|0|44800|0|0|0|0|150=42FC,5224=42
-B8A72553|Wizardry 1 2 3 (J) (NP)|4|0|0|0|0|0|1C008E=EAEA,1C00CB=EAEA,1C00E0=EAEA,1C0108=EAEA,1C05AC=EAEA,1C05E3=EAEA,1C05ED=EAEA,BD=DB,1BF=42BA,159750=4210
-D8FDDD76|Wizardry 5 (U)|4|0|0|0|0|0|18A=42BA,213=428C,66830=42,14C5=EAEA,15D4=EAEA,695E=EAEA,69D8=EAEA,6C5F=EAEA,4003C=EAEA,40046=EAEA,40056=EAEA,40070=EAEA,4009A=EAEA,400A8=EAEA,400B3=EAEA,400C4=EAEA,400DE=EAEA,400FC=EAEA,40117=EAEA,40144=EAEA,40164=EAEA,4016B=EAEA,4017F=EAEA,401B8=EAEA,401C5=EAEA,401CF=EAEA,401DF=EAEA,401F1=EAEA,4020D=EAEA,49C8F=EAEA,5004B=EAEA,50055=EAEA,50065=EAEA,5007F=EAEA,500B7=EAEA,500D1=EAEA,500E6=EAEA,50105=EAEA,5011B=EAEA,5017D=EAEA,50187=EAEA,50197=EAEA,501B1=EAEA,501BA=EAEA,501CB=EAEA,501DD=EAEA,501EA=EAEA,5023B=EAEA,50245=EAEA,50255=EAEA,5026F=EAEA,50289=EAEA,50298=EAEA,95CD3=EAEA,A8655=EAEA,B7A03=EAEA,BBE13=EAEA,DCCB1=EAEA
-1703D522|Wizardry Gaiden IV - Taima no K|4|40040800|0|0|0|0|B0726=EAEA,B05C8=EAEA,523=42DC,B071F=42,60=4283
-13BFB3A0|Wolfchild (U)|4000000|804|0|0|0|0|F8099=EAEA,F8146=EAEA,F811B=EAEA,F815E=EAEA,F809E=EAEA,5F8=42FC,614=42FC
-36079184|Wonder Project J [T+Eng1.04]|5|0|0|0|0|0|AB80=EAEA,2E4A2=EAEA,2E4A8=EAEA,2E4BB=EAEA,2E4BF=EAEA,8420=42DB
-90D0FAC0|Worms (E)|10000002|0|0|0|0|0|150085=EAEA,150178=EAEA,19C3B7=EAEA,1B5A=423A,1B60=421A,7627=DB,794E=423A,7BD1=42D8,1B1013=DB
-4F02A304|X-Men Mutant Apocalypse (J)|4000001|44000|0|0|0|0|AB=42FB
-5E34822A|X-Men Mutant Apocalypse (U)|4000001|44800|0|0|0|0|AB=42FB
-C7C12A57|Xardion|4|0|D02|0|1E|5|5E90=421B,5E9E=421B,5E82=421B
-7448D45C|Yogi Bear (U)|0|0|0|0|0|0|1ED=EAEA,74C=EAEA,856=EAEA,1137=EAEA,1DB6=EAEA,1EFC=EAEA,1FAD=EAEA,279E=EAEA,57FA=EAEA,5849=EAEA,5861=EAEA,586C=EAEA,5871=EAEA,601BD=EAEA,E84A7=EAEA
-EF15F4C3|Yoshi's Cookie (U)|0|0|0|0|0|0|2824F=421B
-D138F224|Yoshi's Island (V1.0) (U)|0|0|0|0|0|0|F4=423B
-CF98DDAA|Yoshi's Island (U) (M3) (V1.1)|F4=423B
-59490CE8|Yoshi's Safari|0|0|0|0|0|0
-7EA1AFE8|Young Merlin|0|0|0|0|0|0
-64A91E64|Ys 3 - Wanderers from Ys|0|0|0|0|0|0|D8=42
-1ADD47F0|Ys 4 - Mask of the Sun (J) [T-E|4|0|0|0|0|0|14060C=EAEA,140631=EAEA,9CA=42DC,A3B=42DC
-7B4CEBAF|Ys 4 - Mask of the Sun (J) [T-E|4|0|0|0|0|14060C|14060C=EAEA,140631=EAEA,9CA=42DC,A3B=42DC
-CFE632B9|Ys V - Expert (J)|4|44800|0|0|0|0|886=EAEA,79D=EAEA,3B81=EAEA,86C=EAEA,5E06=42FB,A9C=42FB,5DCC=42DB
-EC96D517|YUUYUU Hakusho (J)|0|0|0|0|0|0|E15=42FC
-EEF45A93|YUUYUU Hakusho 2 - Kakutou no S|0|0|0|0|0|0|10F=42DC
-5617A42E|YUUYUU Hakusho Final (J)|1|0|0|0|0|0|A71D=EAEA,A683=EAEA,AB=42DC
-535CCCAC|YUUYUU Hakusho Tokubehuten (J)|0|0|0|0|0|0|7957=EAEA,781A=EAEA
-5409D4F4|Zen Nihon GT Sensyuken (J)|1320000|0|0|0|0|0|8003B=EAEA,8012B=EAEA,80137=EAEA,15E=42FB
-5397D5BC|Zero the Kamikaze Squirrel (U)|0|0|0|0|0|0|41B44=EAEA,41B69=EAEA,1F3=42DB,12EA=4214,2884A=42DB,496=421B,41F=421B
-7CFC0C7C|Zombies Ate My Neighbors (U)|10000000|4040|0|0|0|0|4CCF=EAEA,9DC=42
diff --git a/old/snaporig.c b/old/snaporig.c deleted file mode 100644 index af9263a..0000000 --- a/old/snaporig.c +++ /dev/null @@ -1,411 +0,0 @@ -/* - * Snes9x - Portable Super Nintendo Entertainment System (TM) emulator. - * - * (c) Copyright 1996 - 2001 Gary Henderson (gary.henderson@ntlworld.com) and - * Jerremy Koot (jkoot@snes9x.com) - * - * Super FX C emulator code - * (c) Copyright 1997 - 1999 Ivar (ivar@snes9x.com) and - * Gary Henderson. - * Super FX assembler emulator code (c) Copyright 1998 zsKnight and _Demo_. - * - * DSP1 emulator code (c) Copyright 1998 Ivar, _Demo_ and Gary Henderson. - * C4 asm and some C emulation code (c) Copyright 2000 zsKnight and _Demo_. - * C4 C code (c) Copyright 2001 Gary Henderson (gary.henderson@ntlworld.com). - * - * DOS port code contains the works of other authors. See headers in - * individual files. - * - * Snes9x homepage: http://www.snes9x.com - * - * Permission to use, copy, modify and distribute Snes9x in both binary and - * source form, for non-commercial purposes, is hereby granted without fee, - * providing that this license information and copyright notice appear with - * all copies and any derived work. - * - * This software is provided 'as-is', without any express or implied - * warranty. In no event shall the authors be held liable for any damages - * arising from the use of this software. - * - * Snes9x is freeware for PERSONAL USE only. Commercial users should - * seek permission of the copyright holders first. Commercial use includes - * charging money for Snes9x or software derived from Snes9x. - * - * The copyright holders request that bug fixes and improvements to the code - * should be forwarded to them so everyone can benefit from the modifications - * in future versions. - * - * Super NES and Super Nintendo Entertainment System are trademarks of - * Nintendo Co., Limited and its subsidiary companies. - */ -#include <string.h> -#include <ctype.h> -#include <stdlib.h> - -#if defined(__unix) || defined(__linux) || defined(__sun) || defined(__DJGPP) -//#include <unistd.h> -#include <sys/types.h> -#include <sys/stat.h> -#endif - -#include "snapshot.h" -#include "snaporig.h" -#include "memmap.h" -#include "snes9x.h" -#include "65c816.h" -#include "ppu.h" -#include "cpuexec.h" -#include "display.h" -#include "apu.h" -#include "soundux.h" - -struct SOrigPPU OrigPPU; -struct SOrigDMA OrigDMA [8]; -struct SOrigRegisters OrigRegisters; -struct SOrigCPUState OrigCPU; -struct SOrigAPU OrigAPU; -SOrigSoundData OrigSoundData; -struct SOrigAPURegisters OrigAPURegisters; -char ROMFilename [1025]; - -static int ReadOrigSnapshot(STREAM); - -bool8_32 S9xLoadOrigSnapshot(const char* filename) -{ - STREAM snapshot = NULL; - if (S9xOpenSnapshotFile(filename, TRUE, &snapshot)) - { - int result; - if ((result = ReadOrigSnapshot(snapshot)) != SUCCESS) - { - S9xCloseSnapshotFile(snapshot); - return (FALSE); - } - S9xCloseSnapshotFile(snapshot); - return (TRUE); - } - return (FALSE); -} - -static int ReadBlock(const char* key, void* block, int max_len, STREAM snap) -{ - char buffer [20]; - int len = 0; - int rem = 0; - - if (READ_STREAM(buffer, 11, snap) != 11 || - strncmp(buffer, key, 4) != 0 || - (len = atoi(&buffer [4])) == 0) - return (WRONG_FORMAT); - - if (len > max_len) - { - rem = len - max_len; - len = max_len; - } - if (READ_STREAM(block, len, snap) != len) - return (WRONG_FORMAT); - - if (rem) - { - char* junk = new char [rem]; - READ_STREAM(junk, rem, snap); - delete junk; - } - - return (SUCCESS); -} - -static int ReadOrigSnapshot(STREAM snap) -{ - char buffer [_MAX_PATH]; - char rom_filename [_MAX_PATH]; - int result; - int i; - int j; - - int version; - int len = strlen(ORIG_SNAPSHOT_MAGIC) + 1 + 4 + 1; - if (READ_STREAM(buffer, len, snap) != len) - return (WRONG_FORMAT); - if (strncmp(buffer, ORIG_SNAPSHOT_MAGIC, strlen(ORIG_SNAPSHOT_MAGIC)) != 0) - return (WRONG_FORMAT); - if ((version = atoi(&buffer [strlen(SNAPSHOT_MAGIC) + 1])) > ORIG_SNAPSHOT_VERSION) - return (WRONG_VERSION); - - if ((result = ReadBlock("NAM:", rom_filename, _MAX_PATH, snap)) != SUCCESS) - return (result); - - if ((result = ReadBlock("HiR:", buffer, 0x41, snap)) != SUCCESS) - return (result); - - if (strcasecmp(rom_filename, Memory.ROMFilename) != 0 && - strcasecmp(S9xBasename(rom_filename), S9xBasename(Memory.ROMFilename)) != 0) - { - S9xMessage(S9X_WARNING, S9X_FREEZE_ROM_NAME, - "Current loaded ROM image doesn't match that required by freeze-game file."); - } - - S9xReset(); - S9xSetSoundMute(TRUE); - if ((result = ReadBlock("CPU:", &OrigCPU, sizeof(OrigCPU), snap)) != SUCCESS) - return (result); - OrigCPU.FastROMSpeed = OrigCPU.FastROMSpeed_old; - Memory.FixROMSpeed(); - if (version == 3) - { - OrigCPU.Cycles = OrigCPU.Cycles_old; - OrigCPU.NextEvent = OrigCPU.NextEvent_old; - OrigCPU.V_Counter = OrigCPU.V_Counter_old; - OrigCPU.MemSpeed = OrigCPU.MemSpeed_old; - OrigCPU.MemSpeedx2 = OrigCPU.MemSpeedx2_old; - OrigCPU.FastROMSpeed = OrigCPU.FastROMSpeed_old; - } - CPU.Flags = OrigCPU.Flags; - CPU.BranchSkip = OrigCPU.BranchSkip; - CPU.NMIActive = OrigCPU.NMIActive; - CPU.IRQActive = OrigCPU.IRQActive; - CPU.WaitingForInterrupt = OrigCPU.WaitingForInterrupt; - CPU.WhichEvent = OrigCPU.WhichEvent; - CPU.Cycles = OrigCPU.Cycles; - CPU.NextEvent = OrigCPU.NextEvent; - CPU.V_Counter = OrigCPU.V_Counter; - CPU.MemSpeed = OrigCPU.MemSpeed; - CPU.MemSpeedx2 = OrigCPU.MemSpeedx2; - CPU.FastROMSpeed = OrigCPU.FastROMSpeed; - - if ((result = ReadBlock("REG:", &OrigRegisters, sizeof(OrigRegisters), snap)) != SUCCESS) - return (result); - - Registers = *(struct SRegisters*) &OrigRegisters; - - if ((result = ReadBlock("PPU:", &OrigPPU, sizeof(OrigPPU), snap)) != SUCCESS) - return (result); - - if (version == 2) - { - OrigPPU.OBJNameSelect = OrigPPU.OBJNameSelect_old << 13; - OrigPPU.OBJNameBase <<= 1; - OrigPPU.OBJNameSelect <<= 13; - } - PPU.BGMode = OrigPPU.BGMode; - PPU.BG3Priority = OrigPPU.BG3Priority; - PPU.Brightness = OrigPPU.Brightness; - - PPU.VMA.High = OrigPPU.VMA.High; - PPU.VMA.Increment = OrigPPU.VMA.Increment; - PPU.VMA.Address = OrigPPU.VMA.Address; - PPU.VMA.Mask1 = OrigPPU.VMA.Mask1; - PPU.VMA.FullGraphicCount = OrigPPU.VMA.FullGraphicCount; - PPU.VMA.Shift = OrigPPU.VMA.Shift; - - for (i = 0; i < 4; i++) - { - PPU.BG[i].SCBase = OrigPPU.BG[i].SCBase; - PPU.BG[i].VOffset = OrigPPU.BG[i].VOffset; - PPU.BG[i].HOffset = OrigPPU.BG[i].HOffset; - PPU.BG[i].BGSize = OrigPPU.BG[i].BGSize; - PPU.BG[i].NameBase = OrigPPU.BG[i].NameBase; - PPU.BG[i].SCSize = OrigPPU.BG[i].SCSize; - } - - PPU.CGFLIP = OrigPPU.CGFLIP; - for (i = 0; i < 256; i++) - PPU.CGDATA [i] = OrigPPU.CGDATA [i]; - PPU.FirstSprite = OrigPPU.FirstSprite; - for (i = 0; i < 128; i++) - { - PPU.OBJ[i].HPos = OrigPPU.OBJ [i].HPos; - PPU.OBJ[i].VPos = OrigPPU.OBJ [i].VPos; - PPU.OBJ[i].Name = OrigPPU.OBJ [i].Name; - PPU.OBJ[i].VFlip = OrigPPU.OBJ [i].VFlip; - PPU.OBJ[i].HFlip = OrigPPU.OBJ [i].HFlip; - PPU.OBJ[i].Priority = OrigPPU.OBJ [i].Priority; - PPU.OBJ[i].Palette = OrigPPU.OBJ [i].Palette; - PPU.OBJ[i].Size = OrigPPU.OBJ [i].Size; - } - PPU.OAMPriorityRotation = OrigPPU.OAMPriorityRotation; - PPU.OAMAddr = OrigPPU.OAMAddr; - - PPU.OAMFlip = OrigPPU.OAMFlip; - PPU.OAMTileAddress = OrigPPU.OAMTileAddress; - PPU.IRQVBeamPos = OrigPPU.IRQVBeamPos; - PPU.IRQHBeamPos = OrigPPU.IRQHBeamPos; - PPU.VBeamPosLatched = OrigPPU.VBeamPosLatched; - PPU.HBeamPosLatched = OrigPPU.HBeamPosLatched; - - PPU.HBeamFlip = OrigPPU.HBeamFlip; - PPU.VBeamFlip = OrigPPU.VBeamFlip; - PPU.HVBeamCounterLatched = OrigPPU.HVBeamCounterLatched; - - PPU.MatrixA = OrigPPU.MatrixA; - PPU.MatrixB = OrigPPU.MatrixB; - PPU.MatrixC = OrigPPU.MatrixC; - PPU.MatrixD = OrigPPU.MatrixD; - PPU.CentreX = OrigPPU.CentreX; - PPU.CentreY = OrigPPU.CentreY; - PPU.Joypad1ButtonReadPos = OrigPPU.Joypad1ButtonReadPos; - PPU.Joypad2ButtonReadPos = OrigPPU.Joypad2ButtonReadPos; - PPU.Joypad3ButtonReadPos = OrigPPU.Joypad3ButtonReadPos; - - PPU.CGADD = OrigPPU.CGADD; - PPU.FixedColourRed = OrigPPU.FixedColourRed; - PPU.FixedColourGreen = OrigPPU.FixedColourGreen; - PPU.FixedColourBlue = OrigPPU.FixedColourBlue; - PPU.SavedOAMAddr = OrigPPU.SavedOAMAddr; - PPU.ScreenHeight = OrigPPU.ScreenHeight; - PPU.WRAM = OrigPPU.WRAM; - PPU.ForcedBlanking = OrigPPU.ForcedBlanking; - PPU.OBJNameSelect = OrigPPU.OBJNameSelect; - PPU.OBJSizeSelect = OrigPPU.OBJSizeSelect; - PPU.OBJNameBase = OrigPPU.OBJNameBase; - PPU.OAMReadFlip = OrigPPU.OAMReadFlip; - memmove(PPU.OAMData, OrigPPU.OAMData, sizeof(PPU.OAMData)); - PPU.VTimerEnabled = OrigPPU.VTimerEnabled; - PPU.HTimerEnabled = OrigPPU.HTimerEnabled; - PPU.HTimerPosition = OrigPPU.HTimerPosition; - PPU.Mosaic = OrigPPU.Mosaic; - memmove(PPU.BGMosaic, OrigPPU.BGMosaic, sizeof(PPU.BGMosaic)); - PPU.Mode7HFlip = OrigPPU.Mode7HFlip; - PPU.Mode7VFlip = OrigPPU.Mode7VFlip; - PPU.Mode7Repeat = OrigPPU.Mode7Repeat; - PPU.Window1Left = OrigPPU.Window1Left; - PPU.Window1Right = OrigPPU.Window1Right; - PPU.Window2Left = OrigPPU.Window2Left; - PPU.Window2Right = OrigPPU.Window2Right; - for (i = 0; i < 6; i++) - { - PPU.ClipWindowOverlapLogic [i] = OrigPPU.ClipWindowOverlapLogic [i]; - PPU.ClipWindow1Enable [i] = OrigPPU.ClipWindow1Enable [i]; - PPU.ClipWindow2Enable [i] = OrigPPU.ClipWindow2Enable [i]; - PPU.ClipWindow1Inside [i] = OrigPPU.ClipWindow1Inside [i]; - PPU.ClipWindow2Inside [i] = OrigPPU.ClipWindow2Inside [i]; - } - PPU.CGFLIPRead = OrigPPU.CGFLIPRead; - PPU.Need16x8Mulitply = OrigPPU.Need16x8Mulitply; - - IPPU.ColorsChanged = TRUE; - IPPU.OBJChanged = TRUE; - S9xFixColourBrightness(); - IPPU.RenderThisFrame = FALSE; - - if ((result = ReadBlock("DMA:", OrigDMA, sizeof(OrigDMA), snap)) != SUCCESS) - return (result); - - for (i = 0; i < 8; i++) - { - DMA[i].TransferDirection = OrigDMA[i].TransferDirection; - DMA[i].AAddressFixed = OrigDMA[i].AAddressFixed; - DMA[i].AAddressDecrement = OrigDMA[i].AAddressDecrement; - DMA[i].TransferMode = OrigDMA[i].TransferMode; - DMA[i].ABank = OrigDMA[i].ABank; - DMA[i].AAddress = OrigDMA[i].AAddress; - DMA[i].Address = OrigDMA[i].Address; - DMA[i].BAddress = OrigDMA[i].BAddress; - DMA[i].TransferBytes = OrigDMA[i].TransferBytes; - DMA[i].HDMAIndirectAddressing = OrigDMA[i].HDMAIndirectAddressing; - DMA[i].IndirectAddress = OrigDMA[i].IndirectAddress; - DMA[i].IndirectBank = OrigDMA[i].IndirectBank; - DMA[i].Repeat = OrigDMA[i].Repeat; - DMA[i].LineCount = OrigDMA[i].LineCount; - DMA[i].FirstLine = OrigDMA[i].FirstLine; - } - - if ((result = ReadBlock("VRA:", Memory.VRAM, 0x10000, snap)) != SUCCESS) - return (result); - if ((result = ReadBlock("RAM:", Memory.RAM, 0x20000, snap)) != SUCCESS) - return (result); - if ((result = ReadBlock("SRA:", SRAM, 0x10000, snap)) != SUCCESS) - return (result); - if ((result = ReadBlock("FIL:", Memory.FillRAM, 0x8000, snap)) != SUCCESS) - return (result); - if (ReadBlock("APU:", &OrigAPU, sizeof(OrigAPU), snap) == SUCCESS) - { - APU = *(struct SAPU*) &OrigAPU; - - if ((result = ReadBlock("ARE:", &OrigAPURegisters, - sizeof(OrigAPURegisters), snap)) != SUCCESS) - return (result); - APURegisters = *(struct SAPURegisters*) &OrigAPURegisters; - if ((result = ReadBlock("ARA:", IAPU.RAM, 0x10000, snap)) != SUCCESS) - return (result); - if ((result = ReadBlock("SOU:", &OrigSoundData, - sizeof(SOrigSoundData), snap)) != SUCCESS) - return (result); - - SoundData.master_volume_left = OrigSoundData.master_volume_left; - SoundData.master_volume_right = OrigSoundData.master_volume_right; - SoundData.echo_volume_left = OrigSoundData.echo_volume_left; - SoundData.echo_volume_right = OrigSoundData.echo_volume_right; - SoundData.echo_enable = OrigSoundData.echo_enable; - SoundData.echo_feedback = OrigSoundData.echo_feedback; - SoundData.echo_ptr = OrigSoundData.echo_ptr; - SoundData.echo_buffer_size = OrigSoundData.echo_buffer_size; - SoundData.echo_write_enabled = OrigSoundData.echo_write_enabled; - SoundData.echo_channel_enable = OrigSoundData.echo_channel_enable; - SoundData.pitch_mod = OrigSoundData.pitch_mod; - - for (i = 0; i < 3; i++) - SoundData.dummy [i] = OrigSoundData.dummy [i]; - for (i = 0; i < NUM_CHANNELS; i++) - { - SoundData.channels [i].state = OrigSoundData.channels [i].state; - SoundData.channels [i].type = OrigSoundData.channels [i].type; - SoundData.channels [i].volume_left = OrigSoundData.channels [i].volume_left; - SoundData.channels [i].volume_right = OrigSoundData.channels [i].volume_right; - SoundData.channels [i].hertz = OrigSoundData.channels [i].frequency; - SoundData.channels [i].count = OrigSoundData.channels [i].count; - SoundData.channels [i].loop = OrigSoundData.channels [i].loop; - SoundData.channels [i].envx = OrigSoundData.channels [i].envx; - SoundData.channels [i].left_vol_level = OrigSoundData.channels [i].left_vol_level; - SoundData.channels [i].right_vol_level = OrigSoundData.channels [i].right_vol_level; - SoundData.channels [i].envx_target = OrigSoundData.channels [i].envx_target; - SoundData.channels [i].env_error = OrigSoundData.channels [i].env_error; - SoundData.channels [i].erate = OrigSoundData.channels [i].erate; - SoundData.channels [i].direction = OrigSoundData.channels [i].direction; - SoundData.channels [i].attack_rate = OrigSoundData.channels [i].attack_rate; - SoundData.channels [i].decay_rate = OrigSoundData.channels [i].decay_rate; - SoundData.channels [i].sustain_rate = OrigSoundData.channels [i].sustain_rate; - SoundData.channels [i].release_rate = OrigSoundData.channels [i].release_rate; - SoundData.channels [i].sustain_level = OrigSoundData.channels [i].sustain_level; - SoundData.channels [i].sample = OrigSoundData.channels [i].sample; - for (j = 0; j < 16; j++) - SoundData.channels [i].decoded [j] = OrigSoundData.channels [i].decoded [j]; - - for (j = 0; j < 2; j++) - SoundData.channels [i].previous [j] = OrigSoundData.channels [i].previous [j]; - - SoundData.channels [i].sample_number = OrigSoundData.channels [i].sample_number; - SoundData.channels [i].last_block = OrigSoundData.channels [i].last_block; - SoundData.channels [i].needs_decode = OrigSoundData.channels [i].needs_decode; - SoundData.channels [i].block_pointer = OrigSoundData.channels [i].block_pointer; - SoundData.channels [i].sample_pointer = OrigSoundData.channels [i].sample_pointer; - SoundData.channels [i].mode = OrigSoundData.channels [i].mode; - } - - S9xSetSoundMute(FALSE); - IAPU.PC = IAPU.RAM + IAPU.PC; - S9xAPUUnpackStatus(); - if (APUCheckDirectPage()) - IAPU.DirectPage = IAPU.RAM + 0x100; - else - IAPU.DirectPage = IAPU.RAM; - Settings.APUEnabled = TRUE; - CPU.APU_APUExecuting = TRUE; - } - else - { - Settings.APUEnabled = FALSE; - CPU.APU_APUExecuting = FALSE; - S9xSetSoundMute(TRUE); - } - S9xFixSoundAfterSnapshotLoad(); - ICPU.ShiftedPB = Registers.PB << 16; - ICPU.ShiftedDB = Registers.DB << 16; - S9xSetPCBase(ICPU.ShiftedPB + Registers.PC, &CPU); - S9xUnpackStatus(); - S9xFixCycles(&Registers, &ICPU); - S9xReschedule(); - - return (SUCCESS); -} diff --git a/old/snaporig.h b/old/snaporig.h deleted file mode 100644 index e8b77be..0000000 --- a/old/snaporig.h +++ /dev/null @@ -1,350 +0,0 @@ -/* - * Snes9x - Portable Super Nintendo Entertainment System (TM) emulator. - * - * (c) Copyright 1996 - 2001 Gary Henderson (gary.henderson@ntlworld.com) and - * Jerremy Koot (jkoot@snes9x.com) - * - * Super FX C emulator code - * (c) Copyright 1997 - 1999 Ivar (ivar@snes9x.com) and - * Gary Henderson. - * Super FX assembler emulator code (c) Copyright 1998 zsKnight and _Demo_. - * - * DSP1 emulator code (c) Copyright 1998 Ivar, _Demo_ and Gary Henderson. - * C4 asm and some C emulation code (c) Copyright 2000 zsKnight and _Demo_. - * C4 C code (c) Copyright 2001 Gary Henderson (gary.henderson@ntlworld.com). - * - * DOS port code contains the works of other authors. See headers in - * individual files. - * - * Snes9x homepage: http://www.snes9x.com - * - * Permission to use, copy, modify and distribute Snes9x in both binary and - * source form, for non-commercial purposes, is hereby granted without fee, - * providing that this license information and copyright notice appear with - * all copies and any derived work. - * - * This software is provided 'as-is', without any express or implied - * warranty. In no event shall the authors be held liable for any damages - * arising from the use of this software. - * - * Snes9x is freeware for PERSONAL USE only. Commercial users should - * seek permission of the copyright holders first. Commercial use includes - * charging money for Snes9x or software derived from Snes9x. - * - * The copyright holders request that bug fixes and improvements to the code - * should be forwarded to them so everyone can benefit from the modifications - * in future versions. - * - * Super NES and Super Nintendo Entertainment System are trademarks of - * Nintendo Co., Limited and its subsidiary companies. - */ -#ifndef _SNAPORIG_H_ -#define _SNAPORIG_H_ - -#define ORIG_SNAPSHOT_MAGIC "#!snes96" -#define ORIG_SNAPSHOT_VERSION 4 - -EXTERN_C bool8_32 S9xLoadOrigSnapshot(const char* filename); - -struct SOrigCPUState -{ - uint32 Flags; - short Cycles_old; - short NextEvent_old; - uint8 CurrentFrame; - uint8 FastROMSpeed_old_old; - uint16 V_Counter_old; - bool8_32 BranchSkip; - bool8_32 NMIActive; - bool8_32 IRQActive; - bool8_32 WaitingForInterrupt; - bool8_32 InDMA; - uint8 WhichEvent; - uint8* PC; - uint8* PCBase; - uint16 MemSpeed_old; - uint16 MemSpeedx2_old; - uint16 FastROMSpeed_old; - bool8_32 FastDP; - uint8* PCAtOpcodeStart; - uint8* WaitAddress; - uint32 WaitCounter; - long Cycles; - long NextEvent; - long V_Counter; - long MemSpeed; - long MemSpeedx2; - long FastROMSpeed; -}; - -struct SOrigAPU -{ - uint32 Cycles; - bool8_32 ShowROM; - uint8 Flags; - uint8 KeyedChannels; - uint8 OutPorts [4]; - uint8 DSP [0x80]; - uint8 ExtraRAM [64]; - uint16 Timer [3]; - uint16 TimerTarget [3]; - bool8_32 TimerEnabled [3]; - bool8_32 TimerValueWritten [3]; -}; - -typedef union -{ -#ifdef MSB_FIRST - struct - { - uint8 Y, A; - } B; -#else - struct - { - uint8 A, Y; - } B; -#endif - uint16 W; -} OrigYAndA; - -struct SOrigAPURegisters -{ - uint8 P; - OrigYAndA YA; - uint8 X; - uint8 S; - uint16 PC; -}; - -#define ORIG_MAX_BUFFER_SIZE (1024 * 4) -#define NUM_CHANNELS 8 - -typedef struct -{ - int state; - int type; - short volume_left; - short volume_right; - int frequency; - int count; - signed short wave [ORIG_MAX_BUFFER_SIZE]; - bool8_32 loop; - int envx; - short left_vol_level; - short right_vol_level; - short envx_target; - unsigned long int env_error; - unsigned long erate; - int direction; - unsigned long attack_rate; - unsigned long decay_rate; - unsigned long sustain_rate; - unsigned long release_rate; - unsigned long sustain_level; - signed short sample; - signed short decoded [16]; - signed short previous [2]; - uint16 sample_number; - bool8_32 last_block; - bool8_32 needs_decode; - uint32 block_pointer; - uint32 sample_pointer; - int* echo_buf_ptr; - int mode; - uint32 dummy [8]; -} OrigChannel; - -typedef struct -{ - short master_volume_left; - short master_volume_right; - short echo_volume_left; - short echo_volume_right; - int echo_enable; - int echo_feedback; - int echo_ptr; - int echo_buffer_size; - int echo_write_enabled; - int echo_channel_enable; - int pitch_mod; - // Just incase they are needed in the future, for snapshot compatibility. - uint32 dummy [3]; - OrigChannel channels [NUM_CHANNELS]; -} SOrigSoundData; - -struct SOrigOBJ -{ - short HPos; - uint16 VPos; - uint16 Name; - uint8 VFlip; - uint8 HFlip; - uint8 Priority; - uint8 Palette; - uint8 Size; - uint8 Prev; - uint8 Next; -}; - -struct SOrigPPU -{ - uint8 BGMode; - uint8 BG3Priority; - uint8 Brightness; - - struct - { - bool8_32 High; - uint8 Increment; - uint16 Address; - uint16 Mask1; - uint16 FullGraphicCount; - uint16 Shift; - } VMA; - - struct - { - uint8 TileSize; - uint16 TileAddress; - uint8 Width; - uint8 Height; - uint16 SCBase; - uint16 VOffset; - uint16 HOffset; - bool8_32 ThroughMain; - bool8_32 ThroughSub; - uint8 BGSize; - uint16 NameBase; - uint16 SCSize; - bool8_32 Addition; - } BG [4]; - - bool8_32 CGFLIP; - uint16 CGDATA [256]; - uint8 FirstSprite; - uint8 LastSprite; - struct SOrigOBJ OBJ [129]; - uint8 OAMPriorityRotation; - uint16 OAMAddr; - - uint8 OAMFlip; - uint16 OAMTileAddress; - uint16 IRQVBeamPos; - uint16 IRQHBeamPos; - uint16 VBeamPosLatched; - uint16 HBeamPosLatched; - - uint8 HBeamFlip; - uint8 VBeamFlip; - uint8 HVBeamCounterLatched; - - short MatrixA; - short MatrixB; - short MatrixC; - short MatrixD; - short CentreX; - short CentreY; - uint8 Joypad1ButtonReadPos; - uint8 Joypad2ButtonReadPos; - - uint8 CGADD; - uint8 FixedColourRed; - uint8 FixedColourGreen; - uint8 FixedColourBlue; - uint16 SavedOAMAddr; - uint16 ScreenHeight; - uint32 WRAM; - uint8 BG_Forced; - bool8_32 ForcedBlanking; - bool8_32 OBJThroughMain; - bool8_32 OBJThroughSub; - uint8 OBJSizeSelect; - uint8 OBJNameSelect_old; - uint16 OBJNameBase; - bool8_32 OBJAddition; - uint8 OAMReadFlip; - uint8 OAMData [512 + 32]; - bool8_32 VTimerEnabled; - bool8_32 HTimerEnabled; - short HTimerPosition; - uint8 Mosaic; - bool8_32 BGMosaic [4]; - bool8_32 Mode7HFlip; - bool8_32 Mode7VFlip; - uint8 Mode7Repeat; - uint8 Window1Left; - uint8 Window1Right; - uint8 Window2Left; - uint8 Window2Right; - uint8 ClipCounts [6]; - uint8 ClipLeftEdges [3][6]; - uint8 ClipRightEdges [3][6]; - uint8 ClipWindowOverlapLogic [6]; - uint8 ClipWindow1Enable [6]; - uint8 ClipWindow2Enable [6]; - bool8_32 ClipWindow1Inside [6]; - bool8_32 ClipWindow2Inside [6]; - bool8_32 RecomputeClipWindows; - uint8 CGFLIPRead; - uint16 OBJNameSelect; - bool8_32 Need16x8Mulitply; - uint8 Joypad3ButtonReadPos; - uint8 MouseSpeed[2]; -}; - -struct SOrigDMA -{ - bool8_32 TransferDirection; - bool8_32 AAddressFixed; - bool8_32 AAddressDecrement; - uint8 TransferMode; - - uint8 ABank; - uint16 AAddress; - uint16 Address; - uint8 BAddress; - - // General DMA only: - uint16 TransferBytes; - - // H-DMA only: - bool8_32 HDMAIndirectAddressing; - uint16 IndirectAddress; - uint8 IndirectBank; - uint8 Repeat; - uint8 LineCount; - uint8 FirstLine; - bool8_32 JustStarted; -}; - -typedef union -{ -#ifdef MSB_FIRST - struct - { - uint8 h, l; - } B; -#else - struct - { - uint8 l, h; - } B; -#endif - uint16 W; -} OrigPair; - -struct SOrigRegisters -{ - uint8 PB; - uint8 DB; - OrigPair P; - OrigPair A; - OrigPair D; - OrigPair S; - OrigPair X; - OrigPair Y; - uint16 PC; -}; - -#endif diff --git a/old/spc700/Makefile b/old/spc700/Makefile deleted file mode 100644 index e412de9..0000000 --- a/old/spc700/Makefile +++ /dev/null @@ -1,13 +0,0 @@ -CFLAGS = -Wall - -all : spc700a.s - -spc700a.s : spcgen - ./spcgen - -spcgen : spcgen.o - - -clean : - $(RM) spc700a.s spcgen spcgen.o - diff --git a/old/spc700/Makefile.win b/old/spc700/Makefile.win deleted file mode 100644 index 06095b0..0000000 --- a/old/spc700/Makefile.win +++ /dev/null @@ -1,15 +0,0 @@ -# Makefile for MS Visual C
-
-ALL : spc700a.s
-
-spc700a.s : spcgen.exe
- spcgen.exe
-
-spcgen.exe :
- cl /W3 spcgen.c
-
-
-CLEAN :
- -@erase spc700a.s
- -@erase spcgen.exe
- -@erase spcgen.obj
diff --git a/old/spc700/debug/apu.h b/old/spc700/debug/apu.h deleted file mode 100644 index dd0451c..0000000 --- a/old/spc700/debug/apu.h +++ /dev/null @@ -1,195 +0,0 @@ -/*
- * Snes9x - Portable Super Nintendo Entertainment System (TM) emulator.
- *
- * (c) Copyright 1996 - 2001 Gary Henderson (gary.henderson@ntlworld.com) and
- * Jerremy Koot (jkoot@snes9x.com)
- *
- * Super FX C emulator code
- * (c) Copyright 1997 - 1999 Ivar (ivar@snes9x.com) and
- * Gary Henderson.
- * Super FX assembler emulator code (c) Copyright 1998 zsKnight and _Demo_.
- *
- * DSP1 emulator code (c) Copyright 1998 Ivar, _Demo_ and Gary Henderson.
- * C4 asm and some C emulation code (c) Copyright 2000 zsKnight and _Demo_.
- * C4 C code (c) Copyright 2001 Gary Henderson (gary.henderson@ntlworld.com).
- *
- * DOS port code contains the works of other authors. See headers in
- * individual files.
- *
- * Snes9x homepage: http://www.snes9x.com
- *
- * Permission to use, copy, modify and distribute Snes9x in both binary and
- * source form, for non-commercial purposes, is hereby granted without fee,
- * providing that this license information and copyright notice appear with
- * all copies and any derived work.
- *
- * This software is provided 'as-is', without any express or implied
- * warranty. In no event shall the authors be held liable for any damages
- * arising from the use of this software.
- *
- * Snes9x is freeware for PERSONAL USE only. Commercial users should
- * seek permission of the copyright holders first. Commercial use includes
- * charging money for Snes9x or software derived from Snes9x.
- *
- * The copyright holders request that bug fixes and improvements to the code
- * should be forwarded to them so everyone can benefit from the modifications
- * in future versions.
- *
- * Super NES and Super Nintendo Entertainment System are trademarks of
- * Nintendo Co., Limited and its subsidiary companies.
- */
-#ifndef _apu_h_
-#define _apu_h_
-
-#include "spc700.h"
-
-/*
-typedef union
-{
- struct { uint8 A, Y; } B;
- uint16 W;
-} YAndA;
-*/
-
-struct SIAPU
-{
- uint8 *DirectPage; // 0x00
- uint32 Address; // 0x04 c core only
- uint8 *WaitAddress1; // 0x08
- uint8 *WaitAddress2; // 0x0C
- uint32 WaitCounter; // 0x10
- uint8 *ShadowRAM; // 0x14
- uint8 *CachedSamples; // 0x18
- uint8 _Carry; // 0x1C c core only
- uint8 _Overflow; // 0x1D c core only
- uint8 Bit; // 0x1E c core only
- uint8 pad0;
- uint32 TimerErrorCounter; // 0x20
- uint32 Scanline; // 0x24
- int32 OneCycle; // 0x28
- int32 TwoCycles; // 0x2C
- // notaz: reordered and moved everything here, for faster context load/save
- uint32 *asmJumpTab; // 0x30
- uint8 *PC; // 0x34
- YAndA YA; // 0x38 0x0000YYAA
- uint8 P; // 0x3C flags: NODBHIZC
- uint8 pad1;
- uint8 pad2;
- uint8 _Zero; // 0x3F Z=0, when this!=0; also stores neg flag in &0x80
- uint8 X; // 0x40
- uint8 S; // 0x41 stack pointer, default: 0xff
- uint16 pad3;
- uint8 *RAM; // 0x44
- uint8 *ExtraRAM; // 0x48 shortcut to APU.ExtraRAM
-
- uint16 memread_addr;
- uint8 memread_data;
- uint16 memwrite_addr;
- uint8 memwrite_data;
- int icount;
- uint8 opcode;
- uint16 ya_prev;
- uint8 x_prev;
-};
-
-struct SAPU
-{
- int32 Cycles;
- bool8 ShowROM;
- uint8 Flags;
- uint8 KeyedChannels;
- uint8 OutPorts [4];
- uint8 DSP [0x80];
- uint8 ExtraRAM [64];
- uint16 Timer [3];
- uint16 TimerTarget [3];
- bool8 TimerEnabled [3];
- bool8 TimerValueWritten [3];
-};
-
-EXTERN_C struct SAPU APU;
-EXTERN_C struct SIAPU IAPU;
-EXTERN_C struct SIAPU IAPU2;
-EXTERN_C struct SIAPU *pIAPU;
-
-STATIC inline void S9xAPUUnpackStatus()
-{
- IAPU._Zero =((IAPU.P & Zero) == 0) | (IAPU.P & Negative);
- IAPU._Carry = (IAPU.P & Carry);
- IAPU._Overflow = (IAPU.P & Overflow);
-}
-
-STATIC inline void S9xAPUPackStatus()
-{
- IAPU.P &= ~(Zero | Negative | Carry | Overflow);
- if(IAPU._Carry) IAPU.P |= Carry;
- if(!IAPU._Zero) IAPU.P |= Zero;
- if(IAPU._Overflow) IAPU.P |= Overflow;
- if(IAPU._Zero & 0x80) IAPU.P |= Negative;
-}
-
-START_EXTERN_C
-void S9xResetAPU (void);
-bool8 S9xInitAPU ();
-void S9xDeinitAPU ();
-void S9xDecacheSamples ();
-int S9xTraceAPU ();
-int S9xAPUOPrint (char *buffer, uint16 Address);
-void S9xSetAPUControl (uint8 byte);
-void S9xSetAPUDSP (uint8 byte);
-uint8 S9xGetAPUDSP ();
-void S9xSetAPUTimer (uint16 Address, uint8 byte);
-bool8 S9xInitSound (int quality, bool8 stereo, int buffer_size);
-void S9xOpenCloseSoundTracingFile (bool8);
-void S9xPrintAPUState ();
-extern int32 S9xAPUCycles [256]; // Scaled cycle lengths
-extern int32 S9xAPUCycleLengths [256]; // Raw data.
-extern void (*S9xApuOpcodes [256]) (void);
-extern void (*S9xApuOpcodesReal [256]) (void);
-void APUCompare();
-END_EXTERN_C
-
-
-#define APU_VOL_LEFT 0x00
-#define APU_VOL_RIGHT 0x01
-#define APU_P_LOW 0x02
-#define APU_P_HIGH 0x03
-#define APU_SRCN 0x04
-#define APU_ADSR1 0x05
-#define APU_ADSR2 0x06
-#define APU_GAIN 0x07
-#define APU_ENVX 0x08
-#define APU_OUTX 0x09
-
-#define APU_MVOL_LEFT 0x0c
-#define APU_MVOL_RIGHT 0x1c
-#define APU_EVOL_LEFT 0x2c
-#define APU_EVOL_RIGHT 0x3c
-#define APU_KON 0x4c
-#define APU_KOFF 0x5c
-#define APU_FLG 0x6c
-#define APU_ENDX 0x7c
-
-#define APU_EFB 0x0d
-#define APU_PMON 0x2d
-#define APU_NON 0x3d
-#define APU_EON 0x4d
-#define APU_DIR 0x5d
-#define APU_ESA 0x6d
-#define APU_EDL 0x7d
-
-#define APU_C0 0x0f
-#define APU_C1 0x1f
-#define APU_C2 0x2f
-#define APU_C3 0x3f
-#define APU_C4 0x4f
-#define APU_C5 0x5f
-#define APU_C6 0x6f
-#define APU_C7 0x7f
-
-#define APU_SOFT_RESET 0x80
-#define APU_MUTE 0x40
-#define APU_ECHO_DISABLED 0x20
-
-#define FREQUENCY_MASK 0x3fff
-#endif
diff --git a/old/spc700/debug/apumem.h b/old/spc700/debug/apumem.h deleted file mode 100644 index 499bd3f..0000000 --- a/old/spc700/debug/apumem.h +++ /dev/null @@ -1,222 +0,0 @@ -/*
- * Snes9x - Portable Super Nintendo Entertainment System (TM) emulator.
- *
- * (c) Copyright 1996 - 2001 Gary Henderson (gary.henderson@ntlworld.com) and
- * Jerremy Koot (jkoot@snes9x.com)
- *
- * Super FX C emulator code
- * (c) Copyright 1997 - 1999 Ivar (ivar@snes9x.com) and
- * Gary Henderson.
- * Super FX assembler emulator code (c) Copyright 1998 zsKnight and _Demo_.
- *
- * DSP1 emulator code (c) Copyright 1998 Ivar, _Demo_ and Gary Henderson.
- * C4 asm and some C emulation code (c) Copyright 2000 zsKnight and _Demo_.
- * C4 C code (c) Copyright 2001 Gary Henderson (gary.henderson@ntlworld.com).
- *
- * DOS port code contains the works of other authors. See headers in
- * individual files.
- *
- * Snes9x homepage: http://www.snes9x.com
- *
- * Permission to use, copy, modify and distribute Snes9x in both binary and
- * source form, for non-commercial purposes, is hereby granted without fee,
- * providing that this license information and copyright notice appear with
- * all copies and any derived work.
- *
- * This software is provided 'as-is', without any express or implied
- * warranty. In no event shall the authors be held liable for any damages
- * arising from the use of this software.
- *
- * Snes9x is freeware for PERSONAL USE only. Commercial users should
- * seek permission of the copyright holders first. Commercial use includes
- * charging money for Snes9x or software derived from Snes9x.
- *
- * The copyright holders request that bug fixes and improvements to the code
- * should be forwarded to them so everyone can benefit from the modifications
- * in future versions.
- *
- * Super NES and Super Nintendo Entertainment System are trademarks of
- * Nintendo Co., Limited and its subsidiary companies.
- */
-#ifndef _apumemory_h_
-#define _apumemory_h_
-
-START_EXTERN_C
-extern uint8 W4;
-extern uint8 APUROM[64];
-END_EXTERN_C
-
-// TODO: restore nondebug version
-
-static INLINE uint8 S9xAPUGetByteZ (uint8 Address)
-{
- uint8 res = 0;
- pIAPU->memread_addr = Address;
-
- if (Address >= 0xf0 && pIAPU->DirectPage == pIAPU->RAM)
- {
- if (Address >= 0xf4 && Address <= 0xf7)
- {
-#ifdef SPC700_SHUTDOWN
- pIAPU->WaitAddress2 = pIAPU->WaitAddress1;
- pIAPU->WaitAddress1 = pIAPU->PC;
-#endif
- res = (pIAPU->RAM [Address]);
- }
- else if (Address >= 0xfd)
- {
-#ifdef SPC700_SHUTDOWN
- pIAPU->WaitAddress2 = pIAPU->WaitAddress1;
- pIAPU->WaitAddress1 = pIAPU->PC;
-#endif
- uint8 t = pIAPU->RAM [Address];
- if(pIAPU != &IAPU)
- pIAPU->RAM [Address] = 0;
- res = (t);
- }
- else if (Address == 0xf3) {
- res = (S9xGetAPUDSP ());
- }
- else res = (pIAPU->RAM [Address]);
- }
- else
- res = (pIAPU->DirectPage [Address]);
-
- pIAPU->memread_data = res;
- return res;
-}
-
-static INLINE void S9xAPUSetByteZ (uint8 val, uint8 Address)
-{
- pIAPU->memwrite_addr = Address;
- pIAPU->memwrite_data = val;
-
- if(pIAPU == &IAPU) return;
-
- if (Address >= 0xf0 && pIAPU->DirectPage == pIAPU->RAM)
- {
- if (Address == 0xf3)
- S9xSetAPUDSP (val);
- else
- if (Address >= 0xf4 && Address <= 0xf7)
- APU.OutPorts [Address - 0xf4] = val;
- else
- if (Address == 0xf1)
- S9xSetAPUControl (val);
- else
- if (Address < 0xfd)
- {
- pIAPU->RAM [Address] = val;
- if (Address >= 0xfa)
- {
- if (val == 0)
- APU.TimerTarget [Address - 0xfa] = 0x100;
- else
- APU.TimerTarget [Address - 0xfa] = val;
- }
- }
- }
- else
- pIAPU->DirectPage [Address] = val;
-}
-
-static INLINE uint8 S9xAPUGetByte (uint32 Address)
-{
- Address &= 0xffff;
- uint8 res = 0;
- pIAPU->memread_addr = Address;
-
- if (Address <= 0xff && Address >= 0xf0)
- {
- if (Address >= 0xf4 && Address <= 0xf7)
- {
-#ifdef SPC700_SHUTDOWN
- pIAPU->WaitAddress2 = pIAPU->WaitAddress1;
- pIAPU->WaitAddress1 = pIAPU->PC;
-#endif
- res = (pIAPU->RAM [Address]);
- }
- else if (Address == 0xf3) {
- res = (S9xGetAPUDSP ());
- }
- else if (Address >= 0xfd)
- {
-#ifdef SPC700_SHUTDOWN
- pIAPU->WaitAddress2 = pIAPU->WaitAddress1;
- pIAPU->WaitAddress1 = pIAPU->PC;
-#endif
- uint8 t = pIAPU->RAM [Address];
- if(pIAPU != &IAPU)
- pIAPU->RAM [Address] = 0;
- res = (t);
- }
- else res = (pIAPU->RAM [Address]);
- }
- else
- res = (pIAPU->RAM [Address]);
-
- pIAPU->memread_data = res;
- return res;
-}
-
-static INLINE void S9xAPUSetByte (uint8 val, uint32 Address)
-{
- Address &= 0xffff;
- pIAPU->memwrite_addr = Address;
- pIAPU->memwrite_data = val;
-
- if(pIAPU == &IAPU) return;
-
- if (Address <= 0xff && Address >= 0xf0)
- {
- if (Address == 0xf3)
- S9xSetAPUDSP (val);
- else
- if (Address >= 0xf4 && Address <= 0xf7)
- APU.OutPorts [Address - 0xf4] = val;
- else
- if (Address == 0xf1)
- S9xSetAPUControl (val);
- else
- if (Address < 0xfd)
- {
- pIAPU->RAM [Address] = val;
- if (Address >= 0xfa)
- {
- if (val == 0)
- APU.TimerTarget [Address - 0xfa] = 0x100;
- else
- APU.TimerTarget [Address - 0xfa] = val;
- }
- }
- }
- else
- {
-#if 0
-if (Address >= 0x2500 && Address <= 0x2504)
-printf ("%06d %04x <- %02x\n", ICPU.Scanline, Address, val);
-if (Address == 0x26c6)
-{
- extern FILE *apu_trace;
- extern FILE *trace;
- APU.Flags |= TRACE_FLAG;
- CPU.Flags |= TRACE_FLAG;
- if (apu_trace == NULL)
- apu_trace = fopen ("aputrace.log", "wb");
- if (trace == NULL)
- trace = fopen ("trace.log", "wb");
- printf ("TRACING SWITCHED ON\n");
-}
-#endif
- if (Address < 0xffc0)
- pIAPU->RAM [Address] = val;
- else
- {
- APU.ExtraRAM [Address - 0xffc0] = val;
- if (!APU.ShowROM)
- pIAPU->RAM [Address] = val;
- }
- }
-}
-
-#endif
diff --git a/old/spc700/debug/port.h b/old/spc700/debug/port.h deleted file mode 100644 index e7c3e8e..0000000 --- a/old/spc700/debug/port.h +++ /dev/null @@ -1,488 +0,0 @@ -/*
- * Snes9x - Portable Super Nintendo Entertainment System (TM) emulator.
- *
- * (c) Copyright 1996 - 2001 Gary Henderson (gary.henderson@ntlworld.com) and
- * Jerremy Koot (jkoot@snes9x.com)
- *
- * Super FX C emulator code
- * (c) Copyright 1997 - 1999 Ivar (ivar@snes9x.com) and
- * Gary Henderson.
- * Super FX assembler emulator code (c) Copyright 1998 zsKnight and _Demo_.
- *
- * DSP1 emulator code (c) Copyright 1998 Ivar, _Demo_ and Gary Henderson.
- * C4 asm and some C emulation code (c) Copyright 2000 zsKnight and _Demo_.
- * C4 C code (c) Copyright 2001 Gary Henderson (gary.henderson@ntlworld.com).
- *
- * DOS port code contains the works of other authors. See headers in
- * individual files.
- *
- * Snes9x homepage: http://www.snes9x.com
- *
- * Permission to use, copy, modify and distribute Snes9x in both binary and
- * source form, for non-commercial purposes, is hereby granted without fee,
- * providing that this license information and copyright notice appear with
- * all copies and any derived work.
- *
- * This software is provided 'as-is', without any express or implied
- * warranty. In no event shall the authors be held liable for any damages
- * arising from the use of this software.
- *
- * Snes9x is freeware for PERSONAL USE only. Commercial users should
- * seek permission of the copyright holders first. Commercial use includes
- * charging money for Snes9x or software derived from Snes9x.
- *
- * The copyright holders request that bug fixes and improvements to the code
- * should be forwarded to them so everyone can benefit from the modifications
- * in future versions.
- *
- * Super NES and Super Nintendo Entertainment System are trademarks of
- * Nintendo Co., Limited and its subsidiary companies.
- */
-#ifndef _PORT_H_
-#define _PORT_H_
-
-
-// horrible mess here
-
-int yo_rand(void);
-
-#ifdef __SYMBIAN32__
-
-// debug
-#ifdef __DEBUG_PRINT
-#undef printf
-extern "C" void dprintf(char *format, ...);
-#define printf dprintf
-#else
-#define printf(x...)
-#define dprintf(x...)
-#endif
-
-#include <string.h>
-
-#define PIXEL_FORMAT RGB565
-#undef GFX_MULTI_FORMAT
-
-#ifndef snes9x_types_defined
-#define snes9x_types_defined
-
-typedef unsigned char bool8;
-typedef unsigned char uint8;
-typedef unsigned short uint16;
-typedef signed char int8;
-typedef signed short int16;
-typedef signed int int32;
-typedef unsigned int uint32;
-typedef long long int64; // correct?
-#endif
-
-#include "pixform.h"
-
-#ifndef TRUE
-#define TRUE 1
-#endif
-
-#ifndef FALSE
-#define FALSE 0
-#endif
-
-#if defined(__cplusplus) || defined(c_plusplus)
-#define EXTERN_C extern "C"
-#define START_EXTERN_C extern "C" {
-#define END_EXTERN_C }
-#else
-#define EXTERN_C extern
-#define START_EXTERN_C
-#define END_EXTERN_C
-#endif
-
-
-#ifndef PATH_MAX
-#define PATH_MAX 0x100 // == KMaxFileName
-#endif
-
-/*
-#define _MAX_DIR PATH_MAX
-#define _MAX_DRIVE 1
-#define _MAX_FNAME PATH_MAX
-#define _MAX_EXT 3
-*/
-#define _MAX_PATH PATH_MAX
-
-
-#define ZeroMemory(a,b) memset((a),0,(b))
-
-EXTERN_C void S9xGenerateSound ();
-
-#define SLASH_STR "\\"
-#define SLASH_CHAR '\\'
-
-#define STATIC static
-#define FASTCALL
-#define INLINE inline
-#define VOID void
-#define PACKING __attribute__ ((packed))
-#define ALIGN_BY_ONE __attribute__ ((aligned (1), packed))
-#define gp32_pause()
-#define gm_memset memset
-#define CHECK_SOUND()
-#define CPU_SHUTDOWN
-#define VAR_CYCLES
-#define SPC700_C
-#define EXECUTE_SUPERFX_PER_LINE
-#define OLD_COLOUR_BLENDING
-#define _NEWPPU_
-#define gp32_atoi atoi
-//#define SPC700_SHUTDOWN // incompatible with ASM_SPC700
-// notaz
-//#define ASM_SPC700
-#define SUPER_FX
-
-#ifndef TITLE
-#define TITLE "Snes9x"
-#endif
-
-
-#else // __SYMBIAN32__
-
-
-//#include <limits.h>
-
-#ifdef __GP32__
-
-
-//#define __GP32_APUCACHE__
-
-#define CHECK_SOUND()
-
-#define VERSION_MAJOR 0
-#define VERSION_MINOR 3
-
-long *gp32_fopen (char *fname,char *mode);
-void gp32_fclose (long *s);
-long gp32_fread (unsigned char *ptr,long lg,long *s);
-long gp32_fwrite (unsigned char *ptr,long lg,long *s);
-void gp32_fseek (long position,int ref,long *s);
-
-
-//#undef ZLIB
-//#define ZLIB
-//#define UNZIP_SUPPORT
-
-
-#define SPC700_SHUTDOWN
-#define CPU_SHUTDOWN
-#define VAR_CYCLES
-#define SPC700_C
-#define EXECUTE_SUPERFX_PER_LINE
-//#define THREADCPU
-
-
-//#define NETPLAY_SUPPORT
-#define OLD_COLOUR_BLENDING
-
-#endif // __GP32__
-
-#ifndef STORM
-#ifdef __GP32__
-
-extern "C"
-{
-#include "gpdef.h"
-#include "gpstdlib.h"
-#include "gpgraphic.h"
-#include "gpfont.h"
-#include "gpmm.h"
-#include "gpmem.h"
-#include "gpstdio.h"
-}
-
-#undef byte
-#undef word
-#undef dword
-#undef qword
-
-/*typedef unsigned long bool8_32;
-typedef unsigned long uint8_32;
-typedef unsigned long uint16_32;
-typedef long int8_32;
-typedef long int16_32;*/
-
-#undef time_t
-#define time_t long
-
-char *gp32_strrchr(char *s, char c);
-char gp32_toupper(char c);
-char *gp32_strupr(char *s);
-char *gp32_strlwr(char *s);
-int gp32_memcmp(char *s1,char *s2, int lg);
-int gp32_strncmp(char *s1,char *s2, int lg);
-int gp32_strcasecmp(const char *s1, const char *s2 );
-int gp32_strncasecmp(const char *s1, const char *s2, unsigned n);
-long gp32_time(void);
-int gp32_pause(void);
-int gp32_atoi(char *s);
-
-#define malloc gm_malloc
-#define free gm_free
-#define memcpy gm_memcpy
-
-#define strcpy gm_strcpy
-#define strncpy gm_strncpy
-#define strcat gm_strcat
-#define memset gm_memset
-#define memmove gm_memcpy
-#define strlen gm_lstrlen
-#define strcmp gm_compare
-#define memcmp(a,b,c) gp32_memcmp((char*)a,(char*)b,c)
-#define strrchr(a,b) gp32_strrchr((char*)a,(char)b)
-#define strncmp(a,b,c) gp32_strncmp((char*)a,(char*)b,(int)c)
-#define strlwr gp32_strlwr
-//#define atoi gp32_atoi
-
-#define islower(a) ((a>='a')&&(a<='z'))
-#define isdigit(a) ((a>='0')&&(a<='9'))
-#define isalpha(a) (((a>='0')&&(a<='9'))||((a>='0')&&(a<='9'))||((a>='A')&&(a<='Z')))
-#define toupper(a) (islower(a)?a+'A'-'a':a)
-
-#define sprintf gm_sprintf
-
-
-
-void gp32_printf(char *a);
-void gp32_GpTextOut(unsigned char *buffer,int X,int Y,char *A,int col,int bold);
-void gp32_GpTextOutBig(unsigned char *buffer,int X,int Y,char *A,int col,int bold);
-#define printf //(a) gp32_printf(a)
-
-#define strcasecmp gp32_strcasecmp
-#define strncasecmp gp32_strncasecmp
-
-#define time(a) gp32_time()
-
-#define _NEWPPU_
-
-//#define PROFILING
-
-#ifdef PROFILING
-void gp32_profile_start(int a);
-void gp32_profile_end(int a);
-#define PROF_START(a) gp32_profile_start(a)
-#define PROF_END(a) gp32_profile_end(a)
-#endif
-
-#elif defined(__SYMBIAN32__) // /__GP32__
-#include <string.h>
-#else
-#include <memory.h>
-#include <string.h>
-#endif
-#else // #ifndef STORM
-#include <strings.h>
-#include <clib/powerpc_protos.h>
-#endif
-
-//#include <sys/types.h>
-
-#define PIXEL_FORMAT RGB565
-#undef GFX_MULTI_FORMAT
-
-#if defined(TARGET_OS_MAC) && TARGET_OS_MAC
-
-#include "zlib.h"
-#define ZLIB
-#define EXECUTE_SUPERFX_PER_LINE
-#define SOUND
-#define VAR_CYCLES
-#define CPU_SHUTDOWN
-#define SPC700_SHUTDOWN
-#define PIXEL_FORMAT RGB555
-#define CHECK_SOUND()
-#define M_PI 3.14159265359
-#undef _MAX_PATH
-
-#undef DEBUGGER // Apple Universal Headers sometimes #define DEBUGGER
-#undef GFX_MULTI_FORMAT
-
-int strncasecmp(const char *s1, const char *s2, unsigned n);
-int strcasecmp(const char *s1, const char *s2 );
-
-#endif
-
-#ifndef snes9x_types_defined
-#define snes9x_types_defined
-
-typedef unsigned char bool8;
-
-#ifndef __WIN32kk__
-typedef unsigned char uint8;
-typedef unsigned short uint16;
-typedef signed char int8;
-typedef signed short int16;
-typedef signed int int32;
-typedef unsigned int uint32;
-#ifdef __GP32__
-typedef signed __int64 int64;
-//typedef signed long int64;
-#else
-typedef long long int64;
-#endif
-#else // __WIN32kk__
-
-#ifdef __BORLANDC__
-#include <systypes.h>
-#else
-
-typedef unsigned char uint8;
-typedef unsigned short uint16;
-typedef signed char int8;
-typedef short int16;
-
-#ifndef WSAAPI
-// winsock2.h typedefs int32 as well.
-typedef long int32;
-#endif
-
-typedef unsigned int uint32;
-
-#endif // __BORLANDC__
-
-typedef __int64 int64;
-
-#endif // __WIN32kk__
-#endif // snes9x_types_defined
-#include "pixform.h"
-
-#ifndef TRUE
-#define TRUE 1
-#endif
-
-#ifndef FALSE
-#define FALSE 0
-#endif
-
-#ifdef STORM
-#define EXTERN_C
-#define START_EXTERN_C
-#define END_EXTERN_C
-#else
-#if defined(__cplusplus) || defined(c_plusplus)
-#define EXTERN_C extern "C"
-#define START_EXTERN_C extern "C" {
-#define END_EXTERN_C }
-#else
-#define EXTERN_C extern
-#define START_EXTERN_C
-#define END_EXTERN_C
-#endif
-#endif
-
-#ifndef __WIN32kk__
-
-#ifndef PATH_MAX
-#define PATH_MAX 1024
-#endif
-
-#define _MAX_DIR PATH_MAX
-#define _MAX_DRIVE 1
-#define _MAX_FNAME PATH_MAX
-#define _MAX_EXT PATH_MAX
-#define _MAX_PATH PATH_MAX
-
-#define ZeroMemory(a,b) memset((a),0,(b))
-
-#ifndef __WIN32__
-void _makepath (char *path, const char *drive, const char *dir, const char *fname, const char *ext);
-void _splitpath (const char *path, char *drive, char *dir, char *fname, char *ext);
-#endif
-
-#else // __WIN32kk__
-#define strcasecmp stricmp
-#define strncasecmp strnicmp
-#endif
-
-EXTERN_C void S9xGenerateSound ();
-
-#ifdef STORM
-EXTERN_C int soundsignal;
-EXTERN_C void MixSound(void);
-//Yes, CHECK_SOUND is getting defined correctly!
-#define CHECK_SOUND if (Settings.APUEnabled) if(SetSignalPPC(0L, soundsignal) & soundsignal) MixSound
-#else
-#ifndef __GP32__
-#define CHECK_SOUND()
-#endif
-#endif
-
-#if defined (__DJGPP)||defined(__GP32__)
-#define SLASH_STR "\\"
-#define SLASH_CHAR '\\'
-#else
-#define SLASH_STR "/"
-#define SLASH_CHAR '/'
-#endif
-
-#ifdef __linux
-typedef void (*SignalHandler)(int);
-#define SIG_PF SignalHandler
-#endif
-
-#if defined(__i386__) || defined(__i486__) || defined(__i586__) || \
- defined(__WIN32kk__) || defined(__alpha__)
-#define FAST_LSB_WORD_ACCESS
-#define PACKING
-#define ALIGN_BY_ONE
-
-#else
-
-#ifdef __GP32__
-#define STATIC static
-#define FASTCALL
-#define INLINE inline
-#define VOID void
-#else
-// must be gp2x
-#define STATIC static
-#define FASTCALL
-#define INLINE inline
-#define VOID void
-#define PACKING __attribute__ ((packed))
-#define ALIGN_BY_ONE __attribute__ ((aligned (1), packed))
-#define gp32_pause()
-#define gm_memset memset
-#define CHECK_SOUND()
-#define VERSION_MAJOR 0
-#define VERSION_MINOR 3
-#define SPC700_SHUTDOWN
-#define CPU_SHUTDOWN
-#define VAR_CYCLES
-#define SPC700_C
-#define EXECUTE_SUPERFX_PER_LINE
-#define OLD_COLOUR_BLENDING
-#define _NEWPPU_
-#define gp32_atoi atoi
-#endif
-
-#endif
-
-#ifdef __sun
-#define TITLE "Snes9X: Solaris"
-#endif
-
-#ifdef __linux
-#define TITLE "Snes9X: Linux"
-#endif
-
-#ifndef TITLE
-#define TITLE "Snes9x"
-#endif
-
-#ifdef STORM
-#define STATIC
-#define strncasecmp strnicmp
-#else
-#define STATIC static
-#endif
-
-#endif // !defined(__SYMBIAN32__)
-
-#endif // _PORT_H_
diff --git a/old/spc700/debug/spc700.cpp b/old/spc700/debug/spc700.cpp deleted file mode 100644 index 5ab21ab..0000000 --- a/old/spc700/debug/spc700.cpp +++ /dev/null @@ -1,2600 +0,0 @@ -/*
- * Snes9x - Portable Super Nintendo Entertainment System (TM) emulator.
- *
- * (c) Copyright 1996 - 2001 Gary Henderson (gary.henderson@ntlworld.com) and
- * Jerremy Koot (jkoot@snes9x.com)
- *
- * Super FX C emulator code
- * (c) Copyright 1997 - 1999 Ivar (ivar@snes9x.com) and
- * Gary Henderson.
- * Super FX assembler emulator code (c) Copyright 1998 zsKnight and _Demo_.
- *
- * DSP1 emulator code (c) Copyright 1998 Ivar, _Demo_ and Gary Henderson.
- * C4 asm and some C emulation code (c) Copyright 2000 zsKnight and _Demo_.
- * C4 C code (c) Copyright 2001 Gary Henderson (gary.henderson@ntlworld.com).
- *
- * DOS port code contains the works of other authors. See headers in
- * individual files.
- *
- * Snes9x homepage: http://www.snes9x.com
- *
- * Permission to use, copy, modify and distribute Snes9x in both binary and
- * source form, for non-commercial purposes, is hereby granted without fee,
- * providing that this license information and copyright notice appear with
- * all copies and any derived work.
- *
- * This software is provided 'as-is', without any express or implied
- * warranty. In no event shall the authors be held liable for any damages
- * arising from the use of this software.
- *
- * Snes9x is freeware for PERSONAL USE only. Commercial users should
- * seek permission of the copyright holders first. Commercial use includes
- * charging money for Snes9x or software derived from Snes9x.
- *
- * The copyright holders request that bug fixes and improvements to the code
- * should be forwarded to them so everyone can benefit from the modifications
- * in future versions.
- *
- * Super NES and Super Nintendo Entertainment System are trademarks of
- * Nintendo Co., Limited and its subsidiary companies.
- */
-#include "snes9x.h"
-#include "memmap.h"
-#include "display.h"
-#include "cpuexec.h"
-#include "apu.h"
-#include "spc700.h"
-
-// SPC700/Sound DSP chips have a 24.57MHz crystal on their PCB.
-
-//#if defined(ASM_SPC700)
-extern "C" {
-uint8 S9xAPUGetByteZ (uint8 address);
-uint8 S9xAPUGetByte (uint32 address);
-void S9xAPUSetByteZ (uint8, uint8 address);
-void S9xAPUSetByte (uint8, uint32 address);
-}
-/*
-#elif defined(NO_INLINE_SET_GET)
-uint8 S9xAPUGetByteZ (uint8 address);
-uint8 S9xAPUGetByte (uint32 address);
-void S9xAPUSetByteZ (uint8, uint8 address);
-void S9xAPUSetByte (uint8, uint32 address);
-
-#else
-#undef INLINE
-#define INLINE inline
-#include "apumem.h"
-#endif
-*/
-
-START_EXTERN_C
-extern uint8 Work8;
-extern uint16 Work16;
-extern uint32 Work32;
-extern signed char Int8;
-extern short Int16;
-extern long Int32;
-extern short Int16;
-extern uint8 W1;
-extern uint8 W2;
-
-END_EXTERN_C
-
-#define OP1 (*(pIAPU->PC + 1))
-#define OP2 (*(pIAPU->PC + 2))
-
-#ifdef SPC700_SHUTDOWN
-#define APUShutdown() \
- if (Settings.Shutdown && (pIAPU->PC == pIAPU->WaitAddress1 || pIAPU->PC == pIAPU->WaitAddress2)) \
- { \
- if (pIAPU->WaitCounter == 0) \
- { \
- if (!ICPU.CPUExecuting) \
- CPU.APU_Cycles = CPU.Cycles = CPU.NextEvent; \
- else \
- CPU.APU_APUExecuting = FALSE; \
- } \
- else \
- if (pIAPU->WaitCounter >= 2) \
- pIAPU->WaitCounter = 1; \
- else \
- pIAPU->WaitCounter--; \
- }
-#else
-#define APUShutdown()
-#endif
-
-#define APUSetZN8(b)\
- pIAPU->_Zero = (b);
-
-#define APUSetZN16(w)\
- pIAPU->_Zero = ((w) != 0) | ((w) >> 8);
-
-void STOP (char *s)
-{
- char buffer[100];
-
-#ifdef DEBUGGER
- S9xAPUOPrint (buffer, pIAPU->PC - pIAPU->RAM);
-#endif
-
- sprintf (String, "Sound CPU in unknown state executing %s at %04lX\n%s\n", s, pIAPU->PC - pIAPU->RAM, buffer);
- S9xMessage (S9X_ERROR, S9X_APU_STOPPED, String);
- APU.TimerEnabled[0] = APU.TimerEnabled[1] = APU.TimerEnabled[2] = FALSE;
- CPU.APU_APUExecuting = FALSE;
-
-#ifdef DEBUGGER
- CPU.Flags |= DEBUG_MODE_FLAG;
-#else
- S9xExit ();
-#endif
-}
-
-#define TCALL(n)\
-{\
- PushW ((pIAPU->PC - pIAPU->RAM + 1)); \
- pIAPU->PC = pIAPU->RAM + (APU.ExtraRAM [((15 - n) << 1)] + \
- (APU.ExtraRAM [((15 - n) << 1) + 1] << 8)); \
-}
-
-// XXX: HalfCarry - BJ fixed?
-#define SBC(a,b)\
-Int16 = (short) (a) - (short) (b) + (short) (APUCheckCarry ()) - 1;\
-pIAPU->_Carry = Int16 >= 0;\
-if ((((a) ^ (b)) & 0x80) && (((a) ^ (uint8) Int16) & 0x80))\
- APUSetOverflow ();\
-else \
- APUClearOverflow (); \
-APUSetHalfCarry ();\
-if(((a) ^ (b) ^ (uint8) Int16) & 0x10)\
- APUClearHalfCarry ();\
-(a) = (uint8) Int16;\
-APUSetZN8 ((uint8) Int16);
-
-// XXX: HalfCarry - BJ fixed?
-#define ADC(a,b)\
-Work16 = (a) + (b) + APUCheckCarry();\
-pIAPU->_Carry = Work16 >= 0x100; \
-if (~((a) ^ (b)) & ((b) ^ (uint8) Work16) & 0x80)\
- APUSetOverflow ();\
-else \
- APUClearOverflow (); \
-APUClearHalfCarry ();\
-/*if(((a) ^ (b) ^ (uint8) Int16) & 0x10) notaz: Int16!? */\
-if(((a) ^ (b) ^ (uint8) Work16) & 0x10)\
- APUSetHalfCarry ();\
-(a) = (uint8) Work16;\
-APUSetZN8 ((uint8) Work16);
-
-#define CMP(a,b)\
-Int16 = (short) (a) - (short) (b);\
-pIAPU->_Carry = Int16 >= 0;\
-APUSetZN8 ((uint8) Int16);
-
-#define ASL(b)\
- pIAPU->_Carry = ((b) & 0x80) != 0; \
- (b) <<= 1;\
- APUSetZN8 (b);
-#define LSR(b)\
- pIAPU->_Carry = (b) & 1;\
- (b) >>= 1;\
- APUSetZN8 (b);
-#define ROL(b)\
- Work16 = ((b) << 1) | APUCheckCarry (); \
- pIAPU->_Carry = Work16 >= 0x100; \
- (b) = (uint8) Work16; \
- APUSetZN8 (b);
-#define ROR(b)\
- Work16 = (b) | ((uint16) APUCheckCarry () << 8); \
- pIAPU->_Carry = (uint8) Work16 & 1; \
- Work16 >>= 1; \
- (b) = (uint8) Work16; \
- APUSetZN8 (b);
-
-#define Push(b)\
- *(pIAPU->RAM + 0x100 + pIAPU->S) = b;\
- pIAPU->S--;
-
-#define Pop(b)\
- pIAPU->S++;\
- (b) = *(pIAPU->RAM + 0x100 + pIAPU->S);
-
-#ifdef FAST_LSB_WORD_ACCESS
-#define PushW(w)\
- *(uint16 *) (pIAPU->RAM + 0xff + pIAPU->S) = w;\
- pIAPU->S -= 2;
-#define PopW(w)\
- pIAPU->S += 2;\
- w = *(uint16 *) (pIAPU->RAM + 0xff + pIAPU->S);
-#else
-#define PushW(w)\
- *(pIAPU->RAM + 0xff + pIAPU->S) = w;\
- *(pIAPU->RAM + 0x100 + pIAPU->S) = (w >> 8);\
- pIAPU->S -= 2;
-#define PopW(w)\
- pIAPU->S += 2; \
- (w) = *(pIAPU->RAM + 0xff + pIAPU->S) + (*(pIAPU->RAM + 0x100 + pIAPU->S) << 8);
-#endif
-
-#define Relative()\
- Int8 = OP1;\
- Int16 = (int) (pIAPU->PC + 2 - pIAPU->RAM) + Int8;
-
-#define Relative2()\
- Int8 = OP2;\
- Int16 = (int) (pIAPU->PC + 3 - pIAPU->RAM) + Int8;
-
-#ifdef FAST_LSB_WORD_ACCESS
-#define IndexedXIndirect()\
- pIAPU->Address = *(uint16 *) (pIAPU->DirectPage + ((OP1 + pIAPU->X) & 0xff));
-
-#define Absolute()\
- pIAPU->Address = *(uint16 *) (pIAPU->PC + 1);
-
-#define AbsoluteX()\
- pIAPU->Address = *(uint16 *) (pIAPU->PC + 1) + pIAPU->X;
-
-#define AbsoluteY()\
- pIAPU->Address = *(uint16 *) (pIAPU->PC + 1) + pIAPU->YA.B.Y;
-
-#define MemBit()\
- pIAPU->Address = *(uint16 *) (pIAPU->PC + 1);\
- pIAPU->Bit = (uint8)(pIAPU->Address >> 13);\
- pIAPU->Address &= 0x1fff;
-
-#define IndirectIndexedY()\
- pIAPU->Address = *(uint16 *) (pIAPU->DirectPage + OP1) + pIAPU->YA.B.Y;
-#else
-#define IndexedXIndirect()\
- pIAPU->Address = *(pIAPU->DirectPage + ((OP1 + pIAPU->X) & 0xff)) + \
- (*(pIAPU->DirectPage + ((OP1 + pIAPU->X + 1) & 0xff)) << 8);
-#define Absolute()\
- pIAPU->Address = OP1 + (OP2 << 8);
-
-#define AbsoluteX()\
- pIAPU->Address = OP1 + (OP2 << 8) + pIAPU->X;
-
-#define AbsoluteY()\
- pIAPU->Address = OP1 + (OP2 << 8) + pIAPU->YA.B.Y;
-
-#define MemBit()\
- pIAPU->Address = OP1 + (OP2 << 8);\
- pIAPU->Bit = (int8) (pIAPU->Address >> 13);\
- pIAPU->Address &= 0x1fff;
-
-#define IndirectIndexedY()\
- pIAPU->Address = *(pIAPU->DirectPage + OP1) + \
- (*(pIAPU->DirectPage + OP1 + 1) << 8) + \
- pIAPU->YA.B.Y;
-#endif
-
-void Apu00 ()
-{
-// NOP
- pIAPU->PC++;
-}
-
-void Apu01 () { TCALL (0) }
-
-void Apu11 () { TCALL (1) }
-
-void Apu21 () { TCALL (2) }
-
-void Apu31 () { TCALL (3) }
-
-void Apu41 () { TCALL (4) }
-
-void Apu51 () { TCALL (5) }
-
-void Apu61 () { TCALL (6) }
-
-void Apu71 () { TCALL (7) }
-
-void Apu81 () { TCALL (8) }
-
-void Apu91 () { TCALL (9) }
-
-void ApuA1 () { TCALL (10) }
-
-void ApuB1 () { TCALL (11) }
-
-void ApuC1 () { TCALL (12) }
-
-void ApuD1 () { TCALL (13) }
-
-void ApuE1 () { TCALL (14) }
-
-void ApuF1 () { TCALL (15) }
-
-void Apu3F () // CALL absolute
-{
- Absolute ();
- // 0xB6f for Star Fox 2
- PushW ((pIAPU->PC + 3 - pIAPU->RAM));
- pIAPU->PC = pIAPU->RAM + pIAPU->Address;
-}
-
-void Apu4F () // PCALL $XX
-{
- Work8 = OP1;
- PushW ((pIAPU->PC + 2 - pIAPU->RAM));
- pIAPU->PC = pIAPU->RAM + 0xff00 + Work8;
-}
-
-#define SET(b) \
-S9xAPUSetByteZ ((uint8) (S9xAPUGetByteZ (OP1 ) | (1 << (b))), OP1); \
-pIAPU->PC += 2
-
-void Apu02 ()
-{
- SET (0);
-}
-
-void Apu22 ()
-{
- SET (1);
-}
-
-void Apu42 ()
-{
- SET (2);
-}
-
-void Apu62 ()
-{
- SET (3);
-}
-
-void Apu82 ()
-{
- SET (4);
-}
-
-void ApuA2 ()
-{
- SET (5);
-}
-
-void ApuC2 ()
-{
- SET (6);
-}
-
-void ApuE2 ()
-{
- SET (7);
-}
-
-#define CLR(b) \
-S9xAPUSetByteZ ((uint8) (S9xAPUGetByteZ (OP1) & ~(1 << (b))), OP1); \
-pIAPU->PC += 2;
-
-void Apu12 ()
-{
- CLR (0);
-}
-
-void Apu32 ()
-{
- CLR (1);
-}
-
-void Apu52 ()
-{
- CLR (2);
-}
-
-void Apu72 ()
-{
- CLR (3);
-}
-
-void Apu92 ()
-{
- CLR (4);
-}
-
-void ApuB2 ()
-{
- CLR (5);
-}
-
-void ApuD2 ()
-{
- CLR (6);
-}
-
-void ApuF2 ()
-{
- CLR (7);
-}
-
-#define BBS(b) \
-Work8 = OP1; \
-Relative2 (); \
-if (S9xAPUGetByteZ (Work8) & (1 << (b))) \
-{ \
- pIAPU->PC = pIAPU->RAM + (uint16) Int16; \
- CPU.APU_Cycles += pIAPU->TwoCycles; \
-} \
-else \
- pIAPU->PC += 3
-
-void Apu03 ()
-{
- BBS (0);
-}
-
-void Apu23 ()
-{
- BBS (1);
-}
-
-void Apu43 ()
-{
- BBS (2);
-}
-
-void Apu63 ()
-{
- BBS (3);
-}
-
-void Apu83 ()
-{
- BBS (4);
-}
-
-void ApuA3 ()
-{
- BBS (5);
-}
-
-void ApuC3 ()
-{
- BBS (6);
-}
-
-void ApuE3 ()
-{
- BBS (7);
-}
-
-#define BBC(b) \
-Work8 = OP1; \
-Relative2 (); \
-if (!(S9xAPUGetByteZ (Work8) & (1 << (b)))) \
-{ \
- pIAPU->PC = pIAPU->RAM + (uint16) Int16; \
- CPU.APU_Cycles += pIAPU->TwoCycles; \
-} \
-else \
- pIAPU->PC += 3
-
-void Apu13 ()
-{
- BBC (0);
-}
-
-void Apu33 ()
-{
- BBC (1);
-}
-
-void Apu53 ()
-{
- BBC (2);
-}
-
-void Apu73 ()
-{
- BBC (3);
-}
-
-void Apu93 ()
-{
- BBC (4);
-}
-
-void ApuB3 ()
-{
- BBC (5);
-}
-
-void ApuD3 ()
-{
- BBC (6);
-}
-
-void ApuF3 ()
-{
- BBC (7);
-}
-
-void Apu04 ()
-{
-// OR A,dp
- pIAPU->YA.B.A |= S9xAPUGetByteZ (OP1);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void Apu05 ()
-{
-// OR A,abs
- Absolute ();
- pIAPU->YA.B.A |= S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 3;
-}
-
-void Apu06 ()
-{
-// OR A,(X)
- pIAPU->YA.B.A |= S9xAPUGetByteZ (pIAPU->X);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC++;
-}
-
-void Apu07 ()
-{
-// OR A,(dp+X)
- IndexedXIndirect ();
- pIAPU->YA.B.A |= S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void Apu08 ()
-{
-// OR A,#00
- pIAPU->YA.B.A |= OP1;
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void Apu09 ()
-{
-// OR dp(dest),dp(src)
- Work8 = S9xAPUGetByteZ (OP1);
- Work8 |= S9xAPUGetByteZ (OP2);
- S9xAPUSetByteZ (Work8, OP2);
- APUSetZN8 (Work8);
- pIAPU->PC += 3;
-}
-
-void Apu14 ()
-{
-// OR A,dp+X
- pIAPU->YA.B.A |= S9xAPUGetByteZ (OP1 + pIAPU->X);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void Apu15 ()
-{
-// OR A,abs+X
- AbsoluteX ();
- pIAPU->YA.B.A |= S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 3;
-}
-
-void Apu16 ()
-{
-// OR A,abs+Y
- AbsoluteY ();
- pIAPU->YA.B.A |= S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 3;
-}
-
-void Apu17 ()
-{
-// OR A,(dp)+Y
- IndirectIndexedY ();
- pIAPU->YA.B.A |= S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void Apu18 ()
-{
-// OR dp,#00
- Work8 = OP1;
- Work8 |= S9xAPUGetByteZ (OP2);
- S9xAPUSetByteZ (Work8, OP2);
- APUSetZN8 (Work8);
- pIAPU->PC += 3;
-}
-
-void Apu19 ()
-{
-// OR (X),(Y)
- Work8 = S9xAPUGetByteZ (pIAPU->X) | S9xAPUGetByteZ (pIAPU->YA.B.Y);
- APUSetZN8 (Work8);
- S9xAPUSetByteZ (Work8, pIAPU->X);
- pIAPU->PC++;
-}
-
-void Apu0A ()
-{
-// OR1 C,membit
- MemBit ();
- if (!APUCheckCarry ())
- {
- if (S9xAPUGetByte (pIAPU->Address) & (1 << pIAPU->Bit))
- APUSetCarry ();
- }
- pIAPU->PC += 3;
-}
-
-void Apu2A ()
-{
-// OR1 C,not membit
- MemBit ();
- if (!APUCheckCarry ())
- {
- if (!(S9xAPUGetByte (pIAPU->Address) & (1 << pIAPU->Bit)))
- APUSetCarry ();
- }
- pIAPU->PC += 3;
-}
-
-void Apu4A ()
-{
-// AND1 C,membit
- MemBit ();
- if (APUCheckCarry ())
- {
- if (!(S9xAPUGetByte (pIAPU->Address) & (1 << pIAPU->Bit)))
- APUClearCarry ();
- }
- pIAPU->PC += 3;
-}
-
-void Apu6A ()
-{
-// AND1 C, not membit
- MemBit ();
- if (APUCheckCarry ())
- {
- if ((S9xAPUGetByte (pIAPU->Address) & (1 << pIAPU->Bit)))
- APUClearCarry ();
- }
- pIAPU->PC += 3;
-}
-
-void Apu8A ()
-{
-// EOR1 C, membit
- MemBit ();
- if (APUCheckCarry ())
- {
- if (S9xAPUGetByte (pIAPU->Address) & (1 << pIAPU->Bit))
- APUClearCarry ();
- }
- else
- {
- if (S9xAPUGetByte (pIAPU->Address) & (1 << pIAPU->Bit))
- APUSetCarry ();
- }
- pIAPU->PC += 3;
-}
-
-void ApuAA ()
-{
-// MOV1 C,membit
- MemBit ();
- if (S9xAPUGetByte (pIAPU->Address) & (1 << pIAPU->Bit))
- APUSetCarry ();
- else
- APUClearCarry ();
- pIAPU->PC += 3;
-}
-
-void ApuCA ()
-{
-// MOV1 membit,C
- MemBit ();
- if (APUCheckCarry ())
- {
- S9xAPUSetByte (S9xAPUGetByte (pIAPU->Address) | (1 << pIAPU->Bit), pIAPU->Address);
- }
- else
- {
- S9xAPUSetByte (S9xAPUGetByte (pIAPU->Address) & ~(1 << pIAPU->Bit), pIAPU->Address);
- }
- pIAPU->PC += 3;
-}
-
-void ApuEA ()
-{
-// NOT1 membit
- MemBit ();
- S9xAPUSetByte (S9xAPUGetByte (pIAPU->Address) ^ (1 << pIAPU->Bit), pIAPU->Address);
- pIAPU->PC += 3;
-}
-
-void Apu0B ()
-{
-// ASL dp
- Work8 = S9xAPUGetByteZ (OP1);
- ASL (Work8);
- S9xAPUSetByteZ (Work8, OP1);
- pIAPU->PC += 2;
-}
-
-void Apu0C ()
-{
-// ASL abs
- Absolute ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- ASL (Work8);
- S9xAPUSetByte (Work8, pIAPU->Address);
- pIAPU->PC += 3;
-}
-
-void Apu1B ()
-{
-// ASL dp+X
- Work8 = S9xAPUGetByteZ (OP1 + pIAPU->X);
- ASL (Work8);
- S9xAPUSetByteZ (Work8, OP1 + pIAPU->X);
- pIAPU->PC += 2;
-}
-
-void Apu1C ()
-{
-// ASL A
- ASL (pIAPU->YA.B.A);
- pIAPU->PC++;
-}
-
-void Apu0D ()
-{
-// PUSH PSW
- S9xAPUPackStatus ();
- Push (pIAPU->P);
- pIAPU->PC++;
-}
-
-void Apu2D ()
-{
-// PUSH A
- Push (pIAPU->YA.B.A);
- pIAPU->PC++;
-}
-
-void Apu4D ()
-{
-// PUSH X
- Push (pIAPU->X);
- pIAPU->PC++;
-}
-
-void Apu6D ()
-{
-// PUSH Y
- Push (pIAPU->YA.B.Y);
- pIAPU->PC++;
-}
-
-void Apu8E ()
-{
-// POP PSW
- Pop (pIAPU->P);
- S9xAPUUnpackStatus ();
- if (APUCheckDirectPage ())
- pIAPU->DirectPage = pIAPU->RAM + 0x100;
- else
- pIAPU->DirectPage = pIAPU->RAM;
- pIAPU->PC++;
-}
-
-void ApuAE ()
-{
-// POP A
- Pop (pIAPU->YA.B.A);
- pIAPU->PC++;
-}
-
-void ApuCE ()
-{
-// POP X
- Pop (pIAPU->X);
- pIAPU->PC++;
-}
-
-void ApuEE ()
-{
-// POP Y
- Pop (pIAPU->YA.B.Y);
- pIAPU->PC++;
-}
-
-void Apu0E ()
-{
-// TSET1 abs
- Absolute ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- S9xAPUSetByte (Work8 | pIAPU->YA.B.A, pIAPU->Address);
- Work8 &= pIAPU->YA.B.A;
- APUSetZN8 (Work8);
- pIAPU->PC += 3;
-}
-
-void Apu4E ()
-{
-// TCLR1 abs
- Absolute ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- S9xAPUSetByte (Work8 & ~pIAPU->YA.B.A, pIAPU->Address);
- Work8 &= pIAPU->YA.B.A;
- APUSetZN8 (Work8);
- pIAPU->PC += 3;
-}
-
-void Apu0F ()
-{
-// BRK
-
-#if 0
- STOP ("BRK");
-#else
- PushW ((pIAPU->PC + 1 - pIAPU->RAM));
- S9xAPUPackStatus ();
- Push (pIAPU->P);
- APUSetBreak ();
- APUClearInterrupt ();
-// XXX:Where is the BRK vector ???
- pIAPU->PC = pIAPU->RAM + APU.ExtraRAM[0x20] + (APU.ExtraRAM[0x21] << 8);
-#endif
-}
-
-void ApuEF ()
-{
-// SLEEP
- // XXX: sleep
- // STOP ("SLEEP");
- CPU.APU_APUExecuting = FALSE;
- pIAPU->PC++;
-}
-
-void ApuFF ()
-{
-// STOP
- // STOP ("STOP");
- CPU.APU_APUExecuting = FALSE;
- pIAPU->PC++;
-}
-
-void Apu10 ()
-{
-// BPL
- Relative ();
- if (!APUCheckNegative ())
- {
- pIAPU->PC = pIAPU->RAM + (uint16) Int16;
- CPU.APU_Cycles += pIAPU->TwoCycles;
- APUShutdown ();
- }
- else
- pIAPU->PC += 2;
-}
-
-void Apu30 ()
-{
-// BMI
- Relative ();
- if (APUCheckNegative ())
- {
- pIAPU->PC = pIAPU->RAM + (uint16) Int16;
- CPU.APU_Cycles += pIAPU->TwoCycles;
- APUShutdown ();
- }
- else
- pIAPU->PC += 2;
-}
-
-void Apu90 ()
-{
-// BCC
- Relative ();
- if (!APUCheckCarry ())
- {
- pIAPU->PC = pIAPU->RAM + (uint16) Int16;
- CPU.APU_Cycles += pIAPU->TwoCycles;
- APUShutdown ();
- }
- else
- pIAPU->PC += 2;
-}
-
-void ApuB0 ()
-{
-// BCS
- Relative ();
- if (APUCheckCarry ())
- {
- pIAPU->PC = pIAPU->RAM + (uint16) Int16;
- CPU.APU_Cycles += pIAPU->TwoCycles;
- APUShutdown ();
- }
- else
- pIAPU->PC += 2;
-}
-
-void ApuD0 ()
-{
-// BNE
- Relative ();
- if (!APUCheckZero ())
- {
- pIAPU->PC = pIAPU->RAM + (uint16) Int16;
- CPU.APU_Cycles += pIAPU->TwoCycles;
- APUShutdown ();
- }
- else
- pIAPU->PC += 2;
-}
-
-void ApuF0 ()
-{
-// BEQ
- Relative ();
- if (APUCheckZero ())
- {
- pIAPU->PC = pIAPU->RAM + (uint16) Int16;
- CPU.APU_Cycles += pIAPU->TwoCycles;
- APUShutdown ();
- }
- else
- pIAPU->PC += 2;
-}
-
-void Apu50 ()
-{
-// BVC
- Relative ();
- if (!APUCheckOverflow ())
- {
- pIAPU->PC = pIAPU->RAM + (uint16) Int16;
- CPU.APU_Cycles += pIAPU->TwoCycles;
- }
- else
- pIAPU->PC += 2;
-}
-
-void Apu70 ()
-{
-// BVS
- Relative ();
- if (APUCheckOverflow ())
- {
- pIAPU->PC = pIAPU->RAM + (uint16) Int16;
- CPU.APU_Cycles += pIAPU->TwoCycles;
- }
- else
- pIAPU->PC += 2;
-}
-
-void Apu2F ()
-{
-// BRA
- Relative ();
- pIAPU->PC = pIAPU->RAM + (uint16) Int16;
-}
-
-void Apu80 ()
-{
-// SETC
- APUSetCarry ();
- pIAPU->PC++;
-}
-
-void ApuED ()
-{
-// NOTC
- pIAPU->_Carry ^= 1;
- pIAPU->PC++;
-}
-
-void Apu40 ()
-{
-// SETP
- APUSetDirectPage ();
- pIAPU->DirectPage = pIAPU->RAM + 0x100;
- pIAPU->PC++;
-}
-
-void Apu1A ()
-{
-// DECW dp
- Work16 = S9xAPUGetByteZ (OP1) + (S9xAPUGetByteZ (OP1 + 1) << 8);
- Work16--;
- S9xAPUSetByteZ ((uint8) Work16, OP1);
- S9xAPUSetByteZ (Work16 >> 8, OP1 + 1);
- APUSetZN16 (Work16);
- pIAPU->PC += 2;
-}
-
-void Apu5A ()
-{
-// CMPW YA,dp
- Work16 = S9xAPUGetByteZ (OP1) + (S9xAPUGetByteZ (OP1 + 1) << 8);
- Int32 = (long) pIAPU->YA.W - (long) Work16;
- pIAPU->_Carry = Int32 >= 0;
- APUSetZN16 ((uint16) Int32);
- pIAPU->PC += 2;
-}
-
-void Apu3A ()
-{
-// INCW dp
- Work16 = S9xAPUGetByteZ (OP1) + (S9xAPUGetByteZ (OP1 + 1) << 8);
- Work16++;
- S9xAPUSetByteZ ((uint8) Work16, OP1);
- S9xAPUSetByteZ (Work16 >> 8, OP1 + 1);
- APUSetZN16 (Work16);
- pIAPU->PC += 2;
-}
-
-// XXX: HalfCarry - BJ Fixed? Or is it between bits 7 and 8 for ADDW/SUBW?
-void Apu7A ()
-{
-// ADDW YA,dp
- Work16 = S9xAPUGetByteZ (OP1) + (S9xAPUGetByteZ (OP1 + 1) << 8);
- Work32 = (uint32) pIAPU->YA.W + Work16;
- pIAPU->_Carry = Work32 >= 0x10000;
- if (~(pIAPU->YA.W ^ Work16) & (Work16 ^ (uint16) Work32) & 0x8000)
- APUSetOverflow ();
- else
- APUClearOverflow ();
- APUClearHalfCarry ();
- if((pIAPU->YA.W ^ Work16 ^ (uint16) Work32) & 0x10)
- APUSetHalfCarry ();
- pIAPU->YA.W = (uint16) Work32;
- APUSetZN16 (pIAPU->YA.W);
- pIAPU->PC += 2;
-}
-
-// XXX: BJ: i think the old HalfCarry behavior was wrong...
-// XXX: Or is it between bits 7 and 8 for ADDW/SUBW?
-void Apu9A ()
-{
-// SUBW YA,dp
- Work16 = S9xAPUGetByteZ (OP1) + (S9xAPUGetByteZ (OP1 + 1) << 8);
- Int32 = (long) pIAPU->YA.W - (long) Work16;
- APUClearHalfCarry ();
- pIAPU->_Carry = Int32 >= 0;
- if (((pIAPU->YA.W ^ Work16) & 0x8000) &&
- ((pIAPU->YA.W ^ (uint16) Int32) & 0x8000))
- APUSetOverflow ();
- else
- APUClearOverflow ();
-// if (((pIAPU->YA.W ^ Work16) & 0x0080) &&
-// ((pIAPU->YA.W ^ (uint16) Int32) & 0x0080))
-// APUSetHalfCarry (); // notaz: strange here
- APUSetHalfCarry ();
-// if((pIAPU->YA.W ^ Work16 ^ (uint16) Work32) & 0x10) // notaz: Work32?!
- if((pIAPU->YA.W ^ Work16 ^ (uint16) Int32) & 0x10)
- APUClearHalfCarry ();
- pIAPU->YA.W = (uint16) Int32;
- APUSetZN16 (pIAPU->YA.W);
- pIAPU->PC += 2;
-}
-
-void ApuBA ()
-{
-// MOVW YA,dp
- pIAPU->YA.B.A = S9xAPUGetByteZ (OP1);
- pIAPU->YA.B.Y = S9xAPUGetByteZ (OP1 + 1);
- APUSetZN16 (pIAPU->YA.W);
- pIAPU->PC += 2;
-}
-
-void ApuDA ()
-{
-// MOVW dp,YA
- S9xAPUSetByteZ (pIAPU->YA.B.A, OP1);
- S9xAPUSetByteZ (pIAPU->YA.B.Y, OP1 + 1);
- pIAPU->PC += 2;
-}
-
-void Apu64 ()
-{
-// CMP A,dp
- Work8 = S9xAPUGetByteZ (OP1);
- CMP (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 2;
-}
-
-void Apu65 ()
-{
-// CMP A,abs
- Absolute ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- CMP (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 3;
-}
-
-void Apu66 ()
-{
-// CMP A,(X)
- Work8 = S9xAPUGetByteZ (pIAPU->X);
- CMP (pIAPU->YA.B.A, Work8);
- pIAPU->PC++;
-}
-
-void Apu67 ()
-{
-// CMP A,(dp+X)
- IndexedXIndirect ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- CMP (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 2;
-}
-
-void Apu68 ()
-{
-// CMP A,#00
- Work8 = OP1;
- CMP (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 2;
-}
-
-void Apu69 ()
-{
-// CMP dp(dest), dp(src)
- W1 = S9xAPUGetByteZ (OP1);
- Work8 = S9xAPUGetByteZ (OP2);
- CMP (Work8, W1);
- pIAPU->PC += 3;
-}
-
-void Apu74 ()
-{
-// CMP A, dp+X
- Work8 = S9xAPUGetByteZ (OP1 + pIAPU->X);
- CMP (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 2;
-}
-
-void Apu75 ()
-{
-// CMP A,abs+X
- AbsoluteX ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- CMP (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 3;
-}
-
-void Apu76 ()
-{
-// CMP A, abs+Y
- AbsoluteY ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- CMP (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 3;
-}
-
-void Apu77 ()
-{
-// CMP A,(dp)+Y
- IndirectIndexedY ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- CMP (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 2;
-}
-
-void Apu78 ()
-{
-// CMP dp,#00
- Work8 = OP1;
- W1 = S9xAPUGetByteZ (OP2);
- CMP (W1, Work8);
- pIAPU->PC += 3;
-}
-
-void Apu79 ()
-{
-// CMP (X),(Y)
- W1 = S9xAPUGetByteZ (pIAPU->X);
- Work8 = S9xAPUGetByteZ (pIAPU->YA.B.Y);
- CMP (W1, Work8);
- pIAPU->PC++;
-}
-
-void Apu1E ()
-{
-// CMP X,abs
- Absolute ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- CMP (pIAPU->X, Work8);
- pIAPU->PC += 3;
-}
-
-void Apu3E ()
-{
-// CMP X,dp
- Work8 = S9xAPUGetByteZ (OP1);
- CMP (pIAPU->X, Work8);
- pIAPU->PC += 2;
-}
-
-void ApuC8 ()
-{
-// CMP X,#00
- CMP (pIAPU->X, OP1);
- pIAPU->PC += 2;
-}
-
-void Apu5E ()
-{
-// CMP Y,abs
- Absolute ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- CMP (pIAPU->YA.B.Y, Work8);
- pIAPU->PC += 3;
-}
-
-void Apu7E ()
-{
-// CMP Y,dp
- Work8 = S9xAPUGetByteZ (OP1);
- CMP (pIAPU->YA.B.Y, Work8);
- pIAPU->PC += 2;
-}
-
-void ApuAD ()
-{
-// CMP Y,#00
- Work8 = OP1;
- CMP (pIAPU->YA.B.Y, Work8);
- pIAPU->PC += 2;
-}
-
-void Apu1F ()
-{
-// JMP (abs+X)
- Absolute ();
- pIAPU->PC = pIAPU->RAM + S9xAPUGetByte (pIAPU->Address + pIAPU->X) +
- (S9xAPUGetByte (pIAPU->Address + pIAPU->X + 1) << 8);
-// XXX: HERE:
- // APU.Flags |= TRACE_FLAG;
-}
-
-void Apu5F ()
-{
-// JMP abs
- Absolute ();
- pIAPU->PC = pIAPU->RAM + pIAPU->Address;
-}
-
-void Apu20 ()
-{
-// CLRP
- APUClearDirectPage ();
- pIAPU->DirectPage = pIAPU->RAM;
- pIAPU->PC++;
-}
-
-void Apu60 ()
-{
-// CLRC
- APUClearCarry ();
- pIAPU->PC++;
-}
-
-void ApuE0 ()
-{
-// CLRV
- APUClearHalfCarry ();
- APUClearOverflow ();
- pIAPU->PC++;
-}
-
-void Apu24 ()
-{
-// AND A,dp
- pIAPU->YA.B.A &= S9xAPUGetByteZ (OP1);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void Apu25 ()
-{
-// AND A,abs
- Absolute ();
- pIAPU->YA.B.A &= S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 3;
-}
-
-void Apu26 ()
-{
-// AND A,(X)
- pIAPU->YA.B.A &= S9xAPUGetByteZ (pIAPU->X);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC++;
-}
-
-void Apu27 ()
-{
-// AND A,(dp+X)
- IndexedXIndirect ();
- pIAPU->YA.B.A &= S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void Apu28 ()
-{
-// AND A,#00
- pIAPU->YA.B.A &= OP1;
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void Apu29 ()
-{
-// AND dp(dest),dp(src)
- Work8 = S9xAPUGetByteZ (OP1);
- Work8 &= S9xAPUGetByteZ (OP2);
- S9xAPUSetByteZ (Work8, OP2);
- APUSetZN8 (Work8);
- pIAPU->PC += 3;
-}
-
-void Apu34 ()
-{
-// AND A,dp+X
- pIAPU->YA.B.A &= S9xAPUGetByteZ (OP1 + pIAPU->X);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void Apu35 ()
-{
-// AND A,abs+X
- AbsoluteX ();
- pIAPU->YA.B.A &= S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 3;
-}
-
-void Apu36 ()
-{
-// AND A,abs+Y
- AbsoluteY ();
- pIAPU->YA.B.A &= S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 3;
-}
-
-void Apu37 ()
-{
-// AND A,(dp)+Y
- IndirectIndexedY ();
- pIAPU->YA.B.A &= S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void Apu38 ()
-{
-// AND dp,#00
- Work8 = OP1;
- Work8 &= S9xAPUGetByteZ (OP2);
- S9xAPUSetByteZ (Work8, OP2);
- APUSetZN8 (Work8);
- pIAPU->PC += 3;
-}
-
-void Apu39 ()
-{
-// AND (X),(Y)
- Work8 = S9xAPUGetByteZ (pIAPU->X) & S9xAPUGetByteZ (pIAPU->YA.B.Y);
- APUSetZN8 (Work8);
- S9xAPUSetByteZ (Work8, pIAPU->X);
- pIAPU->PC++;
-}
-
-void Apu2B ()
-{
-// ROL dp
- Work8 = S9xAPUGetByteZ (OP1);
- ROL (Work8);
- S9xAPUSetByteZ (Work8, OP1);
- pIAPU->PC += 2;
-}
-
-void Apu2C ()
-{
-// ROL abs
- Absolute ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- ROL (Work8);
- S9xAPUSetByte (Work8, pIAPU->Address);
- pIAPU->PC += 3;
-}
-
-void Apu3B ()
-{
-// ROL dp+X
- Work8 = S9xAPUGetByteZ (OP1 + pIAPU->X);
- ROL (Work8);
- S9xAPUSetByteZ (Work8, OP1 + pIAPU->X);
- pIAPU->PC += 2;
-}
-
-void Apu3C ()
-{
-// ROL A
- ROL (pIAPU->YA.B.A);
- pIAPU->PC++;
-}
-
-void Apu2E ()
-{
-// CBNE dp,rel
- Work8 = OP1;
- Relative2 ();
-
- if (S9xAPUGetByteZ (Work8) != pIAPU->YA.B.A)
- {
- pIAPU->PC = pIAPU->RAM + (uint16) Int16;
- CPU.APU_Cycles += pIAPU->TwoCycles;
- APUShutdown ();
- }
- else
- pIAPU->PC += 3;
-}
-
-void ApuDE ()
-{
-// CBNE dp+X,rel
- Work8 = OP1 + pIAPU->X;
- Relative2 ();
-
- if (S9xAPUGetByteZ (Work8) != pIAPU->YA.B.A)
- {
- pIAPU->PC = pIAPU->RAM + (uint16) Int16;
- CPU.APU_Cycles += pIAPU->TwoCycles;
- APUShutdown ();
- }
- else
- pIAPU->PC += 3;
-}
-
-void Apu3D ()
-{
-// INC X
- pIAPU->X++;
- APUSetZN8 (pIAPU->X);
-
-#ifdef SPC700_SHUTDOWN
- pIAPU->WaitCounter++;
-#endif
-
- pIAPU->PC++;
-}
-
-void ApuFC ()
-{
-// INC Y
- pIAPU->YA.B.Y++;
- APUSetZN8 (pIAPU->YA.B.Y);
-
-#ifdef SPC700_SHUTDOWN
- pIAPU->WaitCounter++;
-#endif
-
- pIAPU->PC++;
-}
-
-void Apu1D ()
-{
-// DEC X
- pIAPU->X--;
- APUSetZN8 (pIAPU->X);
-
-#ifdef SPC700_SHUTDOWN
- pIAPU->WaitCounter++;
-#endif
-
- pIAPU->PC++;
-}
-
-void ApuDC ()
-{
-// DEC Y
- pIAPU->YA.B.Y--;
- APUSetZN8 (pIAPU->YA.B.Y);
-
-#ifdef SPC700_SHUTDOWN
- pIAPU->WaitCounter++;
-#endif
-
- pIAPU->PC++;
-}
-
-void ApuAB ()
-{
-// INC dp
- Work8 = S9xAPUGetByteZ (OP1) + 1;
- S9xAPUSetByteZ (Work8, OP1);
- APUSetZN8 (Work8);
-
-#ifdef SPC700_SHUTDOWN
- pIAPU->WaitCounter++;
-#endif
-
- pIAPU->PC += 2;
-}
-
-void ApuAC ()
-{
-// INC abs
- Absolute ();
- Work8 = S9xAPUGetByte (pIAPU->Address) + 1;
- S9xAPUSetByte (Work8, pIAPU->Address);
- APUSetZN8 (Work8);
-
-#ifdef SPC700_SHUTDOWN
- pIAPU->WaitCounter++;
-#endif
-
- pIAPU->PC += 3;
-}
-
-void ApuBB ()
-{
-// INC dp+X
- Work8 = S9xAPUGetByteZ (OP1 + pIAPU->X) + 1;
- S9xAPUSetByteZ (Work8, OP1 + pIAPU->X);
- APUSetZN8 (Work8);
-
-#ifdef SPC700_SHUTDOWN
- pIAPU->WaitCounter++;
-#endif
-
- pIAPU->PC += 2;
-}
-
-void ApuBC ()
-{
-// INC A
- pIAPU->YA.B.A++;
- APUSetZN8 (pIAPU->YA.B.A);
-
-#ifdef SPC700_SHUTDOWN
- pIAPU->WaitCounter++;
-#endif
-
- pIAPU->PC++;
-}
-
-void Apu8B ()
-{
-// DEC dp
- Work8 = S9xAPUGetByteZ (OP1) - 1;
- S9xAPUSetByteZ (Work8, OP1);
- APUSetZN8 (Work8);
-
-#ifdef SPC700_SHUTDOWN
- pIAPU->WaitCounter++;
-#endif
-
- pIAPU->PC += 2;
-}
-
-void Apu8C ()
-{
-// DEC abs
- Absolute ();
- Work8 = S9xAPUGetByte (pIAPU->Address) - 1;
- S9xAPUSetByte (Work8, pIAPU->Address);
- APUSetZN8 (Work8);
-
-#ifdef SPC700_SHUTDOWN
- pIAPU->WaitCounter++;
-#endif
-
- pIAPU->PC += 3;
-}
-
-void Apu9B ()
-{
-// DEC dp+X
- Work8 = S9xAPUGetByteZ (OP1 + pIAPU->X) - 1;
- S9xAPUSetByteZ (Work8, OP1 + pIAPU->X);
- APUSetZN8 (Work8);
-
-#ifdef SPC700_SHUTDOWN
- pIAPU->WaitCounter++;
-#endif
-
- pIAPU->PC += 2;
-}
-
-void Apu9C ()
-{
-// DEC A
- pIAPU->YA.B.A--;
- APUSetZN8 (pIAPU->YA.B.A);
-
-#ifdef SPC700_SHUTDOWN
- pIAPU->WaitCounter++;
-#endif
-
- pIAPU->PC++;
-}
-
-void Apu44 ()
-{
-// EOR A,dp
- pIAPU->YA.B.A ^= S9xAPUGetByteZ (OP1);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void Apu45 ()
-{
-// EOR A,abs
- Absolute ();
- pIAPU->YA.B.A ^= S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 3;
-}
-
-void Apu46 ()
-{
-// EOR A,(X)
- pIAPU->YA.B.A ^= S9xAPUGetByteZ (pIAPU->X);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC++;
-}
-
-void Apu47 ()
-{
-// EOR A,(dp+X)
- IndexedXIndirect ();
- pIAPU->YA.B.A ^= S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void Apu48 ()
-{
-// EOR A,#00
- pIAPU->YA.B.A ^= OP1;
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void Apu49 ()
-{
-// EOR dp(dest),dp(src)
- Work8 = S9xAPUGetByteZ (OP1);
- Work8 ^= S9xAPUGetByteZ (OP2);
- S9xAPUSetByteZ (Work8, OP2);
- APUSetZN8 (Work8);
- pIAPU->PC += 3;
-}
-
-void Apu54 ()
-{
-// EOR A,dp+X
- pIAPU->YA.B.A ^= S9xAPUGetByteZ (OP1 + pIAPU->X);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void Apu55 ()
-{
-// EOR A,abs+X
- AbsoluteX ();
- pIAPU->YA.B.A ^= S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 3;
-}
-
-void Apu56 ()
-{
-// EOR A,abs+Y
- AbsoluteY ();
- pIAPU->YA.B.A ^= S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 3;
-}
-
-void Apu57 ()
-{
-// EOR A,(dp)+Y
- IndirectIndexedY ();
- pIAPU->YA.B.A ^= S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void Apu58 ()
-{
-// EOR dp,#00
- Work8 = OP1;
- Work8 ^= S9xAPUGetByteZ (OP2);
- S9xAPUSetByteZ (Work8, OP2);
- APUSetZN8 (Work8);
- pIAPU->PC += 3;
-}
-
-void Apu59 ()
-{
-// EOR (X),(Y)
- Work8 = S9xAPUGetByteZ (pIAPU->X) ^ S9xAPUGetByteZ (pIAPU->YA.B.Y);
- APUSetZN8 (Work8);
- S9xAPUSetByteZ (Work8, pIAPU->X);
- pIAPU->PC++;
-}
-
-void Apu4B ()
-{
-// LSR dp
- Work8 = S9xAPUGetByteZ (OP1);
- LSR (Work8);
- S9xAPUSetByteZ (Work8, OP1);
- pIAPU->PC += 2;
-}
-
-void Apu4C ()
-{
-// LSR abs
- Absolute ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- LSR (Work8);
- S9xAPUSetByte (Work8, pIAPU->Address);
- pIAPU->PC += 3;
-}
-
-void Apu5B ()
-{
-// LSR dp+X
- Work8 = S9xAPUGetByteZ (OP1 + pIAPU->X);
- LSR (Work8);
- S9xAPUSetByteZ (Work8, OP1 + pIAPU->X);
- pIAPU->PC += 2;
-}
-
-void Apu5C ()
-{
-// LSR A
- LSR (pIAPU->YA.B.A);
- pIAPU->PC++;
-}
-
-void Apu7D ()
-{
-// MOV A,X
- pIAPU->YA.B.A = pIAPU->X;
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC++;
-}
-
-void ApuDD ()
-{
-// MOV A,Y
- pIAPU->YA.B.A = pIAPU->YA.B.Y;
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC++;
-}
-
-void Apu5D ()
-{
-// MOV X,A
- pIAPU->X = pIAPU->YA.B.A;
- APUSetZN8 (pIAPU->X);
- pIAPU->PC++;
-}
-
-void ApuFD ()
-{
-// MOV Y,A
- pIAPU->YA.B.Y = pIAPU->YA.B.A;
- APUSetZN8 (pIAPU->YA.B.Y);
- pIAPU->PC++;
-}
-
-void Apu9D ()
-{
-//MOV X,SP
- pIAPU->X = pIAPU->S;
- APUSetZN8 (pIAPU->X);
- pIAPU->PC++;
-}
-
-void ApuBD ()
-{
-// MOV SP,X
- pIAPU->S = pIAPU->X;
- pIAPU->PC++;
-}
-
-void Apu6B ()
-{
-// ROR dp
- Work8 = S9xAPUGetByteZ (OP1);
- ROR (Work8);
- S9xAPUSetByteZ (Work8, OP1);
- pIAPU->PC += 2;
-}
-
-void Apu6C ()
-{
-// ROR abs
- Absolute ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- ROR (Work8);
- S9xAPUSetByte (Work8, pIAPU->Address);
- pIAPU->PC += 3;
-}
-
-void Apu7B ()
-{
-// ROR dp+X
- Work8 = S9xAPUGetByteZ (OP1 + pIAPU->X);
- ROR (Work8);
- S9xAPUSetByteZ (Work8, OP1 + pIAPU->X);
- pIAPU->PC += 2;
-}
-
-void Apu7C ()
-{
-// ROR A
- ROR (pIAPU->YA.B.A);
- pIAPU->PC++;
-}
-
-void Apu6E ()
-{
-// DBNZ dp,rel
- Work8 = OP1;
- Relative2 ();
- W1 = S9xAPUGetByteZ (Work8) - 1;
- S9xAPUSetByteZ (W1, Work8);
- if (W1 != 0)
- {
- pIAPU->PC = pIAPU->RAM + (uint16) Int16;
- CPU.APU_Cycles += pIAPU->TwoCycles;
- }
- else
- pIAPU->PC += 3;
-}
-
-void ApuFE ()
-{
-// DBNZ Y,rel
- Relative ();
- pIAPU->YA.B.Y--;
- if (pIAPU->YA.B.Y != 0)
- {
- pIAPU->PC = pIAPU->RAM + (uint16) Int16;
- CPU.APU_Cycles += pIAPU->TwoCycles;
- }
- else
- pIAPU->PC += 2;
-}
-
-void Apu6F ()
-{
-// RET
- PopW (Work16);
- pIAPU->PC = pIAPU->RAM + Work16;
-}
-
-void Apu7F ()
-{
-// RETI
- // STOP ("RETI");
- Pop (pIAPU->P);
- S9xAPUUnpackStatus ();
- PopW (Work16);
- pIAPU->PC = pIAPU->RAM + Work16;
-}
-
-void Apu84 ()
-{
-// ADC A,dp
- Work8 = S9xAPUGetByteZ (OP1);
- ADC (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 2;
-}
-
-void Apu85 ()
-{
-// ADC A, abs
- Absolute ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- ADC (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 3;
-}
-
-void Apu86 ()
-{
-// ADC A,(X)
- Work8 = S9xAPUGetByteZ (pIAPU->X);
- ADC (pIAPU->YA.B.A, Work8);
- pIAPU->PC++;
-}
-
-void Apu87 ()
-{
-// ADC A,(dp+X)
- IndexedXIndirect ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- ADC (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 2;
-}
-
-void Apu88 ()
-{
-// ADC A,#00
- Work8 = OP1;
- ADC (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 2;
-}
-
-void Apu89 ()
-{
-// ADC dp(dest),dp(src)
- Work8 = S9xAPUGetByteZ (OP1);
- W1 = S9xAPUGetByteZ (OP2);
- ADC (W1, Work8);
- S9xAPUSetByteZ (W1, OP2);
- pIAPU->PC += 3;
-}
-
-void Apu94 ()
-{
-// ADC A,dp+X
- Work8 = S9xAPUGetByteZ (OP1 + pIAPU->X);
- ADC (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 2;
-}
-
-void Apu95 ()
-{
-// ADC A, abs+X
- AbsoluteX ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- ADC (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 3;
-}
-
-void Apu96 ()
-{
-// ADC A, abs+Y
- AbsoluteY ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- ADC (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 3;
-}
-
-void Apu97 ()
-{
-// ADC A, (dp)+Y
- IndirectIndexedY ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- ADC (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 2;
-}
-
-void Apu98 ()
-{
-// ADC dp,#00
- Work8 = OP1;
- W1 = S9xAPUGetByteZ (OP2);
- ADC (W1, Work8);
- S9xAPUSetByteZ (W1, OP2);
- pIAPU->PC += 3;
-}
-
-void Apu99 ()
-{
-// ADC (X),(Y)
- W1 = S9xAPUGetByteZ (pIAPU->X);
- Work8 = S9xAPUGetByteZ (pIAPU->YA.B.Y);
- ADC (W1, Work8);
- S9xAPUSetByteZ (W1, pIAPU->X);
- pIAPU->PC++;
-}
-
-void Apu8D ()
-{
-// MOV Y,#00
- pIAPU->YA.B.Y = OP1;
- APUSetZN8 (pIAPU->YA.B.Y);
- pIAPU->PC += 2;
-}
-
-void Apu8F ()
-{
-// MOV dp,#00
- Work8 = OP1;
- S9xAPUSetByteZ (Work8, OP2);
- pIAPU->PC += 3;
-}
-
-void Apu9E ()
-{
-// DIV YA,X
- if (pIAPU->X == 0)
- {
- APUSetOverflow ();
- pIAPU->YA.B.Y = 0xff;
- pIAPU->YA.B.A = 0xff;
- }
- else
- {
- APUClearOverflow ();
- Work8 = pIAPU->YA.W / pIAPU->X;
- pIAPU->YA.B.Y = pIAPU->YA.W % pIAPU->X;
- pIAPU->YA.B.A = Work8;
- }
-// XXX How should Overflow, Half Carry, Zero and Negative flags be set??
- // APUSetZN16 (pIAPU->YA.W);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC++;
-}
-
-void Apu9F ()
-{
-// XCN A
- pIAPU->YA.B.A = (pIAPU->YA.B.A >> 4) | (pIAPU->YA.B.A << 4);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC++;
-}
-
-void ApuA4 ()
-{
-// SBC A, dp
- Work8 = S9xAPUGetByteZ (OP1);
- SBC (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 2;
-}
-
-void ApuA5 ()
-{
-// SBC A, abs
- Absolute ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- SBC (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 3;
-}
-
-void ApuA6 ()
-{
-// SBC A, (X)
- Work8 = S9xAPUGetByteZ (pIAPU->X);
- SBC (pIAPU->YA.B.A, Work8);
- pIAPU->PC++;
-}
-
-void ApuA7 ()
-{
-// SBC A,(dp+X)
- IndexedXIndirect ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- SBC (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 2;
-}
-
-void ApuA8 ()
-{
-// SBC A,#00
- Work8 = OP1;
- SBC (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 2;
-}
-
-void ApuA9 ()
-{
-// SBC dp(dest), dp(src)
- Work8 = S9xAPUGetByteZ (OP1);
- W1 = S9xAPUGetByteZ (OP2);
- SBC (W1, Work8);
- S9xAPUSetByteZ (W1, OP2);
- pIAPU->PC += 3;
-}
-
-void ApuB4 ()
-{
-// SBC A, dp+X
- Work8 = S9xAPUGetByteZ (OP1 + pIAPU->X);
- SBC (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 2;
-}
-
-void ApuB5 ()
-{
-// SBC A,abs+X
- AbsoluteX ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- SBC (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 3;
-}
-
-void ApuB6 ()
-{
-// SBC A,abs+Y
- AbsoluteY ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- SBC (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 3;
-}
-
-void ApuB7 ()
-{
-// SBC A,(dp)+Y
- IndirectIndexedY ();
- Work8 = S9xAPUGetByte (pIAPU->Address);
- SBC (pIAPU->YA.B.A, Work8);
- pIAPU->PC += 2;
-}
-
-void ApuB8 ()
-{
-// SBC dp,#00
- Work8 = OP1;
- W1 = S9xAPUGetByteZ (OP2);
- SBC (W1, Work8);
- S9xAPUSetByteZ (W1, OP2);
- pIAPU->PC += 3;
-}
-
-void ApuB9 ()
-{
-// SBC (X),(Y)
- W1 = S9xAPUGetByteZ (pIAPU->X);
- Work8 = S9xAPUGetByteZ (pIAPU->YA.B.Y);
- SBC (W1, Work8);
- S9xAPUSetByteZ (W1, pIAPU->X);
- pIAPU->PC++;
-}
-
-void ApuAF ()
-{
-// MOV (X)+, A
- S9xAPUSetByteZ (pIAPU->YA.B.A, pIAPU->X++);
- pIAPU->PC++;
-}
-
-void ApuBE ()
-{
-// DAS
- if ((pIAPU->YA.B.A & 0x0f) > 9 || !APUCheckHalfCarry())
- {
- pIAPU->YA.B.A -= 6;
- }
- if (pIAPU->YA.B.A > 0x9f || !pIAPU->_Carry)
- {
- pIAPU->YA.B.A -= 0x60;
- APUClearCarry ();
- }
- else { APUSetCarry (); }
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC++;
-}
-
-void ApuBF ()
-{
-// MOV A,(X)+
- pIAPU->YA.B.A = S9xAPUGetByteZ (pIAPU->X++);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC++;
-}
-
-void ApuC0 ()
-{
-// DI
- APUClearInterrupt ();
- pIAPU->PC++;
-}
-
-void ApuA0 ()
-{
-// EI
- APUSetInterrupt ();
- pIAPU->PC++;
-}
-
-void ApuC4 ()
-{
-// MOV dp,A
- S9xAPUSetByteZ (pIAPU->YA.B.A, OP1);
- pIAPU->PC += 2;
-}
-
-void ApuC5 ()
-{
-// MOV abs,A
- Absolute ();
- S9xAPUSetByte (pIAPU->YA.B.A, pIAPU->Address);
- pIAPU->PC += 3;
-}
-
-void ApuC6 ()
-{
-// MOV (X), A
- S9xAPUSetByteZ (pIAPU->YA.B.A, pIAPU->X);
- pIAPU->PC++;
-}
-
-void ApuC7 ()
-{
-// MOV (dp+X),A
- IndexedXIndirect ();
- S9xAPUSetByte (pIAPU->YA.B.A, pIAPU->Address);
- pIAPU->PC += 2;
-}
-
-void ApuC9 ()
-{
-// MOV abs,X
- Absolute ();
- S9xAPUSetByte (pIAPU->X, pIAPU->Address);
- pIAPU->PC += 3;
-}
-
-void ApuCB ()
-{
-// MOV dp,Y
- S9xAPUSetByteZ (pIAPU->YA.B.Y, OP1);
- pIAPU->PC += 2;
-}
-
-void ApuCC ()
-{
-// MOV abs,Y
- Absolute ();
- S9xAPUSetByte (pIAPU->YA.B.Y, pIAPU->Address);
- pIAPU->PC += 3;
-}
-
-void ApuCD ()
-{
-// MOV X,#00
- pIAPU->X = OP1;
- APUSetZN8 (pIAPU->X);
- pIAPU->PC += 2;
-}
-
-void ApuCF ()
-{
-// MUL YA
- pIAPU->YA.W = (uint16) pIAPU->YA.B.A * pIAPU->YA.B.Y;
- APUSetZN16 (pIAPU->YA.W);
- pIAPU->PC++;
-}
-
-void ApuD4 ()
-{
-// MOV dp+X, A
- S9xAPUSetByteZ (pIAPU->YA.B.A, OP1 + pIAPU->X);
- pIAPU->PC += 2;
-}
-
-void ApuD5 ()
-{
-// MOV abs+X,A
- AbsoluteX ();
- S9xAPUSetByte (pIAPU->YA.B.A, pIAPU->Address);
- pIAPU->PC += 3;
-}
-
-void ApuD6 ()
-{
-// MOV abs+Y,A
- AbsoluteY ();
- S9xAPUSetByte (pIAPU->YA.B.A, pIAPU->Address);
- pIAPU->PC += 3;
-}
-
-void ApuD7 ()
-{
-// MOV (dp)+Y,A
- IndirectIndexedY ();
- S9xAPUSetByte (pIAPU->YA.B.A, pIAPU->Address);
- pIAPU->PC += 2;
-}
-
-void ApuD8 ()
-{
-// MOV dp,X
- S9xAPUSetByteZ (pIAPU->X, OP1);
- pIAPU->PC += 2;
-}
-
-void ApuD9 ()
-{
-// MOV dp+Y,X
- S9xAPUSetByteZ (pIAPU->X, OP1 + pIAPU->YA.B.Y);
- pIAPU->PC += 2;
-}
-
-void ApuDB ()
-{
-// MOV dp+X,Y
- S9xAPUSetByteZ (pIAPU->YA.B.Y, OP1 + pIAPU->X);
- pIAPU->PC += 2;
-}
-
-void ApuDF ()
-{
-// DAA
- if ((pIAPU->YA.B.A & 0x0f) > 9 || APUCheckHalfCarry())
- {
- if(pIAPU->YA.B.A > 0xf0) APUSetCarry ();
- pIAPU->YA.B.A += 6;
- //APUSetHalfCarry (); Intel procs do this, but this is a Sony proc...
- }
- //else { APUClearHalfCarry (); } ditto as above
- if (pIAPU->YA.B.A > 0x9f || pIAPU->_Carry)
- {
- pIAPU->YA.B.A += 0x60;
- APUSetCarry ();
- }
- else { APUClearCarry (); }
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC++;
-}
-
-void ApuE4 ()
-{
-// MOV A, dp
- pIAPU->YA.B.A = S9xAPUGetByteZ (OP1);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void ApuE5 ()
-{
-// MOV A,abs
- Absolute ();
- pIAPU->YA.B.A = S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 3;
-}
-
-void ApuE6 ()
-{
-// MOV A,(X)
- pIAPU->YA.B.A = S9xAPUGetByteZ (pIAPU->X);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC++;
-}
-
-void ApuE7 ()
-{
-// MOV A,(dp+X)
- IndexedXIndirect ();
- pIAPU->YA.B.A = S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void ApuE8 ()
-{
-// MOV A,#00
- pIAPU->YA.B.A = OP1;
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void ApuE9 ()
-{
-// MOV X, abs
- Absolute ();
- pIAPU->X = S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->X);
- pIAPU->PC += 3;
-}
-
-void ApuEB ()
-{
-// MOV Y,dp
- pIAPU->YA.B.Y = S9xAPUGetByteZ (OP1);
- APUSetZN8 (pIAPU->YA.B.Y);
- pIAPU->PC += 2;
-}
-
-void ApuEC ()
-{
-// MOV Y,abs
- Absolute ();
- pIAPU->YA.B.Y = S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.Y);
- pIAPU->PC += 3;
-}
-
-void ApuF4 ()
-{
-// MOV A, dp+X
- pIAPU->YA.B.A = S9xAPUGetByteZ (OP1 + pIAPU->X);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void ApuF5 ()
-{
-// MOV A, abs+X
- AbsoluteX ();
- pIAPU->YA.B.A = S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 3;
-}
-
-void ApuF6 ()
-{
-// MOV A, abs+Y
- AbsoluteY ();
- pIAPU->YA.B.A = S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 3;
-}
-
-void ApuF7 ()
-{
-// MOV A, (dp)+Y
- IndirectIndexedY ();
- pIAPU->YA.B.A = S9xAPUGetByte (pIAPU->Address);
- APUSetZN8 (pIAPU->YA.B.A);
- pIAPU->PC += 2;
-}
-
-void ApuF8 ()
-{
-// MOV X,dp
- pIAPU->X = S9xAPUGetByteZ (OP1);
- APUSetZN8 (pIAPU->X);
- pIAPU->PC += 2;
-}
-
-void ApuF9 ()
-{
-// MOV X,dp+Y
- pIAPU->X = S9xAPUGetByteZ (OP1 + pIAPU->YA.B.Y);
- APUSetZN8 (pIAPU->X);
- pIAPU->PC += 2;
-}
-
-void ApuFA ()
-{
-// MOV dp(dest),dp(src)
- S9xAPUSetByteZ (S9xAPUGetByteZ (OP1), OP2);
- pIAPU->PC += 3;
-}
-
-void ApuFB ()
-{
-// MOV Y,dp+X
- pIAPU->YA.B.Y = S9xAPUGetByteZ (OP1 + pIAPU->X);
- APUSetZN8 (pIAPU->YA.B.Y);
- pIAPU->PC += 2;
-}
-
-//#if defined(ASM_SPC700)
-#undef INLINE
-#define INLINE extern "C"
-#include "apumem.h"
-/*
-#elif defined(NO_INLINE_SET_GET)
-#undef INLINE
-#define INLINE
-#include "apumem.h"
-#endif
-*/
-
-void (*S9xApuOpcodes[256]) (void) =
-{
- Apu00, Apu01, Apu02, Apu03, Apu04, Apu05, Apu06, Apu07,
- Apu08, Apu09, Apu0A, Apu0B, Apu0C, Apu0D, Apu0E, Apu0F,
- Apu10, Apu11, Apu12, Apu13, Apu14, Apu15, Apu16, Apu17,
- Apu18, Apu19, Apu1A, Apu1B, Apu1C, Apu1D, Apu1E, Apu1F,
- Apu20, Apu21, Apu22, Apu23, Apu24, Apu25, Apu26, Apu27,
- Apu28, Apu29, Apu2A, Apu2B, Apu2C, Apu2D, Apu2E, Apu2F,
- Apu30, Apu31, Apu32, Apu33, Apu34, Apu35, Apu36, Apu37,
- Apu38, Apu39, Apu3A, Apu3B, Apu3C, Apu3D, Apu3E, Apu3F,
- Apu40, Apu41, Apu42, Apu43, Apu44, Apu45, Apu46, Apu47,
- Apu48, Apu49, Apu4A, Apu4B, Apu4C, Apu4D, Apu4E, Apu4F,
- Apu50, Apu51, Apu52, Apu53, Apu54, Apu55, Apu56, Apu57,
- Apu58, Apu59, Apu5A, Apu5B, Apu5C, Apu5D, Apu5E, Apu5F,
- Apu60, Apu61, Apu62, Apu63, Apu64, Apu65, Apu66, Apu67,
- Apu68, Apu69, Apu6A, Apu6B, Apu6C, Apu6D, Apu6E, Apu6F,
- Apu70, Apu71, Apu72, Apu73, Apu74, Apu75, Apu76, Apu77,
- Apu78, Apu79, Apu7A, Apu7B, Apu7C, Apu7D, Apu7E, Apu7F,
- Apu80, Apu81, Apu82, Apu83, Apu84, Apu85, Apu86, Apu87,
- Apu88, Apu89, Apu8A, Apu8B, Apu8C, Apu8D, Apu8E, Apu8F,
- Apu90, Apu91, Apu92, Apu93, Apu94, Apu95, Apu96, Apu97,
- Apu98, Apu99, Apu9A, Apu9B, Apu9C, Apu9D, Apu9E, Apu9F,
- ApuA0, ApuA1, ApuA2, ApuA3, ApuA4, ApuA5, ApuA6, ApuA7,
- ApuA8, ApuA9, ApuAA, ApuAB, ApuAC, ApuAD, ApuAE, ApuAF,
- ApuB0, ApuB1, ApuB2, ApuB3, ApuB4, ApuB5, ApuB6, ApuB7,
- ApuB8, ApuB9, ApuBA, ApuBB, ApuBC, ApuBD, ApuBE, ApuBF,
- ApuC0, ApuC1, ApuC2, ApuC3, ApuC4, ApuC5, ApuC6, ApuC7,
- ApuC8, ApuC9, ApuCA, ApuCB, ApuCC, ApuCD, ApuCE, ApuCF,
- ApuD0, ApuD1, ApuD2, ApuD3, ApuD4, ApuD5, ApuD6, ApuD7,
- ApuD8, ApuD9, ApuDA, ApuDB, ApuDC, ApuDD, ApuDE, ApuDF,
- ApuE0, ApuE1, ApuE2, ApuE3, ApuE4, ApuE5, ApuE6, ApuE7,
- ApuE8, ApuE9, ApuEA, ApuEB, ApuEC, ApuED, ApuEE, ApuEF,
- ApuF0, ApuF1, ApuF2, ApuF3, ApuF4, ApuF5, ApuF6, ApuF7,
- ApuF8, ApuF9, ApuFA, ApuFB, ApuFC, ApuFD, ApuFE, ApuFF
-};
-
-
-struct SIAPU IAPU2;
-struct SIAPU *pIAPU;
-
-void APUCompare()
-{
- IAPU.icount++;
-
- if(IAPU.PC != IAPU2.PC) {
- dprintf("!%02X %5i PC %08X vs %08X", IAPU.opcode, IAPU.icount, IAPU.PC, IAPU2.PC);
- exit(1);
- }
-
- if(IAPU.YA.W != IAPU2.YA.W) {
- dprintf("!%02X %5i YA %04X vs %04X", IAPU.opcode, IAPU.icount, IAPU.YA.W, IAPU2.YA.W);
- dprintf(" (%04X / %02X)", IAPU.ya_prev, IAPU.x_prev);
- exit(1);
- }
-
- if((IAPU.P&0x7d) != (IAPU2.P&0x7d)) {
- dprintf("!%02X %5i P %02X vs %02X", IAPU.opcode, IAPU.icount, IAPU.P, IAPU2.P);
- exit(1);
- }
-
- if(IAPU.X != IAPU2.X) {
- dprintf("!%02X %5i X %02X vs %02X", IAPU.opcode, IAPU.icount, IAPU.X, IAPU2.X);
- exit(1);
- }
-
- if(IAPU.S != IAPU2.S) {
- dprintf("!%02X %5i S %02X vs %02X", IAPU.opcode, IAPU.icount, IAPU.S, IAPU2.S);
- exit(1);
- }
-
- if((IAPU._Zero == 0) != (IAPU2._Zero == 0)) {
- dprintf("!%02X %5i _Zero %02X vs %02X", IAPU.opcode, IAPU.icount, IAPU._Zero, IAPU2._Zero);
- exit(1);
- }
-
- if((IAPU._Zero & 0x80) != (IAPU2._Zero & 0x80)) {
- dprintf("!%02X %5i _Zero(n) %02X vs %02X", IAPU.opcode, IAPU.icount, IAPU._Zero, IAPU2._Zero);
- exit(1);
- }
-
- if(IAPU.memread_addr != IAPU2.memread_addr) {
- dprintf("!%02X %5i memread_addr %04X vs %04X", IAPU.opcode, IAPU.icount, IAPU.memread_addr, IAPU2.memread_addr);
- exit(1);
- }
-
- if(IAPU.memread_data != IAPU2.memread_data) {
- dprintf("!%02X %5i memread_data %02X@%04X vs %02X@%04X", IAPU.opcode, IAPU.icount, IAPU.memread_data, IAPU.memread_addr, IAPU2.memread_data, IAPU2.memread_addr);
- exit(1);
- }
-
- if(IAPU.memwrite_addr != IAPU2.memwrite_addr) {
- dprintf("!%02X %5i memwrite_addr %04X vs %04X", IAPU.opcode, IAPU.icount, IAPU.memwrite_addr, IAPU2.memwrite_addr);
- exit(1);
- }
-
- if(IAPU.memwrite_data != IAPU2.memwrite_data) {
- dprintf("!%02X %5i memwrite_data %02X@%04X vs %02X@%04X", IAPU.opcode, IAPU.icount, IAPU.memwrite_data, IAPU.memwrite_addr, IAPU2.memwrite_data, IAPU2.memwrite_addr);
- exit(1);
- }
-}
-
-
diff --git a/old/spc700/debug/spc700.h b/old/spc700/debug/spc700.h deleted file mode 100644 index 433fe6f..0000000 --- a/old/spc700/debug/spc700.h +++ /dev/null @@ -1,172 +0,0 @@ -/*
- * Snes9x - Portable Super Nintendo Entertainment System (TM) emulator.
- *
- * (c) Copyright 1996 - 2001 Gary Henderson (gary.henderson@ntlworld.com) and
- * Jerremy Koot (jkoot@snes9x.com)
- *
- * Super FX C emulator code
- * (c) Copyright 1997 - 1999 Ivar (ivar@snes9x.com) and
- * Gary Henderson.
- * Super FX assembler emulator code (c) Copyright 1998 zsKnight and _Demo_.
- *
- * DSP1 emulator code (c) Copyright 1998 Ivar, _Demo_ and Gary Henderson.
- * C4 asm and some C emulation code (c) Copyright 2000 zsKnight and _Demo_.
- * C4 C code (c) Copyright 2001 Gary Henderson (gary.henderson@ntlworld.com).
- *
- * DOS port code contains the works of other authors. See headers in
- * individual files.
- *
- * Snes9x homepage: http://www.snes9x.com
- *
- * Permission to use, copy, modify and distribute Snes9x in both binary and
- * source form, for non-commercial purposes, is hereby granted without fee,
- * providing that this license information and copyright notice appear with
- * all copies and any derived work.
- *
- * This software is provided 'as-is', without any express or implied
- * warranty. In no event shall the authors be held liable for any damages
- * arising from the use of this software.
- *
- * Snes9x is freeware for PERSONAL USE only. Commercial users should
- * seek permission of the copyright holders first. Commercial use includes
- * charging money for Snes9x or software derived from Snes9x.
- *
- * The copyright holders request that bug fixes and improvements to the code
- * should be forwarded to them so everyone can benefit from the modifications
- * in future versions.
- *
- * Super NES and Super Nintendo Entertainment System are trademarks of
- * Nintendo Co., Limited and its subsidiary companies.
- */
-#ifndef _SPC700_H_
-#define _SPC700_H_
-
-#ifdef SPCTOOL
-#define NO_CHANNEL_STRUCT
-#include "spctool/dsp.h"
-#include "spctool/spc700.h"
-#include "spctool/soundmod.h"
-#endif
-
-
-#define Carry 1
-#define Zero 2
-#define Interrupt 4
-#define HalfCarry 8
-#define BreakFlag 16
-#define DirectPageFlag 32
-#define Overflow 64
-#define Negative 128
-
-#define APUClearCarry() (pIAPU->_Carry = 0)
-#define APUSetCarry() (pIAPU->_Carry = 1)
-#define APUSetInterrupt() (pIAPU->P |= Interrupt)
-#define APUClearInterrupt() (pIAPU->P &= ~Interrupt)
-#define APUSetHalfCarry() (pIAPU->P |= HalfCarry)
-#define APUClearHalfCarry() (pIAPU->P &= ~HalfCarry)
-#define APUSetBreak() (pIAPU->P |= BreakFlag)
-#define APUClearBreak() (pIAPU->P &= ~BreakFlag)
-#define APUSetDirectPage() (pIAPU->P |= DirectPageFlag)
-#define APUClearDirectPage() (pIAPU->P &= ~DirectPageFlag)
-#define APUSetOverflow() (pIAPU->_Overflow = 1)
-#define APUClearOverflow() (pIAPU->_Overflow = 0)
-
-#define APUCheckZero() (pIAPU->_Zero == 0)
-#define APUCheckCarry() (pIAPU->_Carry)
-#define APUCheckInterrupt() (pIAPU->P & Interrupt)
-#define APUCheckHalfCarry() (pIAPU->P & HalfCarry)
-#define APUCheckBreak() (pIAPU->P & BreakFlag)
-#define APUCheckDirectPage() (pIAPU->P & DirectPageFlag)
-#define APUCheckOverflow() (pIAPU->_Overflow)
-#define APUCheckNegative() (pIAPU->_Zero & 0x80)
-
-//#define APUClearFlags(f) (IAPU.P &= ~(f))
-//#define APUSetFlags(f) (IAPU.P |= (f))
-//#define APUCheckFlag(f) (IAPU.P & (f))
-
-typedef union
-{
-#ifdef MSB_FIRST
- struct { uint8 Y, A; } B;
-#else
- struct { uint8 A, Y; } B;
-#endif
- uint16 W;
- uint32 _padder; // make sure this whole thing takes 4 bytes
-} YAndA;
-
-struct SAPURegisters{
- uint8 P;
- YAndA YA;
- uint8 X;
- uint8 S;
- uint16 PC;
-};
-
-//EXTERN_C struct SAPURegisters APURegisters;
-
-// Needed by ILLUSION OF GAIA
-//#define ONE_APU_CYCLE 14
-#define ONE_APU_CYCLE 21
-
-// Needed by all games written by the software company called Human
-//#define ONE_APU_CYCLE_HUMAN 17
-#define ONE_APU_CYCLE_HUMAN 21
-
-// 1.953us := 1.024065.54MHz
-
-// return cycles left (always negative)
-extern "C" int spc700_execute(int cycles);
-extern "C" uint32 Spc700JumpTab;
-
-#ifdef SPCTOOL
-EXTERN_C int32 ESPC (int32);
-
-#define APU_EXECUTE() \
-{ \
- int32 l = (CPU.Cycles - CPU.APU_Cycles) / 14; \
- if (l > 0) \
- { \
- l -= _EmuSPC(l); \
- CPU.APU_Cycles += l * 14; \
- } \
-}
-
-#else
-
-#ifdef DEBUGGER
-#define APU_EXECUTE1() \
-{ \
- if (APU.Flags & TRACE_FLAG) \
- S9xTraceAPU ();\
- CPU.APU_Cycles += S9xAPUCycles [*IAPU.PC]; \
- (*S9xApuOpcodes[*IAPU.PC]) (); \
-}
-#else
-#define APU_EXECUTE1() \
-{ \
- IAPU.asmJumpTab = &Spc700JumpTab; \
- memcpy(&IAPU2, &IAPU, sizeof(IAPU)); \
- CPU.APU_Cycles += S9xAPUCycles [*IAPU.PC]; \
- IAPU.opcode = *IAPU.PC; \
- pIAPU = &IAPU; \
- (*S9xApuOpcodes[*IAPU.PC]) (); \
- if(IAPU._Carry) IAPU.P |= Carry; else IAPU.P &= ~Carry; \
- if(IAPU._Overflow) IAPU.P |= Overflow; else IAPU.P &= ~Overflow; \
- pIAPU = &IAPU2; \
- spc700_execute(0); \
- APUCompare(); \
- IAPU.ya_prev = IAPU.YA.W; \
- IAPU.x_prev = IAPU.X; \
-}
-#endif
-
-#define APU_EXECUTE(mode) \
-if (CPU.APU_APUExecuting == mode) \
-{\
- while (CPU.APU_Cycles <= CPU.Cycles) \
- APU_EXECUTE1(); \
-}
-#endif
-
-#endif
diff --git a/old/spc700/spcgen.c b/old/spc700/spcgen.c deleted file mode 100644 index 3ac06d6..0000000 --- a/old/spc700/spcgen.c +++ /dev/null @@ -1,2164 +0,0 @@ -// notaz's SPC700 Emulator
-// (c) Copyright 2006 notaz, All rights reserved.
-//
-// Added some modifications by Bitrider 2010-2011.
-//
-// this is a rewrite of spc700.cpp in ARM asm, inspired by other asm CPU cores like
-// Cyclone and DrZ80. It is meant to be used in Snes9x emulator ports for ARM platforms.
-//
-// notes:
-// "Shutdown" mechanism is not supported, so undefine SPC700_SHUTDOWN in your port.h
-// code branches backwards over start of memory are not supported
-// (never seen any game doing that)
-//
-// license:
-// the code is released under Snes9x license. It would be nice if the word "notaz"
-// would appear somewhere in your documentation or your program's "about" screen
-// if you use this :)
-
-/*
- * Permission to use, copy, modify and distribute Snes9x in both binary and
- * source form, for non-commercial purposes, is hereby granted without fee,
- * providing that this license information and copyright notice appear with
- * all copies and any derived work.
- *
- * This software is provided 'as-is', without any express or implied
- * warranty. In no event shall the authors be held liable for any damages
- * arising from the use of this software.
- *
- * Snes9x is freeware for PERSONAL USE only. Commercial users should
- * seek permission of the copyright holders first. Commercial use includes
- * charging money for Snes9x or software derived from Snes9x.
- *
- * The copyright holders request that bug fixes and improvements to the code
- * should be forwarded to them so everyone can benefit from the modifications
- * in future versions.
- *
- * Super NES and Super Nintendo Entertainment System are trademarks of
- * Nintendo Co., Limited and its subsidiary companies.
- */
-
-int one_apu_cycle[] = {13, 14, 15, 21};
-int current_cycles;
-
-
-// settings
-#define VERSION "0.12"
-#define APU_EXECUTING_OFF 124
-//#define SPC_DEBUG
-
-
-// includes
-#include <stdio.h>
-#include <stdarg.h>
-#include <string.h>
-#include <stdlib.h>
-
-
-// timings
-int S9xAPUCycles [256] =
-{
- /* 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, a, b, c, d, e, f, */
- /* 00 */ 2, 8, 4, 5, 3, 4, 3, 6, 2, 6, 5, 4, 5, 4, 6, 8,
- /* 10 */ 2, 8, 4, 5, 4, 5, 5, 6, 5, 5, 6, 5, 2, 2, 4, 6,
- /* 20 */ 2, 8, 4, 5, 3, 4, 3, 6, 2, 6, 5, 4, 5, 4, 5, 4,
- /* 30 */ 2, 8, 4, 5, 4, 5, 5, 6, 5, 5, 6, 5, 2, 2, 3, 8,
- /* 40 */ 2, 8, 4, 5, 3, 4, 3, 6, 2, 6, 4, 4, 5, 4, 6, 6,
- /* 50 */ 2, 8, 4, 5, 4, 5, 5, 6, 5, 5, 4, 5, 2, 2, 4, 3,
- /* 60 */ 2, 8, 4, 5, 3, 4, 3, 6, 2, 6, 4, 4, 5, 4, 5, 5,
- /* 70 */ 2, 8, 4, 5, 4, 5, 5, 6, 5, 5, 5, 5, 2, 2, 3, 6,
- /* 80 */ 2, 8, 4, 5, 3, 4, 3, 6, 2, 6, 5, 4, 5, 2, 4, 5,
- /* 90 */ 2, 8, 4, 5, 4, 5, 5, 6, 5, 5, 5, 5, 2, 2,12, 5,
- /* a0 */ 3, 8, 4, 5, 3, 4, 3, 6, 2, 6, 4, 4, 5, 2, 4, 4,
- /* b0 */ 2, 8, 4, 5, 4, 5, 5, 6, 5, 5, 5, 5, 2, 2, 3, 4,
- /* c0 */ 3, 8, 4, 5, 4, 5, 4, 7, 2, 5, 6, 4, 5, 2, 4, 9,
- /* d0 */ 2, 8, 4, 5, 5, 6, 6, 7, 4, 5, 4, 5, 2, 2, 6, 3,
- /* e0 */ 2, 8, 4, 5, 3, 4, 3, 6, 2, 4, 5, 3, 4, 3, 4, 3,
- /* f0 */ 2, 8, 4, 5, 4, 5, 5, 6, 3, 4, 5, 4, 2, 2, 4, 3
-};
-
-
-// stuff
-static FILE *AsmFile=NULL;
-static int opcode=0; // 0-0xff
-static int ibuffer = 0;
-static char buff[1024];
-
-
-void ot(char *format, ...)
-{
- va_list valist;
- int i, len;
-
- // notaz: stop me from leaving newlines in the middle of format string
- // and generating bad code
- for(i=0, len=strlen(format); i < len && format[i] != '\n'; i++);
- if(i < len-1 && format[len-1] != '\n') printf("\nWARNING: possible improper newline placement:\n%s\n", format);
-
- va_start(valist,format);
- if (AsmFile) vfprintf(AsmFile,format,valist);
- va_end(valist);
-}
-
-// ot buffered
-void otb(char *format, ...)
-{
- va_list valist;
- int i, len;
-
- // notaz: stop me from leaving newlines in the middle of format string
- // and generating bad code
- for(i=0, len=strlen(format); i < len && format[i] != '\n'; i++);
- if(i < len-1 && format[len-1] != '\n') printf(buff, "\nWARNING: possible improper newline placement:\n%s\n", format);
-
- va_start(valist,format);
- if (AsmFile) vsprintf(buff,format,valist);
- ibuffer = 1;
- va_end(valist);
-}
-
-void flush_buffer() {
- if (ibuffer != 0) {
- ot(buff);
- ibuffer = 0;
- }
-}
-
-// trashes: r0, r1, r2
-// return: r0
-// exit at label "2"
-static void GetAPUDSP() {
- ot("GetAPUDSP: \n");
- ot(" ldrb r1, [spc_ram, #0xf2] \n");
- // r1 = IAPU.RAM [0xf2]
-
- ot(" mov r0, #0\n");
- ot(" and r2, r1, #0X0f \n");
- // switch (reg & 0xf) {
- ot(" cmp r2, #0x08\n");
- ot(" bxeq lr\n"); // APU_ENVX = 8
- // r1 = IAPU.RAM [0xf2] & 0x7f;
-
- ot(" cmp r2, #0x09\n");
- // return APU.DSP [reg];
- ot(" ldrne r2, .APU_DSP\n");
- ot(" and r1, r1, #0X7f \n"); // r1 = IAPU.RAM[0xf2] & 0x7f
- ot(" ldrneb r0, [r2, r1] \n");
- ot(" bxne lr \n");
-
- // APU_OUTX = 9
- // if (SoundData.channels [reg >> 4].state == SOUND_SILENT) return 0;
- // return ((SoundData.channels [reg >> 4].sample >> 8) | (SoundData.channels [reg >> 4].sample & 0x
- ot(" ldr r2, .SOUNDDATA_CHANNELS\n");
- ot(" mov r1, r1, lsr #4 \n");
- //ot(" add r1, r2, r1, asl #8\n");
- //ot(" ldr r0, [r1, #0x0] \n"); // r0 = SoundData.channels[reg >> 4].state
- ot(" ldr r0, [r2, r1, asl #8] \n");
- ot(" add r1, r2, r1, asl #8\n");
- ot(" cmp r0, #0 \n"); // SOUND_SILENT = 0
- ot(" ldrneh r1, [r1, #0x48] \n"); // r1 = SoundData.channels[reg >> 4].sample
- ot(" bxeq lr \n");
-
- ot(" and r0, r1, #0xff\n");
- ot(" orr r0, r0, r1, lsr #8\n");
- ot(" bx lr \n");
-
- ot(".APU_DSP:\n");
- ot(" .long APU + 0x0b\n"); // &APU.DSP
- ot(".SOUNDDATA_CHANNELS:\n");
- ot(" .long SoundData + 0x30\n"); // &SoundData.channels[0]
-}
-
-
-// bitrider
-// macros
-static void GetByte() {
- ot(" mov r1, r0\n");
-
- ot(" ldrb r0, [spc_ram, r1] \n");
-
- ot(" cmp r1, #0x0ff\n");
- ot(" bhi 1f \n");
-
- ot(" cmp r1, #0xf3 \n");
- ot(" addeq lr, pc, #12 \n"); // lr = &ExitPoint
- ot(" beq GetAPUDSP \n");
-
- ot(" cmp r1, #0xfd \n");
- ot(" movhs r2, #0 \n");
- ot(" strhsb r2, [spc_ram, r1] \n");
- ot("1:\n");
-
-
-}
-
-// trashes: r0, r1, r14
-static void GetByteZ() {
- ot(" mov r1, r0\n");
-
- ot(" cmp r1, #0xf3 \n");
- ot(" addeq lr, pc, #20 \n"); // lr = &ExitPoint
- ot(" beq GetAPUDSP \n");
-
- ot(" ldr r14, [context, #iapu_directpage]\n");
- ot(" cmp r1, #0xfd \n");
- ot(" ldrb r0, [r14, r1] \n");
- ot(" movhs r2, #0 \n");
- ot(" strhsb r2, [r14, r1] \n");
-}
-
-static void SetByte(int restore) {
- // Still should check for ShowRom
- ot(" add r2, r1, #40 \n");
- ot(" tst r2, #0x10000 \n");
- ot(" bne 1f \n");
-
- ot(" bic r2, r1, #0x0f\n");
- ot(" cmp r2, #0xf0\n");
- ot(" strneb r0, [spc_ram, r1] \n");
- ot(" bne 3f\n");
-
- ot(" add lr, pc, #20\n");
-
- ot(" cmp r1, #0xf1 \n");
- ot(" beq S9xSetAPUControl \n");
-
- ot(" cmp r1, #0xf3 \n"); // pc + 4
- ot(" beq S9xSetAPUDSP \n"); // pc + 8
- ot(" b S9xAPUSetByteFFtoF0 \n"); // pc + 12
-
- ot("1: \n");
- ot(" bl S9xAPUSetByteFFC0 \n");
- ot(" ldr spc_ram, [context, #iapu_ram] \n");
- ot("3: \n");
-
-}
-
-static void SetByteZ(int restore) {
- ot(" ldr r2, [context, #iapu_directpage] \n");
- ot(" cmp r2, spc_ram \n");
- ot(" bne 2f \n");
-
- ot(" cmp r1, #0xf0 \n");
- ot(" blo 2f \n");
-
- ot(" cmp r1, #0xfe \n");
- ot(" bhs 1f \n");
-
- if (restore) ot(" add lr, pc, #16\n");
- else ot(" add lr, pc, #20\n");
-
- ot(" cmp r1, #0xf1 \n");
- ot(" beq S9xSetAPUControl \n");
-
- ot(" cmp r1, #0xf3 \n"); // pc + 4
- ot(" beq S9xSetAPUDSP \n"); // pc + 8
- ot(" b S9xAPUSetByteFFtoF0 \n"); // pc + 12
- //ot("6: \n"); // pc + 16
- if (restore) {
- ot(" ldr spc_ram, [context, #iapu_ram] \n");
- ot(" b 1f \n");
- }
- ot("2: \n");
- ot(" strb r0, [r2, r1] \n");
- ot("1: \n");
-}
-
-
-// r0-2: Temporary registers
-// r3 : current opcode or temp
-// r4 : Cycles remaining
-// r5 : Pointer to IAPU structure
-// r6 : Pointer to Opcode Jump table
-// r7 : Current PC
-// r8 : YA
-// r9 : P (nzzzzzzz ........ ........ NODBHIZC; nzzzzzzz - NZ flag in use (for a little speedup)
-
-// r10 : X
-// r11 : S
-// r14 : temp
-// lr : RAM pointer
-
-static void PrintFramework()
-{
-
-
-#ifndef SPC_DEBUG
- ot(" .extern IAPU\n");
-#else
- ot(" .extern IAPU2\n");
-#endif
- ot(" .extern CPU @ for STOP and SLEEP\n");
- ot(" .extern S9xAPUGetByte\n");
- ot(" .extern S9xAPUSetByte\n");
- ot(" .extern S9xAPUGetByteZ\n");
- ot(" .extern S9xAPUSetByteZ\n\n");
-
- // bitrider
- ot(" .extern S9xGetAPUDSP\n");
- ot(" .extern S9xSetAPUDSP\n");
- ot(" .extern S9xSetAPUControl\n");
- ot(" .extern S9xAPUSetByteFFC0\n");
- ot(" .extern S9xAPUSetByteFFtoF0\n");
-
- ot(" .global spc700_execute @ int cycles\n");
- //ot(" .global Spc700JumpTab\n\n");
- for (current_cycles=0; current_cycles < (sizeof(one_apu_cycle) / sizeof(int)); current_cycles++)
- ot(" .global Spc700JumpTab_%i\n", one_apu_cycle[current_cycles]);
- ot("\n");
-
-
- ot(" opcode .req r3\n");
- ot(" cycles .req r4\n");
- ot(" context .req r5\n");
- ot(" opcodes .req r6\n");
- ot(" spc_pc .req r7\n");
- ot(" spc_ya .req r8\n");
- ot(" spc_p .req r9\n");
- ot(" spc_x .req r10\n");
- ot(" spc_s .req r11\n");
- ot(" spc_ram .req r12\n\n");
-
- ot(" .equ iapu_directpage, 0x00\n");
- ot(" .equ iapu_ram, 0x44\n");
- ot(" .equ iapu_extraram, 0x48\n");
- ot(" .equ iapu_allregs_load, 0x30\n");
- ot(" .equ iapu_allregs_save, 0x34\n\n");
-
- ot(" .equ flag_c, 0x01\n");
- ot(" .equ flag_z, 0x02\n");
- ot(" .equ flag_i, 0x04\n");
- ot(" .equ flag_h, 0x08\n");
- ot(" .equ flag_b, 0x10\n");
- ot(" .equ flag_d, 0x20\n");
- ot(" .equ flag_o, 0x40\n");
- ot(" .equ flag_n, 0x80\n\n");
-
- ot(" .equ cpu_apu_executing, %i \n\n", APU_EXECUTING_OFF);
- // tmp
-// ot(" .equ iapu_carry, 0x24\n");
-// ot(" .equ iapu_overflow, 0x26\n\n");
-
- ot("@ --------------------------- Framework --------------------------\n");
- ot(" .align 4\n");
- ot("spc700_execute: @ int cycles\n");
-
- ot(" stmfd sp!,{r4-r11,lr}\n");
-
-#ifndef SPC_DEBUG
- ot(" ldr context,=IAPU @ Pointer to SIAPU struct\n");
-#else
- ot(" ldr context,=IAPU2 @ Pointer to SIAPU struct\n");
-#endif
- ot(" mov cycles,r0 @ Cycles\n");
- ot(" add r0,context,#iapu_allregs_load\n");
- ot(" ldmia r0,{opcodes,spc_pc,spc_ya,spc_p,spc_x,spc_ram}\n");
-
- ot(" ldrb opcode,[spc_pc],#1 @ Fetch first opcode\n");
- ot(" mov spc_s,spc_x,lsr #8\n");
- ot(" and spc_x,spc_x,#0xff\n");
- ot("\n");
-
- ot(" ldr pc,[opcodes,opcode,lsl #2] @ Jump to opcode handler\n");
- ot("\n\n");
-
-
- ot("@ We come back here after execution\n");
- ot("spc700End:\n");
- ot(" orr spc_x,spc_x,spc_s,lsl #8\n");
- ot(" add r0,context,#iapu_allregs_save\n");
- ot(" stmia r0,{spc_pc,spc_ya,spc_p,spc_x}\n");
- ot(" mov r0,cycles\n");
- ot(" ldmfd sp!,{r4-r11,pc}\n");
- ot("\n");
-
- ot(" .ltorg\n");
- ot("\n");
-
- GetAPUDSP();
-}
-
-
-// ---------------------------------------------------------------------------
-
-// Trashes r0-r3
-static void MemHandler(int set, int z, int save)
-{
- //if(set) ot(" bl S9xAPUSetByte%s\n", z ? "Z" : "");
- //else ot(" bl S9xAPUGetByte%s\n", z ? "Z" : "");
-
- //if(set) ot(" asm_S9xAPUSetByte%s\n", z ? "Z" : "");
- //else ot(" asm_S9xAPUGetByte%s\n", z ? "Z" : "");
- if(set) {
- if (z) SetByteZ(save);
- else SetByte(save);
- } else {
- if (z) GetByteZ();
- else GetByte();
- }
-
- //if(save) ot(" ldr spc_ram,[context,#iapu_ram]\n");
-}
-
-// pushes reg, trashes r1
-static void Push(char *reg)
-{
- ot(" add r1,spc_ram,spc_s\n");
- ot(" strb %s,[r1,#0x100]\n", reg);
- ot(" sub spc_s,spc_s,#1\n");
-}
-
-// pushes r0, trashes r0,r1
-static void PushW()
-{
- ot(" add r1,spc_ram,spc_s\n");
- ot(" sub spc_s,spc_s,#2\n");
- ot(" strb r0,[r1,#0xff]\n");
- ot(" mov r0,r0,lsr #8\n");
- ot(" strb r0,[r1,#0x100]\n");
-}
-
-// pops to reg
-static void Pop(char *reg)
-{
- ot(" add %s,spc_ram,spc_s\n", reg);
- ot(" ldrb %s,[%s,#(0x100 + 1)]\n", reg, reg);
- ot(" add spc_s,spc_s,#1\n");
-}
-
-// pops to r0, trashes r1
-static void PopW()
-{
- ot(" add r1,spc_ram,spc_s\n");
- ot(" ldrb r0,[r1,#(0xff + 2)]\n");
- ot(" ldrb r1,[r1,#(0x100 + 2)]\n");
- ot(" add spc_s,spc_s,#2\n");
- ot(" orr r0,r0,r1,lsl #8\n");
-}
-
-// // rr <- absolute, trashes r14
-// rr <- absolute
-
-static void AbsoluteAdd(int r, char *rAdd)
-{
- ot(" ldrb r%i,[spc_pc],#1\n", r);
- ot(" ldrb r14,[spc_pc],#1\n");
- if (rAdd) ot(" add r%i,r%i,%s\n", r, r, rAdd);
- ot(" add r%i,r%i,r14,lsl #8\n", r, r);
-}
-
-// // rr <- absolute, trashes r14
-// rr <- absolute
-static void Absolute(int r)
-{
- //ot(" ldrb r%i,[spc_pc],#1\n", r);
- //ot(" ldrb r14,[spc_pc],#1\n");
- //ot(" orr r%i,r%i,r14,lsl #8\n", r, r);
- AbsoluteAdd(r, NULL);
-}
-
-
-// rr <- absoluteX, trashes r14
-static void AbsoluteX(int r)
-{
- //Absolute(r);
- //ot(" ldrb r%i,[spc_pc],#1\n", r);
- //ot(" ldrb r14,[spc_pc],#1\n");
- //ot(" add r%i,r%i,spc_x\n", r, r);
- //ot(" add r%i,r%i,r14,lsl #8\n", r, r);
- AbsoluteAdd(r, "spc_x");
-}
-
-// r0 <- absoluteY, trashes r1
-static void AbsoluteY(int r)
-{
- //Absolute(r);
- //ot(" ldrb r%i,[spc_pc],#1\n", r);
- //ot(" ldrb r14,[spc_pc],#1\n");
- //ot(" add r%i,r%i,spc_ya,lsr #8\n", r, r);
- //ot(" add r%i,r%i,r14,lsl #8\n", r, r);
- AbsoluteAdd(r, "spc_ya, lsr #8");
-}
-
-// rr <- IndirectIndexedY, trashes r14
-static void IndirectIndexedY(int r)
-{
- ot(" ldrb r%i,[spc_pc],#1\n", r);
- ot(" ldr r14,[context,#iapu_directpage]\n");
- ot(" ldrb r%i,[r14,r%i]!\n", r, r);
- ot(" ldrb r14,[r14,#1]\n");
- //ot(" orr r%i,r%i,r14,lsl #8\n", r, r);
- ot(" add r%i,r%i,spc_ya,lsr #8\n", r, r);
- ot(" add r%i,r%i,r14,lsl #8\n", r, r);
-}
-
-// rr <- address, trashes r14
-static void IndexedXIndirect(int r)
-{
- ot(" ldrb r%i,[spc_pc],#1\n", r);
- ot(" ldr r14,[context,#iapu_directpage]\n"); // again, interlocks are bad
- ot(" add r%i,r%i,spc_x\n", r, r);
- ot(" and r%i,r%i,#0xff\n", r, r);
- ot(" ldrb r%i,[r14,r%i]!\n", r, r);
- ot(" ldrb r14,[r14,#1]\n");
- ot(" orr r%i,r%i,r14,lsl #8\n", r, r);
-}
-
-// sets ZN for reg in *reg, not suitable for Y
-static void SetZN8(char *reg)
-{
- ot(" and spc_p,spc_p,#0xff\n");
- ot(" orr spc_p,spc_p,%s,lsl #24\n", reg);
-}
-
-// sets ZN for reg in *reg
-static void SetZN16(char *reg)
-{
- ot(" and spc_p,spc_p,#0xff\n");
- ot(" orr spc_p,spc_p,%s,lsl #16\n", reg);
- ot(" tst %s,#0xff\n", reg);
- ot(" orrne spc_p,spc_p,#0x01000000\n");
-}
-
-// does ROL on r0, sets flags
-static void Rol()
-{
- ot(" mov r0,r0,lsl #1\n");
- ot(" tst spc_p,#flag_c\n");
- ot(" orrne r0,r0,#1\n");
- ot(" tst r0,#0x100\n");
- ot(" orrne spc_p,spc_p,#flag_c\n");
- ot(" biceq spc_p,spc_p,#flag_c\n");
- SetZN8("r0");
-}
-
-// does ROR on r0, sets flags
-static void Ror()
-{
- ot(" tst spc_p,#flag_c\n");
- ot(" orrne r0,r0,#0x100\n");
- ot(" movs r0,r0,lsr #1\n");
- ot(" orrcs spc_p,spc_p,#flag_c\n");
- ot(" biccc spc_p,spc_p,#flag_c\n");
- SetZN8("r0");
-}
-
-// does ASL on r0, sets flags but doesn't cut the shifted bits
-static void Asl()
-{
- ot(" tst r0,#0x80\n");
- ot(" orrne spc_p,spc_p,#flag_c\n");
- ot(" biceq spc_p,spc_p,#flag_c\n");
- ot(" mov r0,r0,lsl #1\n");
- SetZN8("r0");
-}
-
-// does LSR on r0, sets flags
-static void Lsr()
-{
- ot(" tst r0,#0x01\n");
- ot(" orrne spc_p,spc_p,#flag_c\n");
- ot(" biceq spc_p,spc_p,#flag_c\n");
- ot(" mov r0,r0,lsr #1\n");
- SetZN8("r0");
-}
-
-// CMP rr0,rr1; trashes r14
-static void Cmp(char *r0, char *r1, int and_r0)
-{
- char *lop = r0;
-
- if(and_r0) { ot(" and r14,%s,#0xff\n", r0); lop = "r14"; }
- ot(" subs r14,%s,%s\n", lop, r1);
- //ot(" orrge spc_p,spc_p,#flag_c\n");
- //ot(" biclt spc_p,spc_p,#flag_c\n");
- ot(" orrcs spc_p,spc_p,#flag_c\n");
- ot(" biccc spc_p,spc_p,#flag_c\n");
- SetZN8("r14");
-}
-
-// ADC rr0,rr1 -> rr0, trashes r2,r14, does not mask to byte
-static void Adc(char *r0, char *r1)
-{
- ot(" eor r2,%s,%s\n", r0, r1); // r3=(a) ^ (b)
- ot(" movs r14, spc_p, lsr #1\n");
- ot(" adc %s, %s, %s\n", r0, r0, r1);
- //ot(" add %s,%s,%s\n", r0, r0, r1);
- //ot(" tst spc_p,#flag_c\n");
- //ot(" addne %s,%s,#1\n", r0, r0);
- ot(" movs r14,%s,lsr #8\n", r0);
- ot(" orrne spc_p,spc_p,#flag_c\n");
- ot(" biceq spc_p,spc_p,#flag_c\n");
- ot(" eor r14,%s,%s\n", r0, r1); // r14=(b) ^ Work16
- ot(" bic r14,r14,r2\n"); // ((b) ^ Work16) & ~((a) ^ (b))
- ot(" tst r14,#0x80\n");
- ot(" orrne spc_p,spc_p,#flag_o\n");
- ot(" biceq spc_p,spc_p,#flag_o\n");
- ot(" eor r14,r2,%s\n", r0);
- ot(" tst r14,#0x10\n");
- ot(" orrne spc_p,spc_p,#flag_h\n");
- ot(" biceq spc_p,spc_p,#flag_h\n");
-}
-
-// SBC rr0,rr1 -> rr0, trashes r2,r3,r14, does not mask to byte
-static void Sbc(char *r0, char *r1)
-{
- ot(" movs r14,spc_p,lsr #1\n");
- ot(" sbcs r2,%s,%s\n", r0, r1);
- ot(" orrge spc_p,spc_p,#flag_c\n");
- ot(" biclt spc_p,spc_p,#flag_c\n");
- ot(" eor r14,%s,r2\n", r0); // r14=(a) ^ Int16
- ot(" eor r3,%s,%s\n", r0, r1); // r3=(a) ^ (b)
- ot(" and r14,r14,r3\n"); // ((a) ^ Work16) & ((a) ^ (b))
- ot(" tst r14,#0x80\n");
- ot(" orrne spc_p,spc_p,#flag_o\n");
- ot(" biceq spc_p,spc_p,#flag_o\n");
- ot(" eor r14,r3,r2\n");
- ot(" tst r14,#0x10\n");
- ot(" orreq spc_p,spc_p,#flag_h\n");
- ot(" bicne spc_p,spc_p,#flag_h\n");
- ot(" mov %s,r2\n", r0);
-}
-
-
-//
-static void TCall()
-{
- ot(" sub r0,spc_pc,spc_ram\n");
- PushW();
- ot(" ldr r0,[context,#iapu_extraram]\n");
- ot(" ldrh r0,[r0,#0x%x]\n", (15-(opcode>>4))<<1);
- ot(" add spc_pc,spc_ram,r0\n");
-}
-
-//
-static void SetClr1()
-{
- ot(" ldrb r0,[spc_pc]\n");
- MemHandler(0, 1, 0);
- ot(" %s r0,r0,#0x%02x\n", opcode & 0x10 ? "bic" : "orr", 1<<(opcode>>5));
- ot(" ldrb r1,[spc_pc],#1\n");
- MemHandler(1, 1, 1);
-}
-
-//
-static void BssBbc()
-{
- ot(" ldrb r0,[spc_pc],#1\n");
- MemHandler(0, 1, 1);
- ot(" tst r0,#0x%02x\n", 1<<(opcode>>5));
- ot(" add%s spc_pc,spc_pc,#1\n", opcode & 0x10 ? "ne" : "eq");
- ot(" ldr%ssb r0,[spc_pc],#1\n", opcode & 0x10 ? "eq" : "ne");
- ot(" sub%s cycles,cycles,#%i\n",opcode & 0x10 ? "eq" : "ne", one_apu_cycle[current_cycles]*2);
- ot(" add%s spc_pc,spc_pc,r0\n", opcode & 0x10 ? "eq" : "ne");
-}
-
-//
-static void Membit()
-{
- ot(" ldrb r0,[spc_pc], #1\n");
- ot(" ldrb r3,[spc_pc], #1\n");
- //ot(" orr spc_x,spc_x,r1,lsl #(29-5)
- ot(" add r3,r0,r3,lsl #8\n"); //@ store membit where it can survive memhandler call\n"); // saving bit 12 ?
- //ot(" mov r1,r1,lsr #5\n");
- //ot(" mov r0,r0,lsl #19\n");
- //ot(" mov r0,r0,lsr #19\n");
- //if((opcode >> 4) >= 0xC) ot(" mov r3, r0\n"); //ot(" stmfd sp!,{r0}\n"); // membit
- ot(" bic r0, r3, #0xe000\n"); // Clear bits 15, 14 & 13 => r0 = r0 & 0x1fff
- MemHandler(0, 0, 0);
- //ot(" mov r1,spc_x,lsr #29\n");
- //ot(" and spc_x,spc_x,#0xff\n");
- ot(" mov r1, r3, lsr #13\n"); // membit = bits[15:13] of memory address
- if((opcode >> 4) < 0xC) {
- ot(" mov r0,r0,lsr r1\n");
- ot(" tst r0,#1\n");
- switch(opcode >> 4) {
- case 0x0: ot(" orrne spc_p,spc_p,#flag_c\n"); break; // OR1 C,membit
- case 0x2: ot(" orreq spc_p,spc_p,#flag_c\n"); break; // OR1 C,not membit
- case 0x4: ot(" biceq spc_p,spc_p,#flag_c\n"); break; // AND1 C,membit
- case 0x6: ot(" bicne spc_p,spc_p,#flag_c\n"); break; // AND1 C, not membit
- case 0x8: ot(" eorne spc_p,spc_p,#flag_c\n"); break; // EOR1 C, membit
- case 0xA: ot(" orrne spc_p,spc_p,#flag_c\n"); // MOV1 C,membit
- ot(" biceq spc_p,spc_p,#flag_c\n"); break;
- }
- } else {
- ot(" mov r2,#1\n");
- ot(" mov r2,r2,lsl r1\n");
- if((opcode >> 4) == 0xC) { // MOV1 membit,C
- ot(" tst spc_p,#flag_c\n");
- ot(" orrne r0,r0,r2\n");
- ot(" biceq r0,r0,r2\n");
- } else { // NOT1 membit
- ot(" eor r0,r0,r2\n");
- }
- //ot(" ldmfd sp!,{r1}\n");
- ot(" bic r1, r3, #0xe000\n"); // Clear bits 15, 14 & 13 => r0 = r0 & 0x1fff
- MemHandler(1, 0, 0);
- }
- //ot(" ldr spc_ram,[context,#iapu_ram] @ restore what memhandler(s) messed up\n");
-}
-
-//
-static void CBranch()
-{
- int tests[] = { 0x80000000, 0x40, 0x01, 0xff000000 }; // NOCZ
- char *eq = "eq";
- char *ne = "ne";
-
- if((opcode>>6) == 3) { // zero test inverts everything
- eq = "ne";
- ne = "eq";
- }
-
- ot(" tst spc_p,#0x%08X\n", tests[opcode>>6]);
- ot(" add%s spc_pc,spc_pc,#1\n", opcode & 0x20 ? eq : ne);
-/*
- ot(" b%s Apu%02X\n", opcode & 0x20 ? eq : ne, opcode);
- ot(" sub r0,spc_pc,spc_ram\n");
- ot(" ldrsb r1,[spc_pc],#1\n");
- ot(" add r0,r0,r1\n");
- ot(" mov r0,r0,lsl #16\n");
- ot(" add spc_pc,spc_ram,r0,lsr #16\n");
-*/
- ot(" ldr%ssb r0,[spc_pc],#1\n", opcode & 0x20 ? ne : eq);
-
- ot(" sub%s cycles,cycles,#%i\n", opcode & 0x20 ? ne : eq, one_apu_cycle[current_cycles]*2);
- ot(" add%s spc_pc,spc_pc,r0\n", opcode & 0x20 ? ne : eq);
-// ot("Apu%02X:\n", opcode);
-}
-
-// NeededOperation spc_ya,r0 -> spc_ya
-static void ArithOpToA()
-{
- // special A pre-processing
- if((opcode>>5) == 4 || (opcode>>5) == 5) {
- ot(" and r1,spc_ya,#0xff00\n");
- ot(" and spc_ya,spc_ya,#0xff\n");
- }
-
- switch(opcode>>5) {
- case 0: ot(" orr spc_ya,spc_ya,r0\n"); break; // OR
- case 1: ot(" orr r0,r0,#0xff00\n");
- ot(" and spc_ya,spc_ya,r0\n"); break; // AND
- case 2: ot(" eor spc_ya,spc_ya,r0\n"); break; // EOR
- case 3: Cmp("spc_ya", "r0", 1); break; // CMP
- case 4: Adc("spc_ya", "r0"); break; // ADC
- case 5: Sbc("spc_ya", "r0"); break; // SBC
- case 6: printf("MOV (reversed)!?\n"); break; // MOV (reversed)
- case 7: ot(" and spc_ya,spc_ya,#0xff00\n");
- ot(" orr spc_ya,spc_ya,r0\n"); break; // MOV
- }
-
- if((opcode>>5) != 3) SetZN8("spc_ya"); // only if not Cmp
-
- // special A post-processing
- if((opcode>>5) == 4 || (opcode>>5) == 5) {
- ot(" and spc_ya,spc_ya,#0xff\n");
- ot(" orr spc_ya,spc_ya,r1\n");
- }
-}
-
-//
-static void ArithmeticToA()
-{
- switch(opcode&0x1f) {
- case 0x04: // OP A,dp
- ot(" ldrb r0,[spc_pc],#1\n");
- MemHandler(0, 1, 1);
- ArithOpToA();
- break;
-
- case 0x05: // OP A,abs
- Absolute(0);
- MemHandler(0, 0, 1);
- ArithOpToA();
- break;
-
- case 0x06: // OP A,(X)
- ot(" mov r0,spc_x\n");
- MemHandler(0, 1, 1);
- ArithOpToA();
- break;
-
- case 0x07: // OP A,(dp+X)
- IndexedXIndirect(0);
- MemHandler(0, 0, 1);
- ArithOpToA();
- break;
-
- case 0x08: // OP A,#00
- ot(" ldrb r0,[spc_pc],#1\n");
- ArithOpToA();
- break;
-
- case 0x14: // OP A,dp+X
- ot(" ldrb r0,[spc_pc],#1\n");
- ot(" add r0,r0,spc_x\n");
- MemHandler(0, 1, 1);
- ArithOpToA();
- break;
-
- case 0x15: // OP A,abs+X
- AbsoluteX(0);
- MemHandler(0, 0, 1);
- ArithOpToA();
- break;
-
- case 0x16: // OP A,abs+Y
- AbsoluteY(0);
- MemHandler(0, 0, 1);
- ArithOpToA();
- break;
-
- case 0x17: // OP A,(dp)+Y
- IndirectIndexedY(0);
- MemHandler(0, 0, 1);
- ArithOpToA();
- break;
-
- default:
- printf("Op %02X - arithmetic??\n", opcode);
- }
-}
-
-void printOpcodes(int apu_cycles) {
- for(opcode = 0; opcode < 0x100; opcode++) {
- printf("%02X", opcode);
-
- ot("\n\n");
- //tmp_prologue();
- ot("Apu%02X_%i:\n", opcode, apu_cycles);
-
- if((opcode & 0x1f) == 0x10) CBranch(); // BXX
- if((opcode & 0x0f) == 0x01) TCall(); // TCALL X
- if((opcode & 0x0f) == 0x02) SetClr1(); // SET1/CLR1 direct page bit X
- if((opcode & 0x0f) == 0x03) BssBbc(); // BBS/BBC direct page bit X
- if((opcode & 0x1f) == 0x0A) Membit(); // membit ops
- if((opcode & 0x0f) >= 0x04 && (opcode & 0x0f) <= 0x08 && (opcode & 0x1f) != 0x18 && (opcode >> 5) != 6)
- ArithmeticToA();
-
-
- switch(opcode) {
- case 0x00: // NOP
- break;
-
- case 0x3F: // CALL absolute
- Absolute(2);
- ot(" sub r0,spc_pc,spc_ram\n");
- PushW();
- ot(" add spc_pc,spc_ram,r2\n");
- break;
-
- case 0x4F: // PCALL $XX
- ot(" ldrb r2,[spc_pc],#1\n");
- ot(" sub r0,spc_pc,spc_ram\n");
- PushW();
- ot(" add spc_pc,spc_ram,r2\n");
- ot(" add spc_pc,spc_pc,#0xff00\n");
- break;
-
- case 0x09: // OR dp(dest),dp(src)
- ot(" ldrb r0,[spc_pc],#1\n");
- MemHandler(0, 1, 0);
- //ot(" orr spc_x,spc_x,r0,lsl #24 @ save from harm\n");
- ot(" mov r3, r0\n");
- ot(" ldrb r0,[spc_pc]\n");
- MemHandler(0, 1, 0);
- ot(" orr r0, r0, r3\n");
- //ot(" orr r0,r0,spc_x,lsr #24\n");
- //ot(" and spc_x,spc_x,#0xff\n");
- SetZN8("r0");
- ot(" ldrb r1,[spc_pc],#1\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x18: // OR dp,#00
- ot(" ldrb r0,[spc_pc,#1]\n");
- MemHandler(0, 1, 0);
- ot(" ldrb r1,[spc_pc],#1\n");
- ot(" orr r0,r0,r1\n");
- SetZN8("r0");
- ot(" ldrb r1,[spc_pc],#1\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x19: // OR (X),(Y)
- ot(" mov r0,spc_x\n");
- MemHandler(0, 1, 0);
- //ot(" orr spc_x,spc_x,r0,lsl #24\n");
- ot(" mov r3, r0\n");
- ot(" mov r0,spc_ya,lsr #8\n");
- MemHandler(0, 1, 0);
- ot(" orr r0, r3, r0\n");
- //ot(" orr r0,r0,spc_x,lsr #24\n");
- //ot(" and spc_x,spc_x,#0xff\n");
- SetZN8("r0");
- ot(" mov r1,spc_x\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x0B: // ASL dp
- ot(" ldrb r0,[spc_pc]\n");
- MemHandler(0, 1, 0);
- Asl();
- ot(" ldrb r1,[spc_pc],#1\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x0C: // ASL abs
- Absolute(0);
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- MemHandler(0, 0, 0);
- Asl();
- //ot(" ldmfd sp!,{r1}\n");
- ot(" mov r1, r3\n");
- MemHandler(1, 0, 1);
- break;
-
- case 0x1B: // ASL dp+X
- ot(" ldrb r0,[spc_pc],#1\n");
- ot(" add r0,r0,spc_x\n");
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- MemHandler(0, 1, 0);
- Asl();
- //ot(" ldmfd sp!,{r1}\n");
- ot(" mov r1, r3\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x1C: // ASL A
- ot(" tst spc_ya,#0x80\n");
- ot(" orrne spc_p,spc_p,#flag_c\n");
- ot(" biceq spc_p,spc_p,#flag_c\n");
- ot(" and r0,spc_ya,#0x7f\n");
- ot(" and spc_ya,spc_ya,#0xff00\n");
- ot(" orr spc_ya,spc_ya,r0,lsl #1\n");
- SetZN8("spc_ya");
- break;
-
- case 0x0D: // PUSH PSW
- ot(" mov r0,spc_p,lsr #24\n");
- ot(" and r1,r0,#0x80\n");
- ot(" tst r0,r0\n");
- ot(" orreq r1,r1,#flag_z\n");
- ot(" and spc_p,spc_p,#0x7d @ clear N & Z\n");
- ot(" orr spc_p,spc_p,r1\n");
- Push("spc_p");
- otb(" orr spc_p,spc_p,r0,lsl #24\n");
- break;
-
- case 0x2D: // PUSH A
- Push("spc_ya");
- break;
-
- case 0x4D: // PUSH X
- Push("spc_x");
- break;
-
- case 0x6D: // PUSH Y
- ot(" mov r0,spc_ya,lsr #8\n");
- Push("r0");
- break;
-
- case 0x8E: // POP PSW
- Pop("spc_p");
- ot(" and r0,spc_p,#(flag_z|flag_n)\n");
- ot(" eor r0,r0,#flag_z\n");
- ot(" orr spc_p,spc_p,r0,lsl #24\n");
- ot(" tst spc_p,#flag_d\n");
- ot(" addne r0,spc_ram,#0x100\n");
- ot(" moveq r0,spc_ram\n");
- otb(" str r0,[context,#iapu_directpage]\n");
- break;
-
- case 0xAE: // POP A
- Pop("r0");
- ot(" and spc_ya,spc_ya,#0xff00\n");
- otb(" orr spc_ya,spc_ya,r0\n");
- break;
-
- case 0xCE: // POP X
- Pop("spc_x");
- break;
-
- case 0xEE: // POP X
- Pop("r0");
- ot(" and spc_ya,spc_ya,#0xff\n");
- otb(" orr spc_ya,spc_ya,r0,lsl #8\n");
- break;
-
- case 0x0E: // TSET1 abs
- Absolute(0);
- ot(" mov r3, r0\n");
- //ot(" orr spc_x,spc_x,r0,lsl #16 @ save from memhandler\n");
- MemHandler(0, 0, 0);
- ot(" and r2,r0,spc_ya\n");
- SetZN8("r2");
- ot(" orr r0,r0,spc_ya\n");
- ot(" mov r1, r3\n");
- //ot(" mov r1,spc_x,lsr #16\n");
- //ot(" and spc_x,spc_x,#0xff\n");
- MemHandler(1, 0, 1);
- break;
-
- case 0x4E: // TCLR1 abs
- Absolute(0);
- ot(" mov r3, r0\n");
- //ot(" orr spc_x,spc_x,r0,lsl #16 @ save from memhandler\n");
- MemHandler(0, 0, 0);
- ot(" and r2,r0,spc_ya\n");
- SetZN8("r2");
- ot(" bic r0,r0,spc_ya\n");
- ot(" mov r1, r3\n");
- //ot(" mov r1,spc_x,lsr #16\n");
- //ot(" and spc_x,spc_x,#0xff\n");
- MemHandler(1, 0, 1);
- break;
-
- case 0x0F: // BRK
- ot(" sub r0,spc_pc,spc_ram\n");
- PushW();
- ot(" mov r0,spc_p,lsr #24\n");
- ot(" and r1,r0,#0x80\n");
- ot(" tst r0,r0\n");
- ot(" orrne r1,r1,#flag_z\n");
- ot(" and spc_p,spc_p,#0x7d @ clear N & Z\n");
- ot(" orr spc_p,spc_p,r1\n");
- Push("spc_p");
- ot(" orr spc_p,spc_p,#flag_b\n");
- ot(" bic spc_p,spc_p,#flag_i\n");
- ot(" ldr r0,[context,#iapu_extraram]\n");
- ot(" ldrh r0,[r0,#0x20]\n");
- ot(" add spc_pc,spc_ram,r0\n");
- break;
-
- case 0xEF: // SLEEP
- case 0xFF: // STOP: this is to be compatible with yoyofr's code
- //ot(" ldr r0,=CPU\n");
- ot(" ldr r0, 5001f\n", apu_cycles);
- ot(" mov r1,#0\n");
- //otb(" strb r1,[r0,#122]\n");
- otb(" str r1,[r0,#cpu_apu_executing]\n");
- //tmp_epilogue();
- ot(" subs cycles,cycles,#%i\n", S9xAPUCycles[opcode] * one_apu_cycle[current_cycles]);
- ot(" ldrgeb opcode,[spc_pc],#1\n");
- flush_buffer();
- ot(" ldrge pc,[opcodes,opcode,lsl #2]\n");
- ot(" b spc700End\n");
- // don't let code flow until here
- ot("5001:\n", apu_cycles);
- ot(" .long CPU \n");
- break;
-
- case 0x2F: // BRA
- ot(" ldrsb r0,[spc_pc],#1\n");
- ot(" add spc_pc,spc_pc,r0\n");
- break;
-
- case 0x80: // SETC
- otb(" orr spc_p,spc_p,#flag_c\n");
- break;
-
- case 0xED: // NOTC
- otb(" eor spc_p,spc_p,#flag_c\n");
- break;
-
- case 0x40: // SETP
- ot(" orr spc_p,spc_p,#flag_d\n");
- ot(" add r0,spc_ram,#0x100\n");
- otb(" str r0,[context,#iapu_directpage]\n");
- break;
-
- case 0x1A: // DECW dp
- ot(" ldrb r0,[spc_pc]\n");
- MemHandler(0, 1, 0);
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- ot(" ldrb r0,[spc_pc]\n");
- ot(" add r0,r0,#1\n");
- MemHandler(0, 1, 0);
- //ot(" ldmfd sp!,{r1}\n");
- ot(" orr r1,r3,r0,lsl #8\n");
- ot(" sub r0,r1,#1\n");
- SetZN16("r0");
- ot(" stmfd sp!,{r0}\n");
- ot(" ldrb r1,[spc_pc]\n");
- MemHandler(1, 1, 0);
- ot(" ldmfd sp!,{r0}\n");
- ot(" mov r0,r0,lsr #8\n");
- ot(" ldrb r1,[spc_pc],#1\n");
-
- ot(" add r1,r1,#1\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x5A: // CMPW YA,dp
- ot(" ldrb r0,[spc_pc]\n");
- MemHandler(0, 1, 0);
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- ot(" ldrb r0,[spc_pc],#1\n");
- ot(" add r0,r0,#1\n");
- MemHandler(0, 1, 1);
- //ot(" ldmfd sp!,{r1}\n");
- ot(" orr r1,r3,r0,lsl #8\n");
- ot(" subs r0,spc_ya,r1\n");
- ot(" orrge spc_p,spc_p,#flag_c\n");
- ot(" biclt spc_p,spc_p,#flag_c\n");
- SetZN16("r0");
- break;
-
- case 0x3A: // INCW dp
- ot(" ldrb r0,[spc_pc]\n");
- MemHandler(0, 1, 0);
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- ot(" ldrb r0,[spc_pc]\n");
- ot(" add r0,r0,#1\n");
- MemHandler(0, 1, 0);
- //ot(" ldmfd sp!,{r1}\n");
- ot(" orr r1,r3,r0,lsl #8\n");
- ot(" add r0,r1,#1\n");
- SetZN16("r0");
- ot(" stmfd sp!,{r0}\n");
- ot(" ldrb r1,[spc_pc]\n");
- MemHandler(1, 1, 0);
- ot(" ldmfd sp!,{r0}\n");
- ot(" mov r0,r0,lsr #8\n");
- ot(" ldrb r1,[spc_pc],#1\n");
- ot(" add r1,r1,#1\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x7A: // ADDW YA,dp
- ot(" ldrb r0,[spc_pc]\n");
- MemHandler(0, 1, 0);
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- ot(" ldrb r0,[spc_pc],#1\n");
- ot(" add r0,r0,#1\n");
- MemHandler(0, 1, 1);
- //ot(" ldmfd sp!,{r1}\n");
- ot(" orr r1,r3,r0,lsl #8\n");
- ot(" add r0,spc_ya,r1\n");
- ot(" movs r2,r0,lsr #16\n");
- ot(" orrne spc_p,spc_p,#flag_c\n");
- ot(" biceq spc_p,spc_p,#flag_c\n");
- ot(" bic r2,r0,#0x00ff0000\n");
- ot(" eor r3,r1,r2\n"); // Work16 ^ (uint16) Work32
- ot(" eor r14,spc_ya,r1\n");
- ot(" mvn r14,r14\n"); // ~(pIAPU->YA.W ^ Work16)
- ot(" and r14,r14,r3\n");
- ot(" tst r14,#0x8000\n");
- ot(" orrne spc_p,spc_p,#flag_o\n");
- ot(" biceq spc_p,spc_p,#flag_o\n");
- ot(" eor r14,r3,spc_ya\n");
- ot(" tst r14,#0x10\n");
- ot(" orrne spc_p,spc_p,#flag_h\n");
- ot(" biceq spc_p,spc_p,#flag_h\n");
- ot(" mov spc_ya,r2\n");
- SetZN16("spc_ya");
-
- break;
-
- case 0x9A: // SUBW YA,dp
- ot(" ldrb r0,[spc_pc]\n");
- MemHandler(0, 1, 0);
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- ot(" ldrb r0,[spc_pc],#1\n");
- ot(" add r0,r0,#1\n");
- MemHandler(0, 1, 1);
- //ot(" ldmfd sp!,{r1}\n");
- ot(" orr r1,r3,r0,lsl #8\n");
- ot(" subs r0,spc_ya,r1\n");
- ot(" orrge spc_p,spc_p,#flag_c\n");
- ot(" biclt spc_p,spc_p,#flag_c\n");
- ot(" mov r2,r0,lsl #16\n");
- ot(" mov r2,r2,lsr #16\n"); // r2=(uint16) Int32
- ot(" eor r3,spc_ya,r2\n"); // r3=pIAPU->YA.W ^ (uint16) Int32
- ot(" eor r14,spc_ya,r1\n");
- ot(" and r14,r14,r3\n");
- ot(" tst r14,#0x8000\n");
- ot(" orrne spc_p,spc_p,#flag_o\n");
- ot(" biceq spc_p,spc_p,#flag_o\n");
- ot(" eor r14,r3,r1\n");
- ot(" tst r14,#0x10\n");
- ot(" bicne spc_p,spc_p,#flag_h\n");
- ot(" orreq spc_p,spc_p,#flag_h\n");
- ot(" mov spc_ya,r2\n");
- SetZN16("spc_ya");
- break;
-
- case 0xBA: // MOVW YA,dp
- ot(" ldrb r0,[spc_pc]\n");
- MemHandler(0, 1, 0);
- ot(" ldrb r1, [spc_pc],#1\n");
- ot(" mov spc_ya, r0\n"); // avoiding inter-locks
- ot(" add r0, r1, #1\n");
- MemHandler(0, 1, 1);
- ot(" orr spc_ya,spc_ya,r0,lsl #8\n");
- SetZN16("spc_ya");
- break;
-
- case 0xDA: // MOVW dp,YA
- ot(" ldrb r1,[spc_pc]\n");
- ot(" mov r0,spc_ya\n");
- MemHandler(1, 1, 0);
- ot(" ldrb r1,[spc_pc],#1\n");
- ot(" mov r0,spc_ya,lsr #8\n"); // avoiding inter-locks
- ot(" add r1,r1,#1\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x69: // CMP dp(dest), dp(src)
- ot(" ldrb r0,[spc_pc],#1\n");
- MemHandler(0, 1, 0);
- ot(" orr spc_x,spc_x,r0,lsl #24\n");
- ot(" ldrb r0,[spc_pc],#1\n");
- MemHandler(0, 1, 1);
- ot(" mov r1,spc_x,lsr #24\n");
- Cmp("r0", "r1", 0);
- otb(" and spc_x,spc_x,#0xff\n");
- break;
-
- case 0x78: // CMP dp,#00
- ot(" ldrb r0,[spc_pc,#1]\n");
- MemHandler(0, 1, 1);
- ot(" ldrb r1,[spc_pc],#2\n");
- Cmp("r0", "r1", 0);
- break;
-
- case 0x79: // CMP (X),(Y)
- ot(" mov r0,spc_x\n");
- MemHandler(0, 1, 0);
- ot(" orr spc_x,spc_x,r0,lsl #24\n");
- ot(" mov r0,spc_ya,lsr #8\n");
- MemHandler(0, 1, 1);
- ot(" mov r1,spc_x,lsr #24\n");
- Cmp("r1", "r0", 0);
- otb(" and spc_x,spc_x,#0xff\n");
- break;
-
- case 0x1E: // CMP X,abs
- Absolute(0);
- MemHandler(0, 0, 1);
- Cmp("spc_x", "r0", 0);
- break;
-
- case 0x3E: // CMP X,dp
- ot(" ldrb r0,[spc_pc],#1\n");
-
- MemHandler(0, 1, 1);
- Cmp("spc_x", "r0", 0);
- break;
-
- case 0xC8: // CMP X,#00
- ot(" ldrb r0,[spc_pc],#1\n");
- Cmp("spc_x", "r0", 0);
- break;
-
- case 0x5E: // CMP Y,abs
- Absolute(0);
- MemHandler(0, 0, 1);
- ot(" mov r1,spc_ya,lsr #8\n");
- Cmp("r1", "r0", 0);
- break;
-
- case 0x7E: // CMP Y,dp
- ot(" ldrb r0,[spc_pc],#1\n");
- MemHandler(0, 1, 1);
- ot(" mov r1,spc_ya,lsr #8\n");
- Cmp("r1", "r0", 0);
- break;
-
- case 0xAD: // CMP Y,#00
- ot(" ldrb r0,[spc_pc],#1\n");
- ot(" mov r1,spc_ya,lsr #8\n");
- Cmp("r1", "r0", 0);
- break;
-
- case 0x1F: // JMP (abs+X)
- AbsoluteX(0);
- ot(" sub sp,sp,#8\n");
- ot(" str r0,[sp,#4]\n");
- MemHandler(0, 0, 0);
- ot(" str r0,[sp]\n");
- ot(" ldr r0,[sp,#4]\n");
- ot(" add r0,r0,#1\n");
- MemHandler(0, 0, 1);
- ot(" ldr r1,[sp],#8\n");
- ot(" orr r0,r1,r0,lsl #8\n");
- ot(" add spc_pc,spc_ram,r0\n");
- break;
-
- case 0x5F: // JMP abs
- //Absolute(0);
- //ot(" add spc_pc,spc_ram,r0\n");
- ot(" ldrb r0, [spc_pc], #1\n");
- ot(" ldrb r14, [spc_pc], #1\n");
- ot(" add spc_pc, r0, spc_ram\n");
- ot(" add spc_pc, spc_pc, r14, lsl #8\n");
- break;
-
- case 0x20: // CLRP
- ot(" bic spc_p,spc_p,#flag_d\n");
- otb(" str spc_ram,[context,#iapu_directpage]\n");
- break;
-
- case 0x60: // CLRC
- otb(" bic spc_p,spc_p,#flag_c\n");
- break;
-
- case 0xE0: // CLRV
- otb(" bic spc_p,spc_p,#(flag_o|flag_h)\n");
- break;
-
- case 0x29: // AND dp(dest), dp(src)
- ot(" ldrb r0,[spc_pc],#1\n");
- MemHandler(0, 1, 0);
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- ot(" ldrb r0,[spc_pc]\n");
- MemHandler(0, 1, 0);
- //ot(" ldmfd sp!,{r1}\n");
- ot(" and r0,r0,r3\n");
- SetZN8("r0");
- ot(" ldrb r1,[spc_pc],#1\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x38: // AND dp,#00
- ot(" ldrb r0,[spc_pc,#1]\n");
- MemHandler(0, 1, 0);
- ot(" ldrb r1,[spc_pc],#2\n");
- ot(" and r0,r0,r1\n");
- SetZN8("r0");
- ot(" ldrb r1,[spc_pc,#-1]\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x39: // AND (X),(Y)
- ot(" mov r0,spc_x\n");
- MemHandler(0, 1, 0);
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- ot(" mov r0,spc_ya,lsr #8\n");
- MemHandler(0, 1, 0);
- //ot(" ldmfd sp!,{r1}\n");
- ot(" and r0,r0,r3\n");
- SetZN8("r0");
- ot(" mov r1,spc_x\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x2B: // ROL dp
- ot(" ldrb r0,[spc_pc]\n");
- MemHandler(0, 1, 0);
- Rol();
- ot(" ldrb r1,[spc_pc],#1\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x2C: // ROL abs
- Absolute(0);
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- MemHandler(0, 0, 0);
- Rol();
- //ot(" ldmfd sp!,{r1}\n");
- ot(" mov r1, r3\n");
- MemHandler(1, 0, 1);
- break;
-
- case 0x3B: // ROL dp+X
- ot(" ldrb r0,[spc_pc]\n");
- ot(" add r0,r0,spc_x\n");
- MemHandler(0, 1, 0);
- Rol();
- ot(" ldrb r1,[spc_pc],#1\n");
- ot(" add r1,r1,spc_x\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x3C: // ROL A
- ot(" and r0,spc_ya,#0xff\n");
- Rol();
- ot(" and r0,r0,#0xff\n");
- ot(" mov spc_ya,spc_ya,lsr #8\n");
- otb(" orr spc_ya,r0,spc_ya,lsl #8\n");
- break;
-
- case 0x2E: // CBNE dp,rel
- ot(" ldrb r0,[spc_pc],#1\n");
- MemHandler(0, 1, 1);
- ot(" and r1,spc_ya,#0xff\n");
- ot(" cmp r0,r1\n");
- ot(" addeq spc_pc,spc_pc,#1\n");
- ot(" ldrnesb r0,[spc_pc],#1\n");
- ot(" subne cycles,cycles,#%i\n", one_apu_cycle[current_cycles]*2);
- ot(" addne spc_pc,spc_pc,r0\n");
- break;
-
- case 0xDE: // CBNE dp+X,rel
- ot(" ldrb r0,[spc_pc],#1\n");
- ot(" add r0,r0,spc_x\n");
- MemHandler(0, 1, 1);
- ot(" and r1,spc_ya,#0xff\n");
- ot(" cmp r0,r1\n");
- ot(" addeq spc_pc,spc_pc,#1\n");
- ot(" ldrnesb r0,[spc_pc],#1\n");
- ot(" addne spc_pc,spc_pc,r0\n");
- ot(" subne cycles,cycles,#%i\n", one_apu_cycle[current_cycles]*2);
- break;
-
- case 0x3D: // INC X
- ot(" add spc_x,spc_x,#1\n");
- ot(" and spc_x,spc_x,#0xff\n");
- SetZN8("spc_x");
- break;
-
- case 0xFC: // INC Y
- ot(" mov r0,spc_ya,lsr #8\n");
- ot(" add r0,r0,#1\n");
- ot(" and r0,r0,#0xff\n");
- SetZN8("r0");
- ot(" and spc_ya,spc_ya,#0xff\n");
- otb(" orr spc_ya,spc_ya,r0,lsl #8\n");
- break;
-
- case 0x1D: // DEC X
- ot(" sub spc_x,spc_x,#1\n");
- ot(" and spc_x,spc_x,#0xff\n");
- SetZN8("spc_x");
- break;
-
- case 0xDC: // DEC Y
- ot(" mov r0,spc_ya,lsr #8\n");
- ot(" sub r0,r0,#1\n");
- ot(" and r0,r0,#0xff\n");
- SetZN8("r0");
- ot(" and spc_ya,spc_ya,#0xff\n");
- otb(" orr spc_ya,spc_ya,r0,lsl #8\n");
- break;
-
- case 0xAB: // INC dp
- ot(" ldrb r0,[spc_pc]\n");
- MemHandler(0, 1, 0);
- ot(" add r0,r0,#1\n");
- SetZN8("r0");
- ot(" ldrb r1,[spc_pc],#1\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0xAC: // INC abs
- Absolute(0);
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- MemHandler(0, 0, 0);
- ot(" add r0,r0,#1\n");
- SetZN8("r0");
- //ot(" ldmfd sp!,{r1}\n");
- ot(" mov r1, r3\n");
- MemHandler(1, 0, 1);
- break;
-
- case 0xBB: // INC dp+X
- ot(" ldrb r0,[spc_pc]\n");
- ot(" add r0,r0,spc_x\n");
- MemHandler(0, 1, 0);
- ot(" add r0,r0,#1\n");
- SetZN8("r0");
- ot(" ldrb r1,[spc_pc],#1\n");
- ot(" add r1,r1,spc_x\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0xBC: // INC A
- ot(" and r0,spc_ya,#0xff\n");
- ot(" add r0,r0,#1\n");
- SetZN8("r0");
- ot(" and r0,r0,#0xff\n");
- ot(" mov spc_ya,spc_ya,lsr #8\n");
- otb(" orr spc_ya,r0,spc_ya,lsl #8\n");
- break;
-
- case 0x8B: // DEC dp
- ot(" ldrb r0,[spc_pc]\n");
- MemHandler(0, 1, 0);
- ot(" sub r0,r0,#1\n");
- SetZN8("r0");
- ot(" ldrb r1,[spc_pc],#1\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x8C: // DEC abs
- Absolute(0);
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- MemHandler(0, 0, 0);
- ot(" sub r0,r0,#1\n");
- SetZN8("r0");
- //ot(" ldmfd sp!,{r1}\n");
- ot(" mov r1, r3\n");
- MemHandler(1, 0, 1);
- break;
-
- case 0x9B: // DEC dp+X
- ot(" ldrb r0,[spc_pc]\n");
- ot(" add r0,r0,spc_x\n");
- MemHandler(0, 1, 0);
- ot(" sub r0,r0,#1\n");
- SetZN8("r0");
- ot(" ldrb r1,[spc_pc],#1\n");
-
- ot(" add r1,r1,spc_x\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x9C: // DEC A
- ot(" and r0,spc_ya,#0xff\n");
- ot(" sub r0,r0,#1\n");
- SetZN8("r0");
- ot(" and r0,r0,#0xff\n");
- ot(" mov spc_ya,spc_ya,lsr #8\n");
- otb(" orr spc_ya,r0,spc_ya,lsl #8\n");
- break;
-
- case 0x49: // EOR dp(dest), dp(src)
- ot(" ldrb r0,[spc_pc],#1\n");
- MemHandler(0, 1, 0);
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- ot(" ldrb r0,[spc_pc]\n");
- MemHandler(0, 1, 0);
- //ot(" ldmfd sp!,{r1}\n");
- ot(" eor r0,r0,r3\n");
- SetZN8("r0");
- ot(" ldrb r1,[spc_pc],#1\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x58: // EOR dp,#00
- ot(" ldrb r0,[spc_pc,#1]\n");
- MemHandler(0, 1, 0);
- ot(" ldrb r1,[spc_pc],#2\n");
- ot(" eor r0,r0,r1\n");
- SetZN8("r0");
- ot(" ldrb r1,[spc_pc,#-1]\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x59: // EOR (X),(Y)
- ot(" mov r0,spc_x\n");
- MemHandler(0, 1, 0);
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- ot(" mov r0,spc_ya,lsr #8\n");
- MemHandler(0, 1, 0);
- //ot(" ldmfd sp!,{r1}\n");
- ot(" eor r0,r0,r3\n");
- SetZN8("r0");
- ot(" mov r1,spc_x\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x4B: // LSR dp
- ot(" ldrb r0,[spc_pc]\n");
- MemHandler(0, 1, 0);
- Lsr();
- ot(" ldrb r1,[spc_pc],#1\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x4C: // LSR abs
- Absolute(0);
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- MemHandler(0, 0, 0);
- Lsr();
- //ot(" ldmfd sp!,{r1}\n");
- ot(" mov r1, r3\n");
- MemHandler(1, 0, 1);
- break;
-
- case 0x5B: // LSR dp+X
- ot(" ldrb r0,[spc_pc]\n");
- ot(" add r0,r0,spc_x\n");
- MemHandler(0, 1, 0);
- Lsr();
- ot(" ldrb r1,[spc_pc],#1\n");
- ot(" add r1,r1,spc_x\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x5C: // LSR A
- ot(" and r0,spc_ya,#0xff\n");
- Lsr();
- ot(" mov spc_ya,spc_ya,lsr #8\n");
- otb(" orr spc_ya,r0,spc_ya,lsl #8\n");
- break;
-
- case 0x7D: // MOV A,X
- ot(" and spc_ya,spc_ya,#0xff00\n");
- ot(" orr spc_ya,spc_ya,spc_x\n");
- SetZN8("spc_ya");
- break;
-
- case 0xDD: // MOV A,Y
- ot(" and spc_ya,spc_ya,#0xff00\n");
- ot(" orr spc_ya,spc_ya,spc_ya,lsr #8\n");
- SetZN8("spc_ya");
- break;
-
- case 0x5D: // MOV X,A
- ot(" and spc_x,spc_ya,#0xff\n");
- SetZN8("spc_x");
- break;
-
- case 0xFD: // MOV Y,A
- ot(" and spc_ya,spc_ya,#0xff\n");
- ot(" orr spc_ya,spc_ya,spc_ya,lsl #8\n");
- SetZN8("spc_ya");
- break;
-
- case 0x9D: // MOV X,SP
- ot(" mov spc_x,spc_s\n");
- SetZN8("spc_x");
- break;
-
- case 0xBD: // SP,X
- otb(" mov spc_s,spc_x\n");
- break;
-
- case 0x6B: // ROR dp
- ot(" ldrb r0,[spc_pc]\n");
- MemHandler(0, 1, 0);
- Ror();
- ot(" ldrb r1,[spc_pc],#1\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x6C: // ROR abs
- Absolute(0);
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- MemHandler(0, 0, 0);
- Ror();
- ot(" mov r1, r3\n");
- //ot(" ldmfd sp!,{r1}\n");
- MemHandler(1, 0, 1);
- break;
-
- case 0x7B: // ROR dp+X
- ot(" ldrb r0,[spc_pc]\n");
- ot(" add r0,r0,spc_x\n");
- MemHandler(0, 1, 0);
- Ror();
- ot(" ldrb r1,[spc_pc],#1\n");
- ot(" add r1,r1,spc_x\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x7C: // ROR A
- ot(" and r0,spc_ya,#0xff\n");
- Ror();
- ot(" mov spc_ya,spc_ya,lsr #8\n");
- otb(" orr spc_ya,r0,spc_ya,lsl #8\n");
- break;
-
- case 0x6E: // DBNZ dp,rel
- ot(" ldrb r0,[spc_pc]\n");
- MemHandler(0, 1, 0);
- ot(" ldrb r1,[spc_pc],#1\n");
- ot(" sub r0,r0,#1\n");
- ot(" tst r0,r0\n");
- ot(" addeq spc_pc,spc_pc,#1\n");
- ot(" ldrnesb r2,[spc_pc],#1\n");
- ot(" addne spc_pc,spc_pc,r2\n");
- ot(" subne cycles,cycles,#%i\n", one_apu_cycle[current_cycles]*2);
- MemHandler(1, 1, 1);
- break;
-
- case 0xFE: // DBNZ Y,rel
- ot(" sub spc_ya,spc_ya,#0x100\n");
- ot(" mov spc_ya,spc_ya,lsl #16\n");
- ot(" mov spc_ya,spc_ya,lsr #16\n");
- ot(" movs r0,spc_ya,lsr #8\n");
- ot(" addeq spc_pc,spc_pc,#1\n");
- ot(" ldrnesb r0,[spc_pc],#1\n");
- ot(" addne spc_pc,spc_pc,r0\n");
- ot(" subne cycles,cycles,#%i\n", one_apu_cycle[current_cycles]*2);
- break;
-
- case 0x6F: // RET
- PopW();
- ot(" add spc_pc,spc_ram,r0\n");
- break;
-
- case 0x7F: // RETI
- Pop("spc_p");
- ot(" and r0,spc_p,#(flag_z|flag_n)\n");
- ot(" eor r0,r0,#flag_z\n");
- ot(" orr spc_p,spc_p,r0,lsl #24\n");
- ot(" tst spc_p,#flag_d\n");
- ot(" addne r0,spc_ram,#0x100\n");
- ot(" moveq r0,spc_ram\n");
- ot(" str r0,[context,#iapu_directpage]\n");
- PopW();
- ot(" add spc_pc,spc_ram,r0\n");
- break;
-
- case 0x89: // ADC dp(dest), dp(src)
- ot(" ldrb r0,[spc_pc],#1\n");
- MemHandler(0, 1, 0);
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- ot(" ldrb r0,[spc_pc]\n");
- MemHandler(0, 1, 0);
- //ot(" ldmfd sp!,{r1}\n");
- //ot(" mov r1, r3\n");
- Adc("r0", "r3");
- SetZN8("r0");
- ot(" ldrb r1,[spc_pc],#1\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x98: // ADC dp,#00
- ot(" ldrb r0,[spc_pc,#1]\n");
- MemHandler(0, 1, 0);
- ot(" ldrb r1,[spc_pc],#2\n");
- Adc("r0", "r1");
- SetZN8("r0");
- ot(" ldrb r1,[spc_pc,#-1]\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x99: // ADC (X),(Y)
- ot(" mov r0,spc_x\n");
- MemHandler(0, 1, 0);
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- ot(" mov r0,spc_ya,lsr #8\n");
- MemHandler(0, 1, 0);
- //ot(" ldmfd sp!,{r1}\n");
- //ot(" mov r1, r3\n");
- Adc("r0", "r3");
- SetZN8("r0");
- ot(" mov r1,spc_x\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x8D: // MOV Y,#00 //-REVISAR
- ot(" ldrb r0,[spc_pc],#1\n");
- ot(" and spc_ya,spc_ya,#0xff\n");
- ot(" orr spc_ya,spc_ya,r0,lsl #8\n");
- SetZN8("r0");
- break;
-
- case 0x8F: // MOV dp,#00 //-REVISAR
- ot(" ldrb r0,[spc_pc],#1\n");
- ot(" ldrb r1,[spc_pc],#1\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0x9E: // DIV YA,X
- ot(" tst spc_x,spc_x @ div by 0?\n");
- ot(" orreq spc_ya,spc_ya,#0xff00\n");
- ot(" orreq spc_ya,spc_ya,#0x00ff\n");
- ot(" orreq spc_p,spc_p,#flag_o\n");
- ot(" beq 1002f\n");
- ot(" bic spc_p,spc_p,#flag_o\n");
-
- // division algo from Cyclone (result in r3, remainder instead of divident)
- ot("@ Divide spc_ya by spc_x\n");
- ot(" mov r3,#0\n");
- ot(" mov r1,spc_x\n");
- ot("\n");
-
- //
- /*ot("@ Shift up divisor till it's just less than numerator\n");
- ot("divshift:\n");
- ot(" cmp r1,spc_ya,lsr #1\n");
- ot(" movls r1,r1,lsl #1\n");
- ot(" bcc divshift\n");
- ot("\n");*/
-
- //optimised version of code provided by William Blair
- ot("@ Shift up divisor till it's just less than numerator\n");
- ot("cmp spc_ya,r1,lsl #8\n");
- ot("movge r1,r1,lsl #8\n");
- ot("cmp spc_ya,r1,lsl #4\n");
- ot("movge r1,r1,lsl #4\n");
- ot("cmp spc_ya,r1,lsl #2\n");
- ot("movge r1,r1,lsl #2\n");
- ot("cmp spc_ya,r1,lsl #1\n");
- ot("movge r1,r1,lsl #1\n");
-
- ot("1001:\n");
- ot(" cmp spc_ya,r1\n");
- ot(" adc r3,r3,r3 ;@ Double r3 and add 1 if carry set\n");
- ot(" subcs spc_ya,spc_ya,r1\n");
- ot(" teq r1,spc_x\n");
- ot(" movne r1,r1,lsr #1\n");
- ot(" bne 1001b\n");
- ot("\n");
-
- ot(" and spc_ya,spc_ya,#0xff\n");
- ot(" and r3,r3,#0xff\n");
- ot(" orr spc_ya,r3,spc_ya,lsl #8\n");
-
- ot("1002:\n");
- SetZN8("spc_ya");
- break;
-
- case 0x9F: // XCN A
- ot(" and r0,spc_ya,#0xff\n");
- ot(" mov r1,r0,lsl #28\n");
- ot(" orr r0,r1,r0,lsl #20\n");
- ot(" and spc_ya,spc_ya,#0xff00\n");
- ot(" orr spc_ya,spc_ya,r0,lsr #24\n");
- SetZN8("spc_ya");
- break;
-
- case 0xA9: // SBC dp(dest), dp(src)
- ot(" ldrb r0,[spc_pc],#1\n");
- MemHandler(0, 1, 0);
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- ot(" ldrb r0,[spc_pc]\n");
- MemHandler(0, 1, 0);
- //ot(" ldmfd sp!,{r1}\n");
- //ot(" mov r1, r3\n");
- Sbc("r0", "r3");
- SetZN8("r0");
- ot(" ldrb r1,[spc_pc],#1\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0xB8: // SBC dp,#00
- ot(" ldrb r0,[spc_pc,#1]\n");
- MemHandler(0, 1, 0);
- ot(" ldrb r1,[spc_pc],#2\n");
- Sbc("r0", "r1");
- SetZN8("r0");
- ot(" ldrb r1,[spc_pc,#-1]\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0xB9: // SBC (X),(Y)
- ot(" mov r0,spc_x\n");
- MemHandler(0, 1, 0);
- //ot(" stmfd sp!,{r0}\n");
- ot(" mov r3, r0\n");
- ot(" mov r0,spc_ya,lsr #8\n");
- MemHandler(0, 1, 0);
- //ot(" ldmfd sp!,{r1}\n");
- //ot(" mov r1, r3\n");
- Sbc("r0", "r3");
- SetZN8("r0");
- ot(" mov r1,spc_x\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0xAF: // MOV (X)+, A
- ot(" mov r0,spc_ya\n");
- ot(" mov r1,spc_x\n");
- MemHandler(1, 1, 1);
- ot(" add spc_x,spc_x,#1\n");
- otb(" and spc_x,spc_x,#0xff\n");
- break;
-
- case 0xBE: // DAS
- ot(" and r0,spc_ya,#0xff\n");
- ot(" and r1,spc_ya,#0x0f\n");
- ot(" cmp r1,#9\n");
- ot(" subhi r0,r0,#6\n");
- ot(" tstls spc_p,#flag_h\n");
- ot(" subeq r0,r0,#6\n");
- ot(" cmp r0,#0x9f\n");
- ot(" bhi 2001f\n");
- ot(" tst spc_p,#flag_c\n");
- ot(" beq 2001f\n");
- ot(" orr spc_p,spc_p,#flag_c\n");
- ot(" b 2002f\n");
- ot("2001:\n"); // tens
- ot(" sub r0,r0,#0x60\n");
- ot(" bic spc_p,spc_p,#flag_c\n");
-
- ot("2002:\n"); // end
- ot(" and spc_ya,spc_ya,#0xff00\n");
- ot(" orr spc_ya,spc_ya,r0\n");
- SetZN8("spc_ya");
- break;
-
- case 0xBF: // MOV A,(X)+
- ot(" mov r0,spc_x\n");
- MemHandler(0, 1, 1);
- ot(" and spc_ya,spc_ya,#0xff00\n");
- ot(" orr spc_ya,spc_ya,r0\n");
- ot(" add spc_x,spc_x,#1\n");
- ot(" and spc_x,spc_x,#0xff\n");
- SetZN8("spc_ya");
- break;
-
- case 0xC0: // DI
- otb(" bic spc_p,spc_p,#flag_i\n");
- break;
-
- case 0xA0: // EI
- otb(" orr spc_p,spc_p,#flag_i\n");
- break;
-
- case 0xC4: // MOV dp,A
- ot(" ldrb r1,[spc_pc],#1\n");
- ot(" mov r0,spc_ya\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0xC5: // MOV abs,A
- Absolute(1);
- ot(" mov r0,spc_ya\n");
- MemHandler(1, 0, 1);
- break;
-
- case 0xC6: // MOV (X),A
- ot(" mov r0,spc_ya\n");
- ot(" mov r1,spc_x\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0xC7: // MOV (dp+X),A
- IndexedXIndirect(1);
- ot(" mov r0,spc_ya\n");
- MemHandler(1, 0, 1);
- break;
-
- case 0xC9: // MOV abs,X
- Absolute(1);
- ot(" mov r0,spc_x\n");
- MemHandler(1, 0, 1);
- break;
-
- case 0xCB: // MOV dp,Y
- ot(" ldrb r1,[spc_pc],#1\n");
- ot(" mov r0,spc_ya,lsr #8\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0xCC: // MOV abs,Y
-
- Absolute(1);
- ot(" mov r0,spc_ya,lsr #8\n");
- MemHandler(1, 0, 1);
- break;
-
- case 0xCD: // MOV X,#00
- ot(" ldrb spc_x,[spc_pc],#1\n");
- SetZN8("spc_x");
- break;
-
- case 0xCF: // MUL YA
- ot(" mov r0,spc_ya,lsr #8\n");
- ot(" and spc_ya,spc_ya,#0xff\n");
- ot(" mul spc_ya,r0,spc_ya\n");
- SetZN16("spc_ya");
- break;
-
- case 0xD4: // MOV dp+X, A
- ot(" ldrb r1,[spc_pc],#1\n");
- ot(" mov r0,spc_ya\n");
- ot(" add r1,r1,spc_x\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0xD5: // MOV abs+X,A
- AbsoluteX(1);
- ot(" mov r0,spc_ya\n");
- MemHandler(1, 0, 1);
- break;
-
- case 0xD6: // MOV abs+Y,A
- AbsoluteY(1);
- ot(" mov r0,spc_ya\n");
- MemHandler(1, 0, 1);
- break;
-
- case 0xD7: // MOV (dp)+Y,A
- IndirectIndexedY(1);
- ot(" mov r0,spc_ya\n");
- MemHandler(1, 0, 1);
- break;
-
- case 0xD8: // MOV dp,X
- ot(" ldrb r1,[spc_pc],#1\n");
- ot(" mov r0,spc_x\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0xD9: // MOV dp+Y,X
- ot(" ldrb r1,[spc_pc],#1\n");
- ot(" mov r0,spc_x\n");
- ot(" add r1,r1,spc_ya,lsr #8\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0xDB: // MOV dp+X,Y
- ot(" ldrb r1,[spc_pc],#1\n");
- ot(" mov r0,spc_ya,lsr #8\n");
- ot(" add r1,r1,spc_x\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0xDF: // DAA
- ot(" and r0,spc_ya,#0xff\n");
- ot(" and r1,spc_ya,#0x0f\n");
- ot(" cmp r1,#9\n");
- ot(" addhi r0,r0,#6\n");
- ot(" bls 3001f\n");
- ot(" cmphi r0,#0xf0\n");
- ot(" orrhi spc_p,spc_p,#flag_c\n");
- ot(" b 3002f\n");
- ot("3001:\n"); // testHc
- ot(" tst spc_p,#flag_h\n");
- ot(" addne r0,r0,#6\n");
- ot(" beq 3002f\n");
- ot(" cmp r0,#0xf0\n");
- ot(" orrhi spc_p,spc_p,#flag_c\n");
- ot("3002:\n"); // test2
- ot(" tst spc_p,#flag_c\n");
- ot(" addne r0,r0,#0x60\n");
- ot(" bne 3003f\n");
- ot(" cmp r0,#0x9f\n");
- ot(" addhi r0,r0,#0x60\n");
- ot(" orrhi spc_p,spc_p,#flag_c\n");
- ot(" bicls spc_p,spc_p,#flag_c\n");
- ot("3003:\n"); // end
- ot(" and spc_ya,spc_ya,#0xff00\n");
- ot(" orr spc_ya,spc_ya,r0\n");
- SetZN8("spc_ya");
- break;
-
- case 0xE9: // MOV X, abs
- Absolute(0);
- MemHandler(0, 0, 1);
- ot(" mov spc_x,r0\n");
- SetZN8("spc_x");
- break;
-
- case 0xEB: // MOV Y,dp
- ot(" ldrb r0,[spc_pc],#1\n");
- MemHandler(0, 1, 1);
- ot(" and spc_ya,spc_ya,#0xff\n");
- ot(" orr spc_ya,spc_ya,r0,lsl #8\n");
- SetZN8("r0");
- break;
-
- case 0xEC: // MOV Y,abs
- Absolute(0);
- MemHandler(0, 0, 1);
- ot(" and spc_ya,spc_ya,#0xff\n");
- ot(" orr spc_ya,spc_ya,r0,lsl #8\n");
- SetZN8("r0");
- break;
-
- case 0xF8: // MOV X,dp
- ot(" ldrb r0,[spc_pc],#1\n");
- MemHandler(0, 1, 1);
- ot(" mov spc_x,r0\n");
- SetZN8("spc_x");
- break;
-
- case 0xF9: // MOV X,dp+Y
- ot(" ldrb r0,[spc_pc],#1\n");
- ot(" add r0,r0,spc_ya,lsr #8\n");
- MemHandler(0, 1, 1);
- ot(" mov spc_x,r0\n");
- SetZN8("spc_x");
- break;
-
- case 0xFA: // MOV dp(dest),dp(src)
- ot(" ldrb r0,[spc_pc],#1\n");
- MemHandler(0, 1, 0);
- ot(" ldrb r1,[spc_pc],#1\n");
- MemHandler(1, 1, 1);
- break;
-
- case 0xFB: // MOV Y,dp+X
- ot(" ldrb r0,[spc_pc],#1\n");
- ot(" add r0,r0,spc_x\n");
- MemHandler(0, 1, 1);
- ot(" and spc_ya,spc_ya,#0xff\n");
- ot(" orr spc_ya,spc_ya,r0,lsl #8\n");
- SetZN8("r0");
- break;
- }
-
- //tmp_epilogue();
- ot(" subs cycles,cycles,#%i\n", S9xAPUCycles[opcode] * one_apu_cycle[current_cycles]);
- ot(" ldrgeb opcode,[spc_pc],#1\n");
- flush_buffer();
- ot(" ldrge pc,[opcodes,opcode,lsl #2]\n");
- ot(" b spc700End\n");
-
- printf("\b\b");
- }
-
-
- ot("\n\n");
-
-}
-
-
-void printJumpTable(int apu_cycles) {
- int i;
- ot("@ -------------------------- Jump Table %i --------------------------\n", apu_cycles);
- ot("Spc700JumpTab_%i:\n", apu_cycles);
-
- for (i=0; i < 0x100; i++)
- {
- if ((i&7)==0) ot(" .long ");
-
- ot("Apu%02X_%i", i, apu_cycles);
-
- if ((i&7)==7) ot(" @ %02x\n",i-7);
- else if (i+1 < 0x100) ot(", ");
- }
-
-}
-
-int main()
-{
- printf("\n notaz's SPC700 Emulator v%s - Core Creator\n\n", VERSION);
-
- // Open the assembly file
- AsmFile=fopen("spc700a.s", "wt"); if (AsmFile==NULL) return 1;
-
- ot("@ notaz's SPC700 Emulator v%s - Assembler Output\n\n", VERSION);
- ot("@ (c) Copyright 2006 notaz, All rights reserved.\n\n");
- ot("@ Modified by bitrider 2010 - 2011\n\n");
- ot("@ this is a rewrite of spc700.cpp in ARM asm, inspired by other asm CPU cores like\n");
- ot("@ Cyclone and DrZ80. It is meant to be used in Snes9x emulator ports for ARM platforms.\n\n");
- ot("@ the code is released under Snes9x license. See spcgen.c or any other source file\n@ from Snes9x source tree.\n\n\n");
-
- PrintFramework();
-
- ot(" .align 4\n");
-
- for (current_cycles=0; current_cycles < (sizeof(one_apu_cycle) / sizeof(int)); current_cycles++) {
- printOpcodes(one_apu_cycle[current_cycles]);
- printJumpTable(one_apu_cycle[current_cycles]);
- }
-
-
- fclose(AsmFile); AsmFile=NULL;
-
- printf("Assembling...\n");
- // Assemble the file
- //system("as -marmv4t -mthumb-interwork -o spc700a.o spc700a.S");
- printf("Done!\n\n");
-
- return 0;
-}
diff --git a/old/tile16.cpp.bak b/old/tile16.cpp.bak deleted file mode 100644 index 76c6eb7..0000000 --- a/old/tile16.cpp.bak +++ /dev/null @@ -1,811 +0,0 @@ -/* - * Snes9x - Portable Super Nintendo Entertainment System (TM) emulator. - * - * (c) Copyright 1996 - 2001 Gary Henderson (gary.henderson@ntlworld.com) and - * Jerremy Koot (jkoot@snes9x.com) - * - * Super FX C emulator code - * (c) Copyright 1997 - 1999 Ivar (ivar@snes9x.com) and - * Gary Henderson. - * Super FX assembler emulator code (c) Copyright 1998 zsKnight and _Demo_. - * - * DSP1 emulator code (c) Copyright 1998 Ivar, _Demo_ and Gary Henderson. - * C4 asm and some C emulation code (c) Copyright 2000 zsKnight and _Demo_. - * C4 C code (c) Copyright 2001 Gary Henderson (gary.henderson@ntlworld.com). - * - * DOS port code contains the works of other authors. See headers in - * individual files. - * - * Snes9x homepage: http://www.snes9x.com - * - * Permission to use, copy, modify and distribute Snes9x in both binary and - * source form, for non-commercial purposes, is hereby granted without fee, - * providing that this license information and copyright notice appear with - * all copies and any derived work. - * - * This software is provided 'as-is', without any express or implied - * warranty. In no event shall the authors be held liable for any damages - * arising from the use of this software. - * - * Snes9x is freeware for PERSONAL USE only. Commercial users should - * seek permission of the copyright holders first. Commercial use includes - * charging money for Snes9x or software derived from Snes9x. - * - * The copyright holders request that bug fixes and improvements to the code - * should be forwarded to them so everyone can benefit from the modifications - * in future versions. - * - * Super NES and Super Nintendo Entertainment System are trademarks of - * Nintendo Co., Limited and its subsidiary companies. - */ - -// ARM V5 Assembly by bitrider - -#include "snes9x.h" - -#include "memmap.h" -#include "ppu.h" -#include "display.h" -#include "gfx.h" -#include "tile16.h" - - -extern uint32 HeadMask [4]; -extern uint32 TailMask [5]; - -uint8 ConvertTile (uint8 *pCache, uint32 TileAddr) -{ - register uint8 *tp = &Memory.VRAM[TileAddr]; - uint32 *p = (uint32 *) pCache; - uint32 non_zero = 0; - uint8 line; - uint32 p1; - uint32 p2; - register uint8 pix; - - switch (BG.BitShift) - { - case 8: - for (line = 8; line != 0; line--, tp += 2) - { - p1 = p2 = 0; - if ((pix = *(tp + 0))) - { - p1 |= odd_high[0][pix >> 4]; - p2 |= odd_low[0][pix & 0xf]; - } - if ((pix = *(tp + 1))) - { - p1 |= even_high[0][pix >> 4]; - p2 |= even_low[0][pix & 0xf]; - } - if ((pix = *(tp + 16))) - { - p1 |= odd_high[1][pix >> 4]; - p2 |= odd_low[1][pix & 0xf]; - } - if ((pix = *(tp + 17))) - { - p1 |= even_high[1][pix >> 4]; - p2 |= even_low[1][pix & 0xf]; - } - if ((pix = *(tp + 32))) - { - p1 |= odd_high[2][pix >> 4]; - p2 |= odd_low[2][pix & 0xf]; - } - if ((pix = *(tp + 33))) - { - p1 |= even_high[2][pix >> 4]; - p2 |= even_low[2][pix & 0xf]; - } - if ((pix = *(tp + 48))) - { - p1 |= odd_high[3][pix >> 4]; - p2 |= odd_low[3][pix & 0xf]; - } - if ((pix = *(tp + 49))) - { - p1 |= even_high[3][pix >> 4]; - p2 |= even_low[3][pix & 0xf]; - } - *p++ = p1; - *p++ = p2; - non_zero |= p1 | p2; - } - break; - - case 4: - for (line = 8; line != 0; line--, tp += 2) - { - p1 = p2 = 0; - if ((pix = *(tp + 0))) - { - p1 |= odd_high[0][pix >> 4]; - p2 |= odd_low[0][pix & 0xf]; - } - if ((pix = *(tp + 1))) - { - p1 |= even_high[0][pix >> 4]; - p2 |= even_low[0][pix & 0xf]; - } - if ((pix = *(tp + 16))) - { - p1 |= odd_high[1][pix >> 4]; - p2 |= odd_low[1][pix & 0xf]; - } - if ((pix = *(tp + 17))) - { - p1 |= even_high[1][pix >> 4]; - p2 |= even_low[1][pix & 0xf]; - } - *p++ = p1; - *p++ = p2; - non_zero |= p1 | p2; - } - break; - - case 2: - for (line = 8; line != 0; line--, tp += 2) - { - p1 = p2 = 0; - if ((pix = *(tp + 0))) - { - p1 |= odd_high[0][pix >> 4]; - p2 |= odd_low[0][pix & 0xf]; - } - if ((pix = *(tp + 1))) - { - p1 |= even_high[0][pix >> 4]; - p2 |= even_low[0][pix & 0xf]; - } - *p++ = p1; - *p++ = p2; - non_zero |= p1 | p2; - } - break; - } - return (non_zero ? TRUE : BLANK_TILE); -} - - -inline void WRITE_4PIXELSHI16 (uint32 Offset, uint8 *Pixels) -{ - uint32 Pixel; - uint16 *Screen = (uint16 *) GFX.S + Offset; - uint8 *Depth = GFX.DB + Offset; - -#define FN(N) \ - if (GFX.Z1 > Depth [N] && (Pixel = Pixels[2*N])) \ - { \ - Screen [N] = GFX.ScreenColors [Pixel]; \ - Depth [N] = GFX.Z2; \ - } - - FN(0) - FN(1) - FN(2) - FN(3) -#undef FN -} - -inline void WRITE_4PIXELSHI16_FLIPPED (uint32 Offset, uint8 *Pixels) -{ - uint32 Pixel; - uint16 *Screen = (uint16 *) GFX.S + Offset; - uint8 *Depth = GFX.DB + Offset; - -#define FN(N) \ - if (GFX.Z1 > Depth [N] && (Pixel = Pixels[6 - 2*N])) \ - { \ - Screen [N] = GFX.ScreenColors [Pixel]; \ - Depth [N] = GFX.Z2; \ - } - - FN(0) - FN(1) - FN(2) - FN(3) -#undef FN -} - -static INLINE void WRITE_4PIXELS16x2 (uint32 Offset, uint8 *Pixels) -{ - register uint32 Pixel; - uint16 *Screen = (uint16 *) GFX.S + Offset; - uint8 *Depth = GFX.DB + Offset; - -#define FN(N) \ - if (GFX.Z1 > Depth [N * 2] && (Pixel = Pixels[N])) \ - { \ - Screen [N * 2] = Screen [N * 2 + 1] = GFX.ScreenColors [Pixel]; \ - Depth [N * 2] = Depth [N * 2 + 1] = GFX.Z2; \ - } - - FN(0) - FN(1) - FN(2) - FN(3) -#undef FN -} - -static INLINE void WRITE_4PIXELS16_FLIPPEDx2 (uint32 Offset, uint8 *Pixels) -{ - register uint32 Pixel; - uint16 *Screen = (uint16 *) GFX.S + Offset; - uint8 *Depth = GFX.DB + Offset; - -#define FN(N) \ - if (GFX.Z1 > Depth [N * 2] && (Pixel = Pixels[3 - N])) \ - { \ - Screen [N * 2] = Screen [N * 2 + 1] = GFX.ScreenColors [Pixel]; \ - Depth [N * 2] = Depth [N * 2 + 1] = GFX.Z2; \ - } - - FN(0) - FN(1) - FN(2) - FN(3) -#undef FN -} - -static INLINE void WRITE_4PIXELS16x2x2 (uint32 Offset, uint8 *Pixels) -{ - register uint32 Pixel; - uint16 *Screen = (uint16 *) GFX.S + Offset; - uint8 *Depth = GFX.DB + Offset; - -#define FN(N) \ - if (GFX.Z1 > Depth [N * 2] && (Pixel = Pixels[N])) \ - { \ - Screen [N * 2] = Screen [N * 2 + 1] = Screen [(GFX_PITCH >> 1) + N * 2] = \ - Screen [(GFX_PITCH >> 1) + N * 2 + 1] = GFX.ScreenColors [Pixel]; \ - Depth [N * 2] = Depth [N * 2 + 1] = Depth [(GFX_PITCH >> 1) + N * 2] = \ - Depth [(GFX_PITCH >> 1) + N * 2 + 1] = GFX.Z2; \ - } - - FN(0) - FN(1) - FN(2) - FN(3) -#undef FN -} - -static INLINE void WRITE_4PIXELS16_FLIPPEDx2x2 (uint32 Offset, uint8 *Pixels) -{ - register uint32 Pixel; - uint16 *Screen = (uint16 *) GFX.S + Offset; - uint8 *Depth = GFX.DB + Offset; - -#define FN(N) \ - if (GFX.Z1 > Depth [N * 2] && (Pixel = Pixels[3 - N])) \ - { \ - Screen [N * 2] = Screen [N * 2 + 1] = Screen [(GFX_PITCH >> 1) + N * 2] = \ - Screen [(GFX_PITCH >> 1) + N * 2 + 1] = GFX.ScreenColors [Pixel]; \ - Depth [N * 2] = Depth [N * 2 + 1] = Depth [(GFX_PITCH >> 1) + N * 2] = \ - Depth [(GFX_PITCH >> 1) + N * 2 + 1] = GFX.Z2; \ - } - - FN(0) - FN(1) - FN(2) - FN(3) -#undef FN -} - -// DrawTile16 ----------------------------------------- -void DrawTile16 (uint32 Tile, uint32 Offset, uint32 StartLine, uint32 LineCount) -{ - TILE_PREAMBLE - -if (Tile & V_FLIP){ - if (!(Tile & H_FLIP)){ - __asm__ volatile ( - "2: \n" -#define FN(p, p2, p3, p4) \ - " ldrb r9, [%[depth], #" p "] \n"\ - " ldrb r8, [%[depth], #" p3 "] \n"\ - " cmp %[gfx_z1], r9 \n"\ - " ldrhib r9, [%[bp], #" p "] \n"\ - " bls 3f \n"\ - " movs r9, r9, lsl #2 \n"\ - " ldrne r9, [%[colors], r9] \n"\ - " strneb %[gfx_z2], [%[depth], #" p "] \n"\ - " strneh r9, [%[screen], #" p2 "] \n"\ - "3: \n"\ - " cmp %[gfx_z1], r8 \n"\ - " ldrhib r9, [%[bp], #" p3 "] \n"\ - " bls 3f \n"\ - " movs r9, r9, lsl #2 \n"\ - " ldrne r9, [%[colors], r9] \n"\ - " strneb %[gfx_z2], [%[depth], #" p3 "] \n"\ - " strneh r9, [%[screen], #" p4 "] \n"\ - "3: \n" - - FN("0", "0", "1", "2") - FN("2", "4", "3", "6") - FN("4", "8", "5", "10") - FN("6", "12", "7", "14") - // Loop - " sub %[bp], %[bp], #8 \n" - " add %[screen], %[screen], #640 \n" - " add %[depth], %[depth], #320 \n" - " subs %[lcount], %[lcount], #1 \n" - " bne 2b" - // output - : // none - // input - : [lcount] "r" (LineCount), - [gfx_z1] "r" (GFX.Z1), - [gfx_z2] "r" (GFX.Z2), - [screen] "r" ((uint16 *) GFX.S + Offset), - [colors] "r" (GFX.ScreenColors), - [depth] "r" (GFX.DB + Offset), - [bp] "r" (pCache + 56 - StartLine) - // clobbered - : "r9", "r8", "cc" // r8 & flags - ); - } else { - __asm__ volatile ( - "2: \n" -#define FN1(p, p2, p3, p4, p5, p6) \ - " ldrb r9, [%[depth], #" p "] \n"\ - " ldrb r8, [%[depth], #" p4 "] \n"\ - " cmp %[gfx_z1], r9 \n"\ - " ldrhib r9, [%[bp], #" p3 "] \n"\ - " bls 3f \n"\ - " movs r9, r9, lsl #2 \n"\ - " ldrne r9, [%[colors], r9] \n"\ - " strneb %[gfx_z2], [%[depth], #" p "] \n"\ - " strneh r9, [%[screen], #" p2 "] \n"\ - "3: \n"\ - " cmp %[gfx_z1], r8 \n"\ - " ldrhib r9, [%[bp], #" p6 "] \n"\ - " bls 3f \n"\ - " movs r9, r9, lsl #2 \n"\ - " ldrne r9, [%[colors], r9] \n"\ - " strneb %[gfx_z2], [%[depth], #" p4 "] \n"\ - " strneh r9, [%[screen], #" p5 "] \n"\ - "3: \n" - - FN1("0", "0", "7", "1", "2", "6") - FN1("2", "4", "5", "3", "6", "4") - FN1("4", "8", "3", "5", "10", "2") - FN1("6", "12", "1", "7", "14", "0") - // Loop - " sub %[bp], %[bp], #8 \n" - " add %[screen], %[screen], #640 \n" - " add %[depth], %[depth], #320 \n" - " subs %[lcount], %[lcount], #1 \n" - " bne 2b" - // output - : // none - // input - : [lcount] "r" (LineCount), - [gfx_z1] "r" (GFX.Z1), - [gfx_z2] "r" (GFX.Z2), - [screen] "r" ((uint16 *) GFX.S + Offset), - [colors] "r" (GFX.ScreenColors), - [depth] "r" (GFX.DB + Offset), - [bp] "r" (pCache + 56 - StartLine) - // clobbered - : "r9", "r8", "cc" // r8 & flags - ); - } -} else { - if (!(Tile & H_FLIP)){ - __asm__ volatile ( - "2: \n" - FN("0", "0", "1", "2") - FN("2", "4", "3", "6") - FN("4", "8", "5", "10") - FN("6", "12", "7", "14") - // Loop - " add %[bp], %[bp], #8 \n" - " add %[screen], %[screen], #640 \n" - " add %[depth], %[depth], #320 \n" - " subs %[lcount], %[lcount], #1 \n" - " bne 2b" - // output - : // none - // input - : [lcount] "r" (LineCount), - [gfx_z1] "r" (GFX.Z1), - [gfx_z2] "r" (GFX.Z2), - [screen] "r" ((uint16 *) GFX.S + Offset), - [colors] "r" (GFX.ScreenColors), - [depth] "r" (GFX.DB + Offset), - [bp] "r" (pCache + StartLine) - // clobbered - : "r9", "r8", "cc" // r8 & flags - ); - } else { - __asm__ volatile ( - "2: \n" - FN1("0", "0", "7", "1", "2", "6") - FN1("2", "4", "5", "3", "6", "4") - FN1("4", "8", "3", "5", "10", "2") - FN1("6", "12", "1", "7", "14", "0") - // Loop - " add %[bp], %[bp], #8 \n" - " add %[screen], %[screen], #640 \n" - " add %[depth], %[depth], #320 \n" - " subs %[lcount], %[lcount], #1 \n" - " bne 2b" - // output - : // none - // input - : [lcount] "r" (LineCount), - [gfx_z1] "r" (GFX.Z1), - [gfx_z2] "r" (GFX.Z2), - [screen] "r" ((uint16 *) GFX.S + Offset), - [colors] "r" (GFX.ScreenColors), - [depth] "r" (GFX.DB + Offset), - [bp] "r" (pCache + StartLine) - // clobbered - : "r9", "r8", "cc" // r8 & flags - ); - - } - } -#undef FN -#undef FN1 - -} - -// DrawClippedTile16 ----------------------------------------- -void DrawClippedTile16 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount) -{ -if (Width == 0) return; - - TILE_PREAMBLE - -Offset = Offset + StartPixel; - -if (Tile & V_FLIP){ - if (!(Tile & H_FLIP)){ - __asm__ volatile ( - "2: \n" -#define FN(p) \ - " ldrb r9, [%[depth], #" p "] \n"\ - " cmp %[gfx_z1], r9 \n"\ - " bls 3f \n"\ - " ldrb r9, [%[bp], #" p "] \n"\ - " movs r9, r9, lsl #2 \n"\ - " ldrne r9, [%[colors], r9] \n"\ - " strneb %[gfx_z2], [%[depth], #" p "] \n"\ - " strneh r9, [%[screen], #(" p " * 2)] \n"\ - "3: \n" - -#define C(p) " cmp %[width], #(" p " + 1) \n"\ - " beq 1f \n" - - FN("0") - C("0") - FN("1") - C("1") - FN("2") - C("2") - FN("3") - C("3") - FN("4") - C("4") - FN("5") - C("5") - FN("6") - C("6") - FN("7") - // Loop - "1: \n" - " sub %[bp], %[bp], #8 \n" - " add %[screen], %[screen], #640 \n" - " add %[depth], %[depth], #320 \n" - " subs %[lcount], %[lcount], #1 \n" - " bne 2b" - // output - : // none - // input - : [lcount] "r" (LineCount), - [gfx_z1] "r" (GFX.Z1), - [gfx_z2] "r" (GFX.Z2), - [screen] "r" ((uint16 *) GFX.S + Offset), - [colors] "r" (GFX.ScreenColors), - [depth] "r" (GFX.DB + Offset), - [width] "r" (Width), - [bp] "r" (pCache + 56 - StartLine + StartPixel) - // clobbered - : "r9", "cc" // r8 & flags - ); - } else { - __asm__ volatile ( - "2: \n" -#define FN1(p) \ - " ldrb r9, [%[depth], #" p "] \n"\ - " cmp %[gfx_z1], r9 \n"\ - " bls 3f \n"\ - " ldrb r9, [%[bp], #(7 - " p ")] \n"\ - " movs r9, r9, lsl #2 \n"\ - " ldrne r9, [%[colors], r9] \n"\ - " strneb %[gfx_z2], [%[depth], #" p "] \n"\ - " strneh r9, [%[screen], #(" p " * 2)] \n"\ - "3: \n"\ - - FN1("0") - C("0") - FN1("1") - C("1") - FN1("2") - C("2") - FN1("3") - C("3") - FN1("4") - C("4") - FN1("5") - C("5") - FN1("6") - C("6") - FN1("7") - // Loop - "1: \n" - " sub %[bp], %[bp], #8 \n" - " add %[screen], %[screen], #640 \n" - " add %[depth], %[depth], #320 \n" - " subs %[lcount], %[lcount], #1 \n" - " bne 2b" - // output - : // none - // input - : [lcount] "r" (LineCount), - [gfx_z1] "r" (GFX.Z1), - [gfx_z2] "r" (GFX.Z2), - [screen] "r" ((uint16 *) GFX.S + Offset), - [colors] "r" (GFX.ScreenColors), - [depth] "r" (GFX.DB + Offset), - [width] "r" (Width), - [bp] "r" (pCache + 56 - StartLine - StartPixel) - // clobbered - : "r9", "cc" // r8 & flags - ); - } -} else { - if (!(Tile & H_FLIP)){ - __asm__ volatile ( - "2: \n" - FN("0") - C("0") - FN("1") - C("1") - FN("2") - C("2") - FN("3") - C("3") - FN("4") - C("4") - FN("5") - C("5") - FN("6") - C("6") - FN("7") - // Loop - "1: \n" - " add %[bp], %[bp], #8 \n" - " add %[screen], %[screen], #640 \n" - " add %[depth], %[depth], #320 \n" - " subs %[lcount], %[lcount], #1 \n" - " bne 2b" - // output - : // none - // input - : [lcount] "r" (LineCount), - [gfx_z1] "r" (GFX.Z1), - [gfx_z2] "r" (GFX.Z2), - [screen] "r" ((uint16 *) GFX.S + Offset), - [colors] "r" (GFX.ScreenColors), - [depth] "r" (GFX.DB + Offset), - [width] "r" (Width), - [bp] "r" (pCache + StartLine + StartPixel) - // clobbered - : "r9", "cc" // r8 & flags - ); - } else { - __asm__ volatile ( - "2: \n" - FN1("0") - C("0") - FN1("1") - C("1") - FN1("2") - C("2") - FN1("3") - C("3") - FN1("4") - C("4") - FN1("5") - C("5") - FN1("6") - C("6") - FN1("7") - // Loop - "1: \n" - " add %[bp], %[bp], #8 \n" - " add %[screen], %[screen], #640 \n" - " add %[depth], %[depth], #320 \n" - " subs %[lcount], %[lcount], #1 \n" - " bne 2b" - // output - : // none - // input - : [lcount] "r" (LineCount), - [gfx_z1] "r" (GFX.Z1), - [gfx_z2] "r" (GFX.Z2), - [screen] "r" ((uint16 *) GFX.S + Offset), - [colors] "r" (GFX.ScreenColors), - [depth] "r" (GFX.DB + Offset), - [width] "r" (Width), - [bp] "r" (pCache + StartLine - StartPixel) - // clobbered - : "r9", "cc" // r8 & flags - ); - - } - } -#undef FN -#undef FN1 -#undef C - -} - - -void DrawTile16x2 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount) -{ - TILE_PREAMBLE - register uint8 *bp; - - RENDER_TILE(WRITE_4PIXELS16x2, WRITE_4PIXELS16_FLIPPEDx2, 8) -} - -void DrawClippedTile16x2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount) -{ - TILE_PREAMBLE - register uint8 *bp; - - TILE_CLIP_PREAMBLE - RENDER_CLIPPED_TILE(WRITE_4PIXELS16x2, WRITE_4PIXELS16_FLIPPEDx2, 8) -} - -void DrawTile16x2x2 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount) -{ - TILE_PREAMBLE - register uint8 *bp; - - RENDER_TILE(WRITE_4PIXELS16x2x2, WRITE_4PIXELS16_FLIPPEDx2x2, 8) -} - -void DrawClippedTile16x2x2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount) -{ - TILE_PREAMBLE - register uint8 *bp; - - TILE_CLIP_PREAMBLE - RENDER_CLIPPED_TILE(WRITE_4PIXELS16x2x2, WRITE_4PIXELS16_FLIPPEDx2x2, 8) -} - -void DrawLargePixel16 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Pixels, - uint32 StartLine, uint32 LineCount) -{ - TILE_PREAMBLE - - register uint16 *sp = (uint16 *) GFX.S + Offset; - uint8 *Depth = GFX.DB + Offset; - uint16 pixel; - -#define PLOT_PIXEL(screen, pixel) (pixel) - - RENDER_TILE_LARGE (GFX.ScreenColors [pixel], PLOT_PIXEL) -} - - -void DrawLargePixel16Add (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Pixels, - uint32 StartLine, uint32 LineCount) -{ - TILE_PREAMBLE - - register uint16 *sp = (uint16 *) GFX.S + Offset; - uint8 *Depth = GFX.ZBuffer + Offset; - register uint16 pixel; - -#define LARGE_ADD_PIXEL(s, p) \ -(Depth [z + GFX.DepthDelta] ? (Depth [z + GFX.DepthDelta] != 1 ? \ - COLOR_ADD (p, *(s + GFX.Delta)) : \ - COLOR_ADD (p, GFX.FixedColour)) \ - : p) - - RENDER_TILE_LARGE (GFX.ScreenColors [pixel], LARGE_ADD_PIXEL) -} - -void DrawLargePixel16Add1_2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Pixels, - uint32 StartLine, uint32 LineCount) -{ - TILE_PREAMBLE - - register uint16 *sp = (uint16 *) GFX.S + Offset; - uint8 *Depth = GFX.ZBuffer + Offset; - register uint16 pixel; - -#define LARGE_ADD_PIXEL1_2(s, p) \ -((uint16) (Depth [z + GFX.DepthDelta] ? (Depth [z + GFX.DepthDelta] != 1 ? \ - COLOR_ADD1_2 (p, *(s + GFX.Delta)) : \ - COLOR_ADD (p, GFX.FixedColour)) \ - : p)) - - RENDER_TILE_LARGE (GFX.ScreenColors [pixel], LARGE_ADD_PIXEL1_2) -} - -void DrawLargePixel16Sub (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Pixels, - uint32 StartLine, uint32 LineCount) -{ - TILE_PREAMBLE - - register uint16 *sp = (uint16 *) GFX.S + Offset; - uint8 *Depth = GFX.ZBuffer + Offset; - register uint16 pixel; - -#define LARGE_SUB_PIXEL(s, p) \ -(Depth [z + GFX.DepthDelta] ? (Depth [z + GFX.DepthDelta] != 1 ? \ - COLOR_SUB (p, *(s + GFX.Delta)) : \ - COLOR_SUB (p, GFX.FixedColour)) \ - : p) - - RENDER_TILE_LARGE (GFX.ScreenColors [pixel], LARGE_SUB_PIXEL) -} - -void DrawLargePixel16Sub1_2 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Pixels, - uint32 StartLine, uint32 LineCount) -{ - TILE_PREAMBLE - - register uint16 *sp = (uint16 *) GFX.S + Offset; - uint8 *Depth = GFX.ZBuffer + Offset; - uint16 pixel; - -#define LARGE_SUB_PIXEL1_2(s, p) \ -(Depth [z + GFX.DepthDelta] ? (Depth [z + GFX.DepthDelta] != 1 ? \ - COLOR_SUB1_2 (p, *(s + GFX.Delta)) : \ - COLOR_SUB (p, GFX.FixedColour)) \ - : p) - - RENDER_TILE_LARGE (GFX.ScreenColors [pixel], LARGE_SUB_PIXEL1_2) -} - -void DrawHiResTile16 (uint32 Tile, uint32 Offset, uint32 StartLine, - uint32 LineCount) -{ - TILE_PREAMBLE - register uint8 *bp; - - RENDER_TILEHI(WRITE_4PIXELSHI16, WRITE_4PIXELSHI16_FLIPPED, 4) -} - -void DrawHiResClippedTile16 (uint32 Tile, uint32 Offset, - uint32 StartPixel, uint32 Width, - uint32 StartLine, uint32 LineCount) -{ - TILE_PREAMBLE - register uint8 *bp; - - TILE_CLIP_PREAMBLE - RENDER_CLIPPED_TILEHI(WRITE_4PIXELSHI16, WRITE_4PIXELSHI16_FLIPPED, 4) -} |