moved some of the GBA core files to the new agb directory and setup the paths, fixed some includes i didn't setup properly for GB.
This commit is contained in:
parent
df3ae15cac
commit
7aef2948b1
6
Makefile
6
Makefile
|
@ -75,9 +75,9 @@ CALTERNOBJ=${HQCDIR}/hq_implementation${OE}
|
||||||
|
|
||||||
MAINOBJ=${MAINDIR}/2xSaI${OE} ${MAINDIR}/admame${OE} ${MAINDIR}/agbprint${OE} ${MAINDIR}/armdis${OE} \
|
MAINOBJ=${MAINDIR}/2xSaI${OE} ${MAINDIR}/admame${OE} ${MAINDIR}/agbprint${OE} ${MAINDIR}/armdis${OE} \
|
||||||
${MAINDIR}/bilinear${OE} ${MAINDIR}/bios${OE} ${MAINDIR}/Cheats${OE} ${MAINDIR}/CheatSearch${OE} \
|
${MAINDIR}/bilinear${OE} ${MAINDIR}/bios${OE} ${MAINDIR}/Cheats${OE} ${MAINDIR}/CheatSearch${OE} \
|
||||||
${MAINDIR}/EEprom${OE} ${MAINDIR}/elf${OE} ${MAINDIR}/Flash${OE} ${MAINDIR}/GBA${OE} \
|
${MAINDIR}/EEprom${OE} ${MAINDIR}/elf${OE} ${MAINDIR}/Flash${OE} ${MAINDIR}/agb/GBA${OE} \
|
||||||
${MAINDIR}/gbafilter${OE} ${MAINDIR}/Gfx${OE} ${MAINDIR}/Globals${OE} ${MAINDIR}/interframe${OE} \
|
${MAINDIR}/agb/gbafilter${OE} ${MAINDIR}/agb/GBAGFX${OE} ${MAINDIR}/Globals${OE} ${MAINDIR}/interframe${OE} \
|
||||||
${MAINDIR}/hq2x${OE} ${MAINDIR}/GBA-thumb${OE} ${MAINDIR}/GBA-arm${OE} ${MAINDIR}/Mode0${OE} \
|
${MAINDIR}/hq2x${OE} ${MAINDIR}/agb/gba-thumb${OE} ${MAINDIR}/agb/gba-arm${OE} ${MAINDIR}/Mode0${OE} \
|
||||||
${MAINDIR}/Mode1${OE} ${MAINDIR}/Mode2${OE} ${MAINDIR}/Mode3${OE} ${MAINDIR}/Mode4${OE} \
|
${MAINDIR}/Mode1${OE} ${MAINDIR}/Mode2${OE} ${MAINDIR}/Mode3${OE} ${MAINDIR}/Mode4${OE} \
|
||||||
${MAINDIR}/Mode5${OE} ${MAINDIR}/pixel${OE} \
|
${MAINDIR}/Mode5${OE} ${MAINDIR}/pixel${OE} \
|
||||||
${MAINDIR}/remote${OE} ${MAINDIR}/RTC${OE} ${MAINDIR}/scanline${OE} \
|
${MAINDIR}/remote${OE} ${MAINDIR}/RTC${OE} ${MAINDIR}/scanline${OE} \
|
||||||
|
|
26
VBA.vcproj
26
VBA.vcproj
|
@ -602,7 +602,7 @@
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\gbafilter.cpp"
|
RelativePath=".\src\agb\gbafilter.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
|
@ -638,7 +638,7 @@
|
||||||
Name="GBA"
|
Name="GBA"
|
||||||
>
|
>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\agbprint.cpp"
|
RelativePath=".\src\agb\agbprint.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
|
@ -662,19 +662,19 @@
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\GBA-arm.cpp"
|
RelativePath=".\src\agb\gba-arm.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\GBA-thumb.cpp"
|
RelativePath=".\src\agb\gba-thumb.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\GBA.cpp"
|
RelativePath=".\src\agb\gba.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\Gfx.cpp"
|
RelativePath=".\src\agb\gbagfx.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
|
@ -1130,11 +1130,11 @@
|
||||||
Name="Linking"
|
Name="Linking"
|
||||||
>
|
>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\Link.cpp"
|
RelativePath=".\src\agb\gbalink.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\Link.h"
|
RelativePath=".\src\agb\gbalink.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
|
@ -1240,7 +1240,7 @@
|
||||||
Name="GBA"
|
Name="GBA"
|
||||||
>
|
>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\agbprint.h"
|
RelativePath=".\src\agb\agbprint.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
|
@ -1260,19 +1260,19 @@
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\GBA.h"
|
RelativePath=".\src\agb\gba.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\GBAcpu.h"
|
RelativePath=".\src\agb\gbacpu.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\GBAinline.h"
|
RelativePath=".\src\agb\gbainline.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\Gfx.h"
|
RelativePath=".\src\agb\gbagfx.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
|
|
|
@ -806,7 +806,7 @@
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\gbafilter.cpp"
|
RelativePath=".\src\agb\gbafilter.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
|
@ -910,19 +910,19 @@
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\GBA-arm.cpp"
|
RelativePath=".\src\agb\gba-arm.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\GBA-thumb.cpp"
|
RelativePath=".\src\agb\gba-thumb.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\GBA.cpp"
|
RelativePath=".\src\agb\gba.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\Gfx.cpp"
|
RelativePath=".\src\agb\gbagfx.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
|
@ -1346,11 +1346,11 @@
|
||||||
Name="Linking"
|
Name="Linking"
|
||||||
>
|
>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\Link.cpp"
|
RelativePath=".\src\agb\gbalink.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\Link.h"
|
RelativePath=".\src\agb\gbalink.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
|
@ -1464,15 +1464,15 @@
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\GBA.h"
|
RelativePath=".\src\agb\gba.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\GBAinline.h"
|
RelativePath=".\src\agb\gbainline.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath=".\src\Gfx.h"
|
RelativePath=".\src\agb\gbagfx.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
|
|
|
@ -21,8 +21,8 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
|
|
||||||
#include "GBA.h"
|
#include "agb/GBA.h"
|
||||||
#include "GBAinline.h"
|
#include "agb/GBAinline.h"
|
||||||
#include "Cheats.h"
|
#include "Cheats.h"
|
||||||
#include "Globals.h"
|
#include "Globals.h"
|
||||||
#include "NLS.h"
|
#include "NLS.h"
|
||||||
|
|
|
@ -17,7 +17,7 @@
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
#include <memory.h>
|
#include <memory.h>
|
||||||
#include "GBA.h"
|
#include "agb/GBA.h"
|
||||||
#include "EEprom.h"
|
#include "EEprom.h"
|
||||||
#include "Util.h"
|
#include "Util.h"
|
||||||
|
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <memory.h>
|
#include <memory.h>
|
||||||
#include "GBA.h"
|
#include "agb/GBA.h"
|
||||||
#include "Globals.h"
|
#include "Globals.h"
|
||||||
#include "Flash.h"
|
#include "Flash.h"
|
||||||
#include "Sram.h"
|
#include "Sram.h"
|
||||||
|
|
2966
src/GBA-arm.cpp
2966
src/GBA-arm.cpp
File diff suppressed because it is too large
Load Diff
2331
src/GBA-thumb.cpp
2331
src/GBA-thumb.cpp
File diff suppressed because it is too large
Load Diff
3983
src/GBA.cpp
3983
src/GBA.cpp
File diff suppressed because it is too large
Load Diff
160
src/GBA.h
160
src/GBA.h
|
@ -1,160 +0,0 @@
|
||||||
// -*- C++ -*-
|
|
||||||
// VisualBoyAdvance - Nintendo Gameboy/GameboyAdvance (TM) emulator.
|
|
||||||
// Copyright (C) 1999-2003 Forgotten
|
|
||||||
// Copyright (C) 2005 Forgotten and the VBA development team
|
|
||||||
|
|
||||||
// This program is free software; you can redistribute it and/or modify
|
|
||||||
// it under the terms of the GNU General Public License as published by
|
|
||||||
// the Free Software Foundation; either version 2, or(at your option)
|
|
||||||
// any later version.
|
|
||||||
//
|
|
||||||
// This program is distributed in the hope that it will be useful,
|
|
||||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
// GNU General Public License for more details.
|
|
||||||
//
|
|
||||||
// You should have received a copy of the GNU General Public License
|
|
||||||
// along with this program; if not, write to the Free Software Foundation,
|
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
||||||
|
|
||||||
#ifndef VBA_GBA_H
|
|
||||||
#define VBA_GBA_H
|
|
||||||
|
|
||||||
#include "System.h"
|
|
||||||
|
|
||||||
#define SAVE_GAME_VERSION_1 1
|
|
||||||
#define SAVE_GAME_VERSION_2 2
|
|
||||||
#define SAVE_GAME_VERSION_3 3
|
|
||||||
#define SAVE_GAME_VERSION_4 4
|
|
||||||
#define SAVE_GAME_VERSION_5 5
|
|
||||||
#define SAVE_GAME_VERSION_6 6
|
|
||||||
#define SAVE_GAME_VERSION_7 7
|
|
||||||
#define SAVE_GAME_VERSION_8 8
|
|
||||||
#define SAVE_GAME_VERSION_9 9
|
|
||||||
#define SAVE_GAME_VERSION_10 10
|
|
||||||
#define SAVE_GAME_VERSION SAVE_GAME_VERSION_10
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
u8 *address;
|
|
||||||
u32 mask;
|
|
||||||
} memoryMap;
|
|
||||||
|
|
||||||
typedef union {
|
|
||||||
struct {
|
|
||||||
#ifdef WORDS_BIGENDIAN
|
|
||||||
u8 B3;
|
|
||||||
u8 B2;
|
|
||||||
u8 B1;
|
|
||||||
u8 B0;
|
|
||||||
#else
|
|
||||||
u8 B0;
|
|
||||||
u8 B1;
|
|
||||||
u8 B2;
|
|
||||||
u8 B3;
|
|
||||||
#endif
|
|
||||||
} B;
|
|
||||||
struct {
|
|
||||||
#ifdef WORDS_BIGENDIAN
|
|
||||||
u16 W1;
|
|
||||||
u16 W0;
|
|
||||||
#else
|
|
||||||
u16 W0;
|
|
||||||
u16 W1;
|
|
||||||
#endif
|
|
||||||
} W;
|
|
||||||
#ifdef WORDS_BIGENDIAN
|
|
||||||
volatile u32 I;
|
|
||||||
#else
|
|
||||||
u32 I;
|
|
||||||
#endif
|
|
||||||
} reg_pair;
|
|
||||||
|
|
||||||
#ifndef NO_GBA_MAP
|
|
||||||
extern memoryMap map[256];
|
|
||||||
#endif
|
|
||||||
|
|
||||||
extern reg_pair reg[45];
|
|
||||||
extern u8 biosProtected[4];
|
|
||||||
|
|
||||||
extern bool N_FLAG;
|
|
||||||
extern bool Z_FLAG;
|
|
||||||
extern bool C_FLAG;
|
|
||||||
extern bool V_FLAG;
|
|
||||||
extern bool armIrqEnable;
|
|
||||||
extern bool armState;
|
|
||||||
extern int armMode;
|
|
||||||
extern void (*cpuSaveGameFunc)(u32,u8);
|
|
||||||
|
|
||||||
#ifdef BKPT_SUPPORT
|
|
||||||
extern u8 freezeWorkRAM[0x40000];
|
|
||||||
extern u8 freezeInternalRAM[0x8000];
|
|
||||||
extern u8 freezeVRAM[0x18000];
|
|
||||||
extern u8 freezeOAM[0x400];
|
|
||||||
extern u8 freezePRAM[0x400];
|
|
||||||
extern bool debugger_last;
|
|
||||||
extern int oldreg[17];
|
|
||||||
extern char oldbuffer[10];
|
|
||||||
#endif
|
|
||||||
|
|
||||||
extern bool CPUReadGSASnapshot(const char *);
|
|
||||||
extern bool CPUWriteGSASnapshot(const char *, const char *, const char *, const char *);
|
|
||||||
extern bool CPUWriteBatteryFile(const char *);
|
|
||||||
extern bool CPUReadBatteryFile(const char *);
|
|
||||||
extern bool CPUExportEepromFile(const char *);
|
|
||||||
extern bool CPUImportEepromFile(const char *);
|
|
||||||
extern bool CPUWritePNGFile(const char *);
|
|
||||||
extern bool CPUWriteBMPFile(const char *);
|
|
||||||
extern void CPUCleanUp();
|
|
||||||
extern void CPUUpdateRender();
|
|
||||||
extern void CPUUpdateRenderBuffers(bool);
|
|
||||||
extern bool CPUReadMemState(char *, int);
|
|
||||||
extern bool CPUReadState(const char *);
|
|
||||||
extern bool CPUWriteMemState(char *, int);
|
|
||||||
extern bool CPUWriteState(const char *);
|
|
||||||
extern int CPULoadRom(const char *);
|
|
||||||
extern void doMirroring(bool);
|
|
||||||
extern void CPUUpdateRegister(u32, u16);
|
|
||||||
extern void applyTimer ();
|
|
||||||
extern void CPUInit(const char *,bool);
|
|
||||||
extern void CPUReset();
|
|
||||||
extern void CPULoop(int);
|
|
||||||
extern void CPUCheckDMA(int,int);
|
|
||||||
extern bool CPUIsGBAImage(const char *);
|
|
||||||
extern bool CPUIsZipFile(const char *);
|
|
||||||
#ifdef PROFILING
|
|
||||||
#include "prof/prof.h"
|
|
||||||
extern void cpuProfil(profile_segment *seg);
|
|
||||||
extern void cpuEnableProfiling(int hz);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
extern struct EmulatedSystem GBASystem;
|
|
||||||
|
|
||||||
#define R13_IRQ 18
|
|
||||||
#define R14_IRQ 19
|
|
||||||
#define SPSR_IRQ 20
|
|
||||||
#define R13_USR 26
|
|
||||||
#define R14_USR 27
|
|
||||||
#define R13_SVC 28
|
|
||||||
#define R14_SVC 29
|
|
||||||
#define SPSR_SVC 30
|
|
||||||
#define R13_ABT 31
|
|
||||||
#define R14_ABT 32
|
|
||||||
#define SPSR_ABT 33
|
|
||||||
#define R13_UND 34
|
|
||||||
#define R14_UND 35
|
|
||||||
#define SPSR_UND 36
|
|
||||||
#define R8_FIQ 37
|
|
||||||
#define R9_FIQ 38
|
|
||||||
#define R10_FIQ 39
|
|
||||||
#define R11_FIQ 40
|
|
||||||
#define R12_FIQ 41
|
|
||||||
#define R13_FIQ 42
|
|
||||||
#define R14_FIQ 43
|
|
||||||
#define SPSR_FIQ 44
|
|
||||||
|
|
||||||
#include "Cheats.h"
|
|
||||||
#include "Globals.h"
|
|
||||||
#include "EEprom.h"
|
|
||||||
#include "Flash.h"
|
|
||||||
|
|
||||||
#endif //VBA_GBA_H
|
|
302
src/GBAcpu.h
302
src/GBAcpu.h
|
@ -1,302 +0,0 @@
|
||||||
// -*- C++ -*-
|
|
||||||
// VisualBoyAdvance - Nintendo Gameboy/GameboyAdvance (TM) emulator.
|
|
||||||
// Copyright (C) 1999-2003 Forgotten
|
|
||||||
// Copyright (C) 2005 Forgotten and the VBA development team
|
|
||||||
|
|
||||||
// This program is free software; you can redistribute it and/or modify
|
|
||||||
// it under the terms of the GNU General Public License as published by
|
|
||||||
// the Free Software Foundation; either version 2, or(at your option)
|
|
||||||
// any later version.
|
|
||||||
//
|
|
||||||
// This program is distributed in the hope that it will be useful,
|
|
||||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
// GNU General Public License for more details.
|
|
||||||
//
|
|
||||||
// You should have received a copy of the GNU General Public License
|
|
||||||
// along with this program; if not, write to the Free Software Foundation,
|
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
||||||
|
|
||||||
#ifndef VBA_GBAcpu_H
|
|
||||||
#define VBA_GBAcpu_H
|
|
||||||
|
|
||||||
extern int armExecute();
|
|
||||||
extern int thumbExecute();
|
|
||||||
|
|
||||||
#ifdef __GNUC__
|
|
||||||
# define INSN_REGPARM __attribute__((regparm(1)))
|
|
||||||
# define LIKELY(x) __builtin_expect(!!(x),1)
|
|
||||||
# define UNLIKELY(x) __builtin_expect(!!(x),0)
|
|
||||||
#else
|
|
||||||
# define INSN_REGPARM /*nothing*/
|
|
||||||
# define LIKELY(x) (x)
|
|
||||||
# define UNLIKELY(x) (x)
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define UPDATE_REG(address, value)\
|
|
||||||
{\
|
|
||||||
WRITE16LE(((u16 *)&ioMem[address]),value);\
|
|
||||||
}\
|
|
||||||
|
|
||||||
#define ARM_PREFETCH \
|
|
||||||
{\
|
|
||||||
cpuPrefetch[0] = CPUReadMemoryQuick(armNextPC);\
|
|
||||||
cpuPrefetch[1] = CPUReadMemoryQuick(armNextPC+4);\
|
|
||||||
}
|
|
||||||
|
|
||||||
#define THUMB_PREFETCH \
|
|
||||||
{\
|
|
||||||
cpuPrefetch[0] = CPUReadHalfWordQuick(armNextPC);\
|
|
||||||
cpuPrefetch[1] = CPUReadHalfWordQuick(armNextPC+2);\
|
|
||||||
}
|
|
||||||
|
|
||||||
#define ARM_PREFETCH_NEXT \
|
|
||||||
cpuPrefetch[1] = CPUReadMemoryQuick(armNextPC+4);
|
|
||||||
|
|
||||||
#define THUMB_PREFETCH_NEXT\
|
|
||||||
cpuPrefetch[1] = CPUReadHalfWordQuick(armNextPC+2);
|
|
||||||
|
|
||||||
|
|
||||||
extern int SWITicks;
|
|
||||||
extern u32 mastercode;
|
|
||||||
extern bool busPrefetch;
|
|
||||||
extern bool busPrefetchEnable;
|
|
||||||
extern u32 busPrefetchCount;
|
|
||||||
extern int cpuNextEvent;
|
|
||||||
extern bool holdState;
|
|
||||||
extern u32 cpuPrefetch[2];
|
|
||||||
extern int cpuTotalTicks;
|
|
||||||
extern u8 memoryWait[16];
|
|
||||||
extern u8 memoryWait32[16];
|
|
||||||
extern u8 memoryWaitSeq[16];
|
|
||||||
extern u8 memoryWaitSeq32[16];
|
|
||||||
extern u8 cpuBitsSet[256];
|
|
||||||
extern u8 cpuLowestBitSet[256];
|
|
||||||
extern void CPUSwitchMode(int mode, bool saveState, bool breakLoop);
|
|
||||||
extern void CPUSwitchMode(int mode, bool saveState);
|
|
||||||
extern void CPUUpdateCPSR();
|
|
||||||
extern void CPUUpdateFlags(bool breakLoop);
|
|
||||||
extern void CPUUpdateFlags();
|
|
||||||
extern void CPUUndefinedException();
|
|
||||||
extern void CPUSoftwareInterrupt();
|
|
||||||
extern void CPUSoftwareInterrupt(int comment);
|
|
||||||
|
|
||||||
|
|
||||||
// Waitstates when accessing data
|
|
||||||
inline int dataTicksAccess16(u32 address) // DATA 8/16bits NON SEQ
|
|
||||||
{
|
|
||||||
int addr = (address>>24)&15;
|
|
||||||
int value = memoryWait[addr];
|
|
||||||
|
|
||||||
if ((addr>=0x08) || (addr < 0x02))
|
|
||||||
{
|
|
||||||
busPrefetchCount=0;
|
|
||||||
busPrefetch=false;
|
|
||||||
}
|
|
||||||
else if (busPrefetch)
|
|
||||||
{
|
|
||||||
int waitState = value;
|
|
||||||
if (!waitState)
|
|
||||||
waitState = 1;
|
|
||||||
busPrefetchCount = ((busPrefetchCount+1)<<waitState) - 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline int dataTicksAccess32(u32 address) // DATA 32bits NON SEQ
|
|
||||||
{
|
|
||||||
int addr = (address>>24)&15;
|
|
||||||
int value = memoryWait32[addr];
|
|
||||||
|
|
||||||
if ((addr>=0x08) || (addr < 0x02))
|
|
||||||
{
|
|
||||||
busPrefetchCount=0;
|
|
||||||
busPrefetch=false;
|
|
||||||
}
|
|
||||||
else if (busPrefetch)
|
|
||||||
{
|
|
||||||
int waitState = value;
|
|
||||||
if (!waitState)
|
|
||||||
waitState = 1;
|
|
||||||
busPrefetchCount = ((busPrefetchCount+1)<<waitState) - 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline int dataTicksAccessSeq16(u32 address)// DATA 8/16bits SEQ
|
|
||||||
{
|
|
||||||
int addr = (address>>24)&15;
|
|
||||||
int value = memoryWaitSeq[addr];
|
|
||||||
|
|
||||||
if ((addr>=0x08) || (addr < 0x02))
|
|
||||||
{
|
|
||||||
busPrefetchCount=0;
|
|
||||||
busPrefetch=false;
|
|
||||||
}
|
|
||||||
else if (busPrefetch)
|
|
||||||
{
|
|
||||||
int waitState = value;
|
|
||||||
if (!waitState)
|
|
||||||
waitState = 1;
|
|
||||||
busPrefetchCount = ((busPrefetchCount+1)<<waitState) - 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
inline int dataTicksAccessSeq32(u32 address)// DATA 32bits SEQ
|
|
||||||
{
|
|
||||||
int addr = (address>>24)&15;
|
|
||||||
int value = memoryWaitSeq32[addr];
|
|
||||||
|
|
||||||
if ((addr>=0x08) || (addr < 0x02))
|
|
||||||
{
|
|
||||||
busPrefetchCount=0;
|
|
||||||
busPrefetch=false;
|
|
||||||
}
|
|
||||||
else if (busPrefetch)
|
|
||||||
{
|
|
||||||
int waitState = value;
|
|
||||||
if (!waitState)
|
|
||||||
waitState = 1;
|
|
||||||
busPrefetchCount = ((busPrefetchCount+1)<<waitState) - 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// Waitstates when executing opcode
|
|
||||||
inline int codeTicksAccess16(u32 address) // THUMB NON SEQ
|
|
||||||
{
|
|
||||||
int addr = (address>>24)&15;
|
|
||||||
|
|
||||||
if ((addr>=0x08) && (addr<=0x0D))
|
|
||||||
{
|
|
||||||
if (busPrefetchCount&0x1)
|
|
||||||
{
|
|
||||||
if (busPrefetchCount&0x2)
|
|
||||||
{
|
|
||||||
busPrefetchCount = ((busPrefetchCount&0xFF)>>2) | (busPrefetchCount&0xFFFFFF00);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
busPrefetchCount = ((busPrefetchCount&0xFF)>>1) | (busPrefetchCount&0xFFFFFF00);
|
|
||||||
return memoryWaitSeq[addr]-1;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
busPrefetchCount=0;
|
|
||||||
return memoryWait[addr];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
busPrefetchCount = 0;
|
|
||||||
return memoryWait[addr];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
inline int codeTicksAccess32(u32 address) // ARM NON SEQ
|
|
||||||
{
|
|
||||||
int addr = (address>>24)&15;
|
|
||||||
|
|
||||||
if ((addr>=0x08) && (addr<=0x0D))
|
|
||||||
{
|
|
||||||
if (busPrefetchCount&0x1)
|
|
||||||
{
|
|
||||||
if (busPrefetchCount&0x2)
|
|
||||||
{
|
|
||||||
busPrefetchCount = ((busPrefetchCount&0xFF)>>2) | (busPrefetchCount&0xFFFFFF00);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
busPrefetchCount = ((busPrefetchCount&0xFF)>>1) | (busPrefetchCount&0xFFFFFF00);
|
|
||||||
return memoryWaitSeq[addr] - 1;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
busPrefetchCount = 0;
|
|
||||||
return memoryWait32[addr];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
busPrefetchCount = 0;
|
|
||||||
return memoryWait32[addr];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
inline int codeTicksAccessSeq16(u32 address) // THUMB SEQ
|
|
||||||
{
|
|
||||||
int addr = (address>>24)&15;
|
|
||||||
|
|
||||||
if ((addr>=0x08) && (addr<=0x0D))
|
|
||||||
{
|
|
||||||
if (busPrefetchCount&0x1)
|
|
||||||
{
|
|
||||||
busPrefetchCount = ((busPrefetchCount&0xFF)>>1) | (busPrefetchCount&0xFFFFFF00);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
if (busPrefetchCount>0xFF)
|
|
||||||
{
|
|
||||||
busPrefetchCount=0;
|
|
||||||
return memoryWait[addr];
|
|
||||||
}
|
|
||||||
else
|
|
||||||
return memoryWaitSeq[addr];
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
busPrefetchCount = 0;
|
|
||||||
return memoryWaitSeq[addr];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
inline int codeTicksAccessSeq32(u32 address) // ARM SEQ
|
|
||||||
{
|
|
||||||
int addr = (address>>24)&15;
|
|
||||||
|
|
||||||
if ((addr>=0x08) && (addr<=0x0D))
|
|
||||||
{
|
|
||||||
if (busPrefetchCount&0x1)
|
|
||||||
{
|
|
||||||
if (busPrefetchCount&0x2)
|
|
||||||
{
|
|
||||||
busPrefetchCount = ((busPrefetchCount&0xFF)>>2) | (busPrefetchCount&0xFFFFFF00);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
busPrefetchCount = ((busPrefetchCount&0xFF)>>1) | (busPrefetchCount&0xFFFFFF00);
|
|
||||||
return memoryWaitSeq[addr];
|
|
||||||
}
|
|
||||||
else
|
|
||||||
if (busPrefetchCount>0xFF)
|
|
||||||
{
|
|
||||||
busPrefetchCount=0;
|
|
||||||
return memoryWait32[addr];
|
|
||||||
}
|
|
||||||
else
|
|
||||||
return memoryWaitSeq32[addr];
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
return memoryWaitSeq32[addr];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// Emulates the Cheat System (m) code
|
|
||||||
inline void cpuMasterCodeCheck()
|
|
||||||
{
|
|
||||||
if((mastercode) && (mastercode == armNextPC))
|
|
||||||
{
|
|
||||||
u32 joy = 0;
|
|
||||||
if(systemReadJoypads())
|
|
||||||
joy = systemReadJoypad(-1);
|
|
||||||
u32 ext = (joy >> 10);
|
|
||||||
cpuTotalTicks += cheatsCheckKeys(P1^0x3FF, ext);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif //VBA_GBAcpu_H
|
|
739
src/GBAinline.h
739
src/GBAinline.h
|
@ -1,739 +0,0 @@
|
||||||
// -*- C++ -*-
|
|
||||||
// VisualBoyAdvance - Nintendo Gameboy/GameboyAdvance (TM) emulator.
|
|
||||||
// Copyright (C) 1999-2003 Forgotten
|
|
||||||
// Copyright (C) 2005 Forgotten and the VBA development team
|
|
||||||
|
|
||||||
// This program is free software; you can redistribute it and/or modify
|
|
||||||
// it under the terms of the GNU General Public License as published by
|
|
||||||
// the Free Software Foundation; either version 2, or(at your option)
|
|
||||||
// any later version.
|
|
||||||
//
|
|
||||||
// This program is distributed in the hope that it will be useful,
|
|
||||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
// GNU General Public License for more details.
|
|
||||||
//
|
|
||||||
// You should have received a copy of the GNU General Public License
|
|
||||||
// along with this program; if not, write to the Free Software Foundation,
|
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
||||||
|
|
||||||
#ifndef VBA_GBAinline_H
|
|
||||||
#define VBA_GBAinline_H
|
|
||||||
|
|
||||||
#include "System.h"
|
|
||||||
#include "Port.h"
|
|
||||||
#include "RTC.h"
|
|
||||||
#include "Sound.h"
|
|
||||||
#include "agbprint.h"
|
|
||||||
|
|
||||||
extern const u32 objTilesAddress[3];
|
|
||||||
|
|
||||||
extern bool stopState;
|
|
||||||
extern bool holdState;
|
|
||||||
extern int holdType;
|
|
||||||
extern int cpuNextEvent;
|
|
||||||
extern bool cpuSramEnabled;
|
|
||||||
extern bool cpuFlashEnabled;
|
|
||||||
extern bool cpuEEPROMEnabled;
|
|
||||||
extern bool cpuEEPROMSensorEnabled;
|
|
||||||
extern bool cpuDmaHack;
|
|
||||||
extern u32 cpuDmaLast;
|
|
||||||
extern bool timer0On;
|
|
||||||
extern int timer0Ticks;
|
|
||||||
extern int timer0ClockReload;
|
|
||||||
extern bool timer1On;
|
|
||||||
extern int timer1Ticks;
|
|
||||||
extern int timer1ClockReload;
|
|
||||||
extern bool timer2On;
|
|
||||||
extern int timer2Ticks;
|
|
||||||
extern int timer2ClockReload;
|
|
||||||
extern bool timer3On;
|
|
||||||
extern int timer3Ticks;
|
|
||||||
extern int timer3ClockReload;
|
|
||||||
extern int cpuTotalTicks;
|
|
||||||
|
|
||||||
#define CPUReadByteQuick(addr) \
|
|
||||||
map[(addr)>>24].address[(addr) & map[(addr)>>24].mask]
|
|
||||||
|
|
||||||
#define CPUReadHalfWordQuick(addr) \
|
|
||||||
READ16LE(((u16*)&map[(addr)>>24].address[(addr) & map[(addr)>>24].mask]))
|
|
||||||
|
|
||||||
#define CPUReadMemoryQuick(addr) \
|
|
||||||
READ32LE(((u32*)&map[(addr)>>24].address[(addr) & map[(addr)>>24].mask]))
|
|
||||||
|
|
||||||
static inline u32 CPUReadMemory(u32 address)
|
|
||||||
{
|
|
||||||
|
|
||||||
#ifdef GBA_LOGGING
|
|
||||||
if(address & 3) {
|
|
||||||
if(systemVerbose & VERBOSE_UNALIGNED_MEMORY) {
|
|
||||||
log("Unaligned word read: %08x at %08x\n", address, armMode ?
|
|
||||||
armNextPC - 4 : armNextPC - 2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
u32 value;
|
|
||||||
switch(address >> 24) {
|
|
||||||
case 0:
|
|
||||||
if(reg[15].I >> 24) {
|
|
||||||
if(address < 0x4000) {
|
|
||||||
#ifdef GBA_LOGGING
|
|
||||||
if(systemVerbose & VERBOSE_ILLEGAL_READ) {
|
|
||||||
log("Illegal word read: %08x at %08x\n", address, armMode ?
|
|
||||||
armNextPC - 4 : armNextPC - 2);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
value = READ32LE(((u32 *)&biosProtected));
|
|
||||||
}
|
|
||||||
else goto unreadable;
|
|
||||||
} else
|
|
||||||
value = READ32LE(((u32 *)&bios[address & 0x3FFC]));
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
value = READ32LE(((u32 *)&workRAM[address & 0x3FFFC]));
|
|
||||||
break;
|
|
||||||
case 3:
|
|
||||||
value = READ32LE(((u32 *)&internalRAM[address & 0x7ffC]));
|
|
||||||
break;
|
|
||||||
case 4:
|
|
||||||
if((address < 0x4000400) && ioReadable[address & 0x3fc]) {
|
|
||||||
if(ioReadable[(address & 0x3fc) + 2])
|
|
||||||
value = READ32LE(((u32 *)&ioMem[address & 0x3fC]));
|
|
||||||
else
|
|
||||||
value = READ16LE(((u16 *)&ioMem[address & 0x3fc]));
|
|
||||||
} else goto unreadable;
|
|
||||||
break;
|
|
||||||
case 5:
|
|
||||||
value = READ32LE(((u32 *)&paletteRAM[address & 0x3fC]));
|
|
||||||
break;
|
|
||||||
case 6:
|
|
||||||
address = (address & 0x1fffc);
|
|
||||||
if (((DISPCNT & 7) >2) && ((address & 0x1C000) == 0x18000))
|
|
||||||
{
|
|
||||||
value = 0;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if ((address & 0x18000) == 0x18000)
|
|
||||||
address &= 0x17fff;
|
|
||||||
value = READ32LE(((u32 *)&vram[address]));
|
|
||||||
break;
|
|
||||||
case 7:
|
|
||||||
value = READ32LE(((u32 *)&oam[address & 0x3FC]));
|
|
||||||
break;
|
|
||||||
case 8:
|
|
||||||
case 9:
|
|
||||||
case 10:
|
|
||||||
case 11:
|
|
||||||
case 12:
|
|
||||||
value = READ32LE(((u32 *)&rom[address&0x1FFFFFC]));
|
|
||||||
break;
|
|
||||||
case 13:
|
|
||||||
if(cpuEEPROMEnabled)
|
|
||||||
// no need to swap this
|
|
||||||
return eepromRead(address);
|
|
||||||
goto unreadable;
|
|
||||||
case 14:
|
|
||||||
if(cpuFlashEnabled | cpuSramEnabled)
|
|
||||||
// no need to swap this
|
|
||||||
return flashRead(address);
|
|
||||||
// default
|
|
||||||
default:
|
|
||||||
unreadable:
|
|
||||||
#ifdef GBA_LOGGING
|
|
||||||
if(systemVerbose & VERBOSE_ILLEGAL_READ) {
|
|
||||||
log("Illegal word read: %08x at %08x\n", address, armMode ?
|
|
||||||
armNextPC - 4 : armNextPC - 2);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if(cpuDmaHack) {
|
|
||||||
value = cpuDmaLast;
|
|
||||||
} else {
|
|
||||||
if(armState) {
|
|
||||||
value = CPUReadMemoryQuick(reg[15].I);
|
|
||||||
} else {
|
|
||||||
value = CPUReadHalfWordQuick(reg[15].I) |
|
|
||||||
CPUReadHalfWordQuick(reg[15].I) << 16;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if(address & 3) {
|
|
||||||
#ifdef C_CORE
|
|
||||||
int shift = (address & 3) << 3;
|
|
||||||
value = (value >> shift) | (value << (32 - shift));
|
|
||||||
#else
|
|
||||||
#ifdef __GNUC__
|
|
||||||
asm("and $3, %%ecx;"
|
|
||||||
"shl $3 ,%%ecx;"
|
|
||||||
"ror %%cl, %0"
|
|
||||||
: "=r" (value)
|
|
||||||
: "r" (value), "c" (address));
|
|
||||||
#else
|
|
||||||
__asm {
|
|
||||||
mov ecx, address;
|
|
||||||
and ecx, 3;
|
|
||||||
shl ecx, 3;
|
|
||||||
ror [dword ptr value], cl;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
extern u32 myROM[];
|
|
||||||
|
|
||||||
static inline u32 CPUReadHalfWord(u32 address)
|
|
||||||
{
|
|
||||||
#ifdef GBA_LOGGING
|
|
||||||
if(address & 1) {
|
|
||||||
if(systemVerbose & VERBOSE_UNALIGNED_MEMORY) {
|
|
||||||
log("Unaligned halfword read: %08x at %08x\n", address, armMode ?
|
|
||||||
armNextPC - 4 : armNextPC - 2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
u32 value;
|
|
||||||
|
|
||||||
switch(address >> 24) {
|
|
||||||
case 0:
|
|
||||||
if (reg[15].I >> 24) {
|
|
||||||
if(address < 0x4000) {
|
|
||||||
#ifdef GBA_LOGGING
|
|
||||||
if(systemVerbose & VERBOSE_ILLEGAL_READ) {
|
|
||||||
log("Illegal halfword read: %08x at %08x\n", address, armMode ?
|
|
||||||
armNextPC - 4 : armNextPC - 2);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
value = READ16LE(((u16 *)&biosProtected[address&2]));
|
|
||||||
} else goto unreadable;
|
|
||||||
} else
|
|
||||||
value = READ16LE(((u16 *)&bios[address & 0x3FFE]));
|
|
||||||
break;
|
|
||||||
case 2:
|
|
||||||
value = READ16LE(((u16 *)&workRAM[address & 0x3FFFE]));
|
|
||||||
break;
|
|
||||||
case 3:
|
|
||||||
value = READ16LE(((u16 *)&internalRAM[address & 0x7ffe]));
|
|
||||||
break;
|
|
||||||
case 4:
|
|
||||||
if((address < 0x4000400) && ioReadable[address & 0x3fe])
|
|
||||||
{
|
|
||||||
value = READ16LE(((u16 *)&ioMem[address & 0x3fe]));
|
|
||||||
if (((address & 0x3fe)>0xFF) && ((address & 0x3fe)<0x10E))
|
|
||||||
{
|
|
||||||
if (((address & 0x3fe) == 0x100) && timer0On)
|
|
||||||
value = 0xFFFF - ((timer0Ticks-cpuTotalTicks) >> timer0ClockReload);
|
|
||||||
else
|
|
||||||
if (((address & 0x3fe) == 0x104) && timer1On && !(TM1CNT & 4))
|
|
||||||
value = 0xFFFF - ((timer1Ticks-cpuTotalTicks) >> timer1ClockReload);
|
|
||||||
else
|
|
||||||
if (((address & 0x3fe) == 0x108) && timer2On && !(TM2CNT & 4))
|
|
||||||
value = 0xFFFF - ((timer2Ticks-cpuTotalTicks) >> timer2ClockReload);
|
|
||||||
else
|
|
||||||
if (((address & 0x3fe) == 0x10C) && timer3On && !(TM3CNT & 4))
|
|
||||||
value = 0xFFFF - ((timer3Ticks-cpuTotalTicks) >> timer3ClockReload);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else goto unreadable;
|
|
||||||
break;
|
|
||||||
case 5:
|
|
||||||
value = READ16LE(((u16 *)&paletteRAM[address & 0x3fe]));
|
|
||||||
break;
|
|
||||||
case 6:
|
|
||||||
address = (address & 0x1fffe);
|
|
||||||
if (((DISPCNT & 7) >2) && ((address & 0x1C000) == 0x18000))
|
|
||||||
{
|
|
||||||
value = 0;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
if ((address & 0x18000) == 0x18000)
|
|
||||||
address &= 0x17fff;
|
|
||||||
value = READ16LE(((u16 *)&vram[address]));
|
|
||||||
break;
|
|
||||||
case 7:
|
|
||||||
value = READ16LE(((u16 *)&oam[address & 0x3fe]));
|
|
||||||
break;
|
|
||||||
case 8:
|
|
||||||
case 9:
|
|
||||||
case 10:
|
|
||||||
case 11:
|
|
||||||
case 12:
|
|
||||||
if(address == 0x80000c4 || address == 0x80000c6 || address == 0x80000c8)
|
|
||||||
value = rtcRead(address);
|
|
||||||
else
|
|
||||||
value = READ16LE(((u16 *)&rom[address & 0x1FFFFFE]));
|
|
||||||
break;
|
|
||||||
case 13:
|
|
||||||
if(cpuEEPROMEnabled)
|
|
||||||
// no need to swap this
|
|
||||||
return eepromRead(address);
|
|
||||||
goto unreadable;
|
|
||||||
case 14:
|
|
||||||
if(cpuFlashEnabled | cpuSramEnabled)
|
|
||||||
// no need to swap this
|
|
||||||
return flashRead(address);
|
|
||||||
// default
|
|
||||||
default:
|
|
||||||
unreadable:
|
|
||||||
#ifdef GBA_LOGGING
|
|
||||||
if(systemVerbose & VERBOSE_ILLEGAL_READ) {
|
|
||||||
log("Illegal halfword read: %08x at %08x\n", address, armMode ?
|
|
||||||
armNextPC - 4 : armNextPC - 2);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if(cpuDmaHack) {
|
|
||||||
value = cpuDmaLast & 0xFFFF;
|
|
||||||
} else {
|
|
||||||
if(armState) {
|
|
||||||
value = CPUReadHalfWordQuick(reg[15].I + (address & 2));
|
|
||||||
} else {
|
|
||||||
value = CPUReadHalfWordQuick(reg[15].I);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if(address & 1) {
|
|
||||||
value = (value >> 8) | (value << 24);
|
|
||||||
}
|
|
||||||
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline u16 CPUReadHalfWordSigned(u32 address)
|
|
||||||
{
|
|
||||||
u16 value = CPUReadHalfWord(address);
|
|
||||||
if((address & 1))
|
|
||||||
value = (s8)value;
|
|
||||||
return value;
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline u8 CPUReadByte(u32 address)
|
|
||||||
{
|
|
||||||
switch(address >> 24) {
|
|
||||||
case 0:
|
|
||||||
if (reg[15].I >> 24) {
|
|
||||||
if(address < 0x4000) {
|
|
||||||
#ifdef GBA_LOGGING
|
|
||||||
if(systemVerbose & VERBOSE_ILLEGAL_READ) {
|
|
||||||
log("Illegal byte read: %08x at %08x\n", address, armMode ?
|
|
||||||
armNextPC - 4 : armNextPC - 2);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
return biosProtected[address & 3];
|
|
||||||
} else goto unreadable;
|
|
||||||
}
|
|
||||||
return bios[address & 0x3FFF];
|
|
||||||
case 2:
|
|
||||||
return workRAM[address & 0x3FFFF];
|
|
||||||
case 3:
|
|
||||||
return internalRAM[address & 0x7fff];
|
|
||||||
case 4:
|
|
||||||
if((address < 0x4000400) && ioReadable[address & 0x3ff])
|
|
||||||
return ioMem[address & 0x3ff];
|
|
||||||
else goto unreadable;
|
|
||||||
case 5:
|
|
||||||
return paletteRAM[address & 0x3ff];
|
|
||||||
case 6:
|
|
||||||
address = (address & 0x1ffff);
|
|
||||||
if (((DISPCNT & 7) >2) && ((address & 0x1C000) == 0x18000))
|
|
||||||
return 0;
|
|
||||||
if ((address & 0x18000) == 0x18000)
|
|
||||||
address &= 0x17fff;
|
|
||||||
return vram[address];
|
|
||||||
case 7:
|
|
||||||
return oam[address & 0x3ff];
|
|
||||||
case 8:
|
|
||||||
case 9:
|
|
||||||
case 10:
|
|
||||||
case 11:
|
|
||||||
case 12:
|
|
||||||
return rom[address & 0x1FFFFFF];
|
|
||||||
case 13:
|
|
||||||
if(cpuEEPROMEnabled)
|
|
||||||
return eepromRead(address);
|
|
||||||
goto unreadable;
|
|
||||||
case 14:
|
|
||||||
if(cpuSramEnabled | cpuFlashEnabled)
|
|
||||||
return flashRead(address);
|
|
||||||
if(cpuEEPROMSensorEnabled) {
|
|
||||||
switch(address & 0x00008f00) {
|
|
||||||
case 0x8200:
|
|
||||||
return systemGetSensorX() & 255;
|
|
||||||
case 0x8300:
|
|
||||||
return (systemGetSensorX() >> 8)|0x80;
|
|
||||||
case 0x8400:
|
|
||||||
return systemGetSensorY() & 255;
|
|
||||||
case 0x8500:
|
|
||||||
return systemGetSensorY() >> 8;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// default
|
|
||||||
default:
|
|
||||||
unreadable:
|
|
||||||
#ifdef GBA_LOGGING
|
|
||||||
if(systemVerbose & VERBOSE_ILLEGAL_READ) {
|
|
||||||
log("Illegal byte read: %08x at %08x\n", address, armMode ?
|
|
||||||
armNextPC - 4 : armNextPC - 2);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
if(cpuDmaHack) {
|
|
||||||
return cpuDmaLast & 0xFF;
|
|
||||||
} else {
|
|
||||||
if(armState) {
|
|
||||||
return CPUReadByteQuick(reg[15].I+(address & 3));
|
|
||||||
} else {
|
|
||||||
return CPUReadByteQuick(reg[15].I+(address & 1));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void CPUWriteMemory(u32 address, u32 value)
|
|
||||||
{
|
|
||||||
|
|
||||||
#ifdef GBA_LOGGING
|
|
||||||
if(address & 3) {
|
|
||||||
if(systemVerbose & VERBOSE_UNALIGNED_MEMORY) {
|
|
||||||
log("Unaligned word write: %08x to %08x from %08x\n",
|
|
||||||
value,
|
|
||||||
address,
|
|
||||||
armMode ? armNextPC - 4 : armNextPC - 2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
switch(address >> 24) {
|
|
||||||
case 0x02:
|
|
||||||
#ifdef BKPT_SUPPORT
|
|
||||||
if(*((u32 *)&freezeWorkRAM[address & 0x3FFFC]))
|
|
||||||
cheatsWriteMemory(address & 0x203FFFC,
|
|
||||||
value);
|
|
||||||
else
|
|
||||||
#endif
|
|
||||||
WRITE32LE(((u32 *)&workRAM[address & 0x3FFFC]), value);
|
|
||||||
break;
|
|
||||||
case 0x03:
|
|
||||||
#ifdef BKPT_SUPPORT
|
|
||||||
if(*((u32 *)&freezeInternalRAM[address & 0x7ffc]))
|
|
||||||
cheatsWriteMemory(address & 0x3007FFC,
|
|
||||||
value);
|
|
||||||
else
|
|
||||||
#endif
|
|
||||||
WRITE32LE(((u32 *)&internalRAM[address & 0x7ffC]), value);
|
|
||||||
break;
|
|
||||||
case 0x04:
|
|
||||||
if(address < 0x4000400) {
|
|
||||||
CPUUpdateRegister((address & 0x3FC), value & 0xFFFF);
|
|
||||||
CPUUpdateRegister((address & 0x3FC) + 2, (value >> 16));
|
|
||||||
} else goto unwritable;
|
|
||||||
break;
|
|
||||||
case 0x05:
|
|
||||||
#ifdef BKPT_SUPPORT
|
|
||||||
if(*((u32 *)&freezePRAM[address & 0x3fc]))
|
|
||||||
cheatsWriteMemory(address & 0x70003FC,
|
|
||||||
value);
|
|
||||||
else
|
|
||||||
#endif
|
|
||||||
WRITE32LE(((u32 *)&paletteRAM[address & 0x3FC]), value);
|
|
||||||
break;
|
|
||||||
case 0x06:
|
|
||||||
address = (address & 0x1fffc);
|
|
||||||
if (((DISPCNT & 7) >2) && ((address & 0x1C000) == 0x18000))
|
|
||||||
return;
|
|
||||||
if ((address & 0x18000) == 0x18000)
|
|
||||||
address &= 0x17fff;
|
|
||||||
|
|
||||||
#ifdef BKPT_SUPPORT
|
|
||||||
if(*((u32 *)&freezeVRAM[address]))
|
|
||||||
cheatsWriteMemory(address + 0x06000000, value);
|
|
||||||
else
|
|
||||||
#endif
|
|
||||||
|
|
||||||
WRITE32LE(((u32 *)&vram[address]), value);
|
|
||||||
break;
|
|
||||||
case 0x07:
|
|
||||||
#ifdef BKPT_SUPPORT
|
|
||||||
if(*((u32 *)&freezeOAM[address & 0x3fc]))
|
|
||||||
cheatsWriteMemory(address & 0x70003FC,
|
|
||||||
value);
|
|
||||||
else
|
|
||||||
#endif
|
|
||||||
WRITE32LE(((u32 *)&oam[address & 0x3fc]), value);
|
|
||||||
break;
|
|
||||||
case 0x0D:
|
|
||||||
if(cpuEEPROMEnabled) {
|
|
||||||
eepromWrite(address, value);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
goto unwritable;
|
|
||||||
case 0x0E:
|
|
||||||
if(!eepromInUse | cpuSramEnabled | cpuFlashEnabled) {
|
|
||||||
(*cpuSaveGameFunc)(address, (u8)value);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
// default
|
|
||||||
default:
|
|
||||||
unwritable:
|
|
||||||
#ifdef GBA_LOGGING
|
|
||||||
if(systemVerbose & VERBOSE_ILLEGAL_WRITE) {
|
|
||||||
log("Illegal word write: %08x to %08x from %08x\n",
|
|
||||||
value,
|
|
||||||
address,
|
|
||||||
armMode ? armNextPC - 4 : armNextPC - 2);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void CPUWriteHalfWord(u32 address, u16 value)
|
|
||||||
{
|
|
||||||
#ifdef GBA_LOGGING
|
|
||||||
if(address & 1) {
|
|
||||||
if(systemVerbose & VERBOSE_UNALIGNED_MEMORY) {
|
|
||||||
log("Unaligned halfword write: %04x to %08x from %08x\n",
|
|
||||||
value,
|
|
||||||
address,
|
|
||||||
armMode ? armNextPC - 4 : armNextPC - 2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
switch(address >> 24) {
|
|
||||||
case 2:
|
|
||||||
#ifdef BKPT_SUPPORT
|
|
||||||
if(*((u16 *)&freezeWorkRAM[address & 0x3FFFE]))
|
|
||||||
cheatsWriteHalfWord(address & 0x203FFFE,
|
|
||||||
value);
|
|
||||||
else
|
|
||||||
#endif
|
|
||||||
WRITE16LE(((u16 *)&workRAM[address & 0x3FFFE]),value);
|
|
||||||
break;
|
|
||||||
case 3:
|
|
||||||
#ifdef BKPT_SUPPORT
|
|
||||||
if(*((u16 *)&freezeInternalRAM[address & 0x7ffe]))
|
|
||||||
cheatsWriteHalfWord(address & 0x3007ffe,
|
|
||||||
value);
|
|
||||||
else
|
|
||||||
#endif
|
|
||||||
WRITE16LE(((u16 *)&internalRAM[address & 0x7ffe]), value);
|
|
||||||
break;
|
|
||||||
case 4:
|
|
||||||
if(address < 0x4000400)
|
|
||||||
CPUUpdateRegister(address & 0x3fe, value);
|
|
||||||
else goto unwritable;
|
|
||||||
break;
|
|
||||||
case 5:
|
|
||||||
#ifdef BKPT_SUPPORT
|
|
||||||
if(*((u16 *)&freezePRAM[address & 0x03fe]))
|
|
||||||
cheatsWriteHalfWord(address & 0x70003fe,
|
|
||||||
value);
|
|
||||||
else
|
|
||||||
#endif
|
|
||||||
WRITE16LE(((u16 *)&paletteRAM[address & 0x3fe]), value);
|
|
||||||
break;
|
|
||||||
case 6:
|
|
||||||
address = (address & 0x1fffe);
|
|
||||||
if (((DISPCNT & 7) >2) && ((address & 0x1C000) == 0x18000))
|
|
||||||
return;
|
|
||||||
if ((address & 0x18000) == 0x18000)
|
|
||||||
address &= 0x17fff;
|
|
||||||
#ifdef BKPT_SUPPORT
|
|
||||||
if(*((u16 *)&freezeVRAM[address]))
|
|
||||||
cheatsWriteHalfWord(address + 0x06000000,
|
|
||||||
value);
|
|
||||||
else
|
|
||||||
#endif
|
|
||||||
WRITE16LE(((u16 *)&vram[address]), value);
|
|
||||||
break;
|
|
||||||
case 7:
|
|
||||||
#ifdef BKPT_SUPPORT
|
|
||||||
if(*((u16 *)&freezeOAM[address & 0x03fe]))
|
|
||||||
cheatsWriteHalfWord(address & 0x70003fe,
|
|
||||||
value);
|
|
||||||
else
|
|
||||||
#endif
|
|
||||||
WRITE16LE(((u16 *)&oam[address & 0x3fe]), value);
|
|
||||||
break;
|
|
||||||
case 8:
|
|
||||||
case 9:
|
|
||||||
if(address == 0x80000c4 || address == 0x80000c6 || address == 0x80000c8) {
|
|
||||||
if(!rtcWrite(address, value))
|
|
||||||
goto unwritable;
|
|
||||||
} else if(!agbPrintWrite(address, value)) goto unwritable;
|
|
||||||
break;
|
|
||||||
case 13:
|
|
||||||
if(cpuEEPROMEnabled) {
|
|
||||||
eepromWrite(address, (u8)value);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
goto unwritable;
|
|
||||||
case 14:
|
|
||||||
if(!eepromInUse | cpuSramEnabled | cpuFlashEnabled) {
|
|
||||||
(*cpuSaveGameFunc)(address, (u8)value);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
goto unwritable;
|
|
||||||
default:
|
|
||||||
unwritable:
|
|
||||||
#ifdef GBA_LOGGING
|
|
||||||
if(systemVerbose & VERBOSE_ILLEGAL_WRITE) {
|
|
||||||
log("Illegal halfword write: %04x to %08x from %08x\n",
|
|
||||||
value,
|
|
||||||
address,
|
|
||||||
armMode ? armNextPC - 4 : armNextPC - 2);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static inline void CPUWriteByte(u32 address, u8 b)
|
|
||||||
{
|
|
||||||
switch(address >> 24) {
|
|
||||||
case 2:
|
|
||||||
#ifdef BKPT_SUPPORT
|
|
||||||
if(freezeWorkRAM[address & 0x3FFFF])
|
|
||||||
cheatsWriteByte(address & 0x203FFFF, b);
|
|
||||||
else
|
|
||||||
#endif
|
|
||||||
workRAM[address & 0x3FFFF] = b;
|
|
||||||
break;
|
|
||||||
case 3:
|
|
||||||
#ifdef BKPT_SUPPORT
|
|
||||||
if(freezeInternalRAM[address & 0x7fff])
|
|
||||||
cheatsWriteByte(address & 0x3007fff, b);
|
|
||||||
else
|
|
||||||
#endif
|
|
||||||
internalRAM[address & 0x7fff] = b;
|
|
||||||
break;
|
|
||||||
case 4:
|
|
||||||
if(address < 0x4000400) {
|
|
||||||
switch(address & 0x3FF) {
|
|
||||||
case 0x301:
|
|
||||||
if(b == 0x80)
|
|
||||||
stopState = true;
|
|
||||||
holdState = 1;
|
|
||||||
holdType = -1;
|
|
||||||
cpuNextEvent = cpuTotalTicks;
|
|
||||||
break;
|
|
||||||
case 0x60:
|
|
||||||
case 0x61:
|
|
||||||
case 0x62:
|
|
||||||
case 0x63:
|
|
||||||
case 0x64:
|
|
||||||
case 0x65:
|
|
||||||
case 0x68:
|
|
||||||
case 0x69:
|
|
||||||
case 0x6c:
|
|
||||||
case 0x6d:
|
|
||||||
case 0x70:
|
|
||||||
case 0x71:
|
|
||||||
case 0x72:
|
|
||||||
case 0x73:
|
|
||||||
case 0x74:
|
|
||||||
case 0x75:
|
|
||||||
case 0x78:
|
|
||||||
case 0x79:
|
|
||||||
case 0x7c:
|
|
||||||
case 0x7d:
|
|
||||||
case 0x80:
|
|
||||||
case 0x81:
|
|
||||||
case 0x84:
|
|
||||||
case 0x85:
|
|
||||||
case 0x90:
|
|
||||||
case 0x91:
|
|
||||||
case 0x92:
|
|
||||||
case 0x93:
|
|
||||||
case 0x94:
|
|
||||||
case 0x95:
|
|
||||||
case 0x96:
|
|
||||||
case 0x97:
|
|
||||||
case 0x98:
|
|
||||||
case 0x99:
|
|
||||||
case 0x9a:
|
|
||||||
case 0x9b:
|
|
||||||
case 0x9c:
|
|
||||||
case 0x9d:
|
|
||||||
case 0x9e:
|
|
||||||
case 0x9f:
|
|
||||||
soundEvent(address&0xFF, b);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
if(address & 1)
|
|
||||||
CPUUpdateRegister(address & 0x3fe,
|
|
||||||
((READ16LE(((u16 *)&ioMem[address & 0x3fe])))
|
|
||||||
& 0x00FF) |
|
|
||||||
b<<8);
|
|
||||||
else
|
|
||||||
CPUUpdateRegister(address & 0x3fe,
|
|
||||||
((READ16LE(((u16 *)&ioMem[address & 0x3fe])) & 0xFF00) | b));
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
} else goto unwritable;
|
|
||||||
break;
|
|
||||||
case 5:
|
|
||||||
// no need to switch
|
|
||||||
*((u16 *)&paletteRAM[address & 0x3FE]) = (b << 8) | b;
|
|
||||||
break;
|
|
||||||
case 6:
|
|
||||||
address = (address & 0x1fffe);
|
|
||||||
if (((DISPCNT & 7) >2) && ((address & 0x1C000) == 0x18000))
|
|
||||||
return;
|
|
||||||
if ((address & 0x18000) == 0x18000)
|
|
||||||
address &= 0x17fff;
|
|
||||||
|
|
||||||
// no need to switch
|
|
||||||
// byte writes to OBJ VRAM are ignored
|
|
||||||
if ((address) < objTilesAddress[((DISPCNT&7)+1)>>2])
|
|
||||||
{
|
|
||||||
#ifdef BKPT_SUPPORT
|
|
||||||
if(freezeVRAM[address])
|
|
||||||
cheatsWriteByte(address + 0x06000000, b);
|
|
||||||
else
|
|
||||||
#endif
|
|
||||||
*((u16 *)&vram[address]) = (b << 8) | b;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 7:
|
|
||||||
// no need to switch
|
|
||||||
// byte writes to OAM are ignored
|
|
||||||
// *((u16 *)&oam[address & 0x3FE]) = (b << 8) | b;
|
|
||||||
break;
|
|
||||||
case 13:
|
|
||||||
if(cpuEEPROMEnabled) {
|
|
||||||
eepromWrite(address, b);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
goto unwritable;
|
|
||||||
case 14:
|
|
||||||
if (!(saveType == 5) && (!eepromInUse | cpuSramEnabled | cpuFlashEnabled)) {
|
|
||||||
|
|
||||||
//if(!cpuEEPROMEnabled && (cpuSramEnabled | cpuFlashEnabled)) {
|
|
||||||
|
|
||||||
(*cpuSaveGameFunc)(address, b);
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
// default
|
|
||||||
default:
|
|
||||||
unwritable:
|
|
||||||
#ifdef GBA_LOGGING
|
|
||||||
if(systemVerbose & VERBOSE_ILLEGAL_WRITE) {
|
|
||||||
log("Illegal byte write: %02x to %08x from %08x\n",
|
|
||||||
b,
|
|
||||||
address,
|
|
||||||
armMode ? armNextPC - 4 : armNextPC -2 );
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif //VBA_GBAinline_H
|
|
47
src/Gfx.cpp
47
src/Gfx.cpp
|
@ -1,47 +0,0 @@
|
||||||
// VisualBoyAdvance - Nintendo Gameboy/GameboyAdvance (TM) emulator.
|
|
||||||
// Copyright (C) 1999-2003 Forgotten
|
|
||||||
// Copyright (C) 2004 Forgotten and the VBA development team
|
|
||||||
|
|
||||||
// This program is free software; you can redistribute it and/or modify
|
|
||||||
// it under the terms of the GNU General Public License as published by
|
|
||||||
// the Free Software Foundation; either version 2, or(at your option)
|
|
||||||
// any later version.
|
|
||||||
//
|
|
||||||
// This program is distributed in the hope that it will be useful,
|
|
||||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
// GNU General Public License for more details.
|
|
||||||
//
|
|
||||||
// You should have received a copy of the GNU General Public License
|
|
||||||
// along with this program; if not, write to the Free Software Foundation,
|
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
||||||
|
|
||||||
#include "System.h"
|
|
||||||
|
|
||||||
int coeff[32] = {
|
|
||||||
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,
|
|
||||||
16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16, 16};
|
|
||||||
|
|
||||||
u32 line0[240];
|
|
||||||
u32 line1[240];
|
|
||||||
u32 line2[240];
|
|
||||||
u32 line3[240];
|
|
||||||
u32 lineOBJ[240];
|
|
||||||
u32 lineOBJWin[240];
|
|
||||||
u32 lineMix[240];
|
|
||||||
bool gfxInWin0[240];
|
|
||||||
bool gfxInWin1[240];
|
|
||||||
int lineOBJpixleft[128];
|
|
||||||
|
|
||||||
int gfxBG2Changed = 0;
|
|
||||||
int gfxBG3Changed = 0;
|
|
||||||
|
|
||||||
int gfxBG2X = 0;
|
|
||||||
int gfxBG2Y = 0;
|
|
||||||
int gfxBG2LastX = 0;
|
|
||||||
int gfxBG2LastY = 0;
|
|
||||||
int gfxBG3X = 0;
|
|
||||||
int gfxBG3Y = 0;
|
|
||||||
int gfxBG3LastX = 0;
|
|
||||||
int gfxBG3LastY = 0;
|
|
||||||
int gfxLastVCOUNT = 0;
|
|
|
@ -16,7 +16,7 @@
|
||||||
// along with this program; if not, write to the Free Software Foundation,
|
// along with this program; if not, write to the Free Software Foundation,
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
#include "GBA.h"
|
#include "agb/GBA.h"
|
||||||
|
|
||||||
#ifdef BKPT_SUPPORT
|
#ifdef BKPT_SUPPORT
|
||||||
int oldreg[17];
|
int oldreg[17];
|
||||||
|
|
1083
src/Link.cpp
1083
src/Link.cpp
File diff suppressed because it is too large
Load Diff
124
src/Link.h
124
src/Link.h
|
@ -1,124 +0,0 @@
|
||||||
// VisualBoyAdvance - Nintendo Gameboy/GameboyAdvance (TM) emulator.
|
|
||||||
// Copyright (C) 1999-2003 Forgotten
|
|
||||||
// Copyright (C) 2004 Forgotten and the VBA development team
|
|
||||||
|
|
||||||
// This program is free software; you can redistribute it and/or modify
|
|
||||||
// it under the terms of the GNU General Public License as published by
|
|
||||||
// the Free Software Foundation; either version 2, or(at your option)
|
|
||||||
// any later version.
|
|
||||||
//
|
|
||||||
// This program is distributed in the hope that it will be useful,
|
|
||||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
// GNU General Public License for more details.
|
|
||||||
//
|
|
||||||
// You should have received a copy of the GNU General Public License
|
|
||||||
// along with this program; if not, write to the Free Software Foundation,
|
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
||||||
|
|
||||||
#include<winsock.h>
|
|
||||||
|
|
||||||
#ifndef LINKH
|
|
||||||
#define LINKH
|
|
||||||
#define LINK_PARENTLOST 0x80
|
|
||||||
#define UNSUPPORTED -1
|
|
||||||
#define MULTIPLAYER 0
|
|
||||||
#define NORMAL8 1
|
|
||||||
#define NORMAL32 2
|
|
||||||
#define UART 3
|
|
||||||
#define JOYBUS 4
|
|
||||||
#define GP 5
|
|
||||||
#define RFU_INIT 0
|
|
||||||
#define RFU_COMM 1
|
|
||||||
#define RFU_SEND 2
|
|
||||||
#define RFU_RECV 3
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
WORD linkdata[4];
|
|
||||||
WORD linkcmd[4];
|
|
||||||
WORD numtransfers;
|
|
||||||
int lastlinktime;
|
|
||||||
unsigned char numgbas;
|
|
||||||
unsigned char linkflags;
|
|
||||||
int rfu_q[4];
|
|
||||||
u8 rfu_request[4];
|
|
||||||
int rfu_linktime[4];
|
|
||||||
u32 rfu_bdata[4][7];
|
|
||||||
u32 rfu_data[4][32];
|
|
||||||
} LINKDATA;
|
|
||||||
|
|
||||||
class lserver{
|
|
||||||
int numbytes;
|
|
||||||
fd_set fdset;
|
|
||||||
timeval wsocktimeout;
|
|
||||||
//timeval udptimeout;
|
|
||||||
char inbuffer[256], outbuffer[256];
|
|
||||||
int *intinbuffer;
|
|
||||||
u16 *u16inbuffer;
|
|
||||||
int *intoutbuffer;
|
|
||||||
u16 *u16outbuffer;
|
|
||||||
int counter;
|
|
||||||
int done;
|
|
||||||
public:
|
|
||||||
int howmanytimes;
|
|
||||||
SOCKET tcpsocket[4];
|
|
||||||
SOCKADDR_IN udpaddr[4];
|
|
||||||
lserver(void);
|
|
||||||
int Init(void*);
|
|
||||||
void Send(void);
|
|
||||||
void Recv(void);
|
|
||||||
};
|
|
||||||
|
|
||||||
class lclient{
|
|
||||||
fd_set fdset;
|
|
||||||
timeval wsocktimeout;
|
|
||||||
char inbuffer[256], outbuffer[256];
|
|
||||||
int *intinbuffer;
|
|
||||||
u16 *u16inbuffer;
|
|
||||||
int *intoutbuffer;
|
|
||||||
u16 *u16outbuffer;
|
|
||||||
int numbytes;
|
|
||||||
public:
|
|
||||||
bool oncesend;
|
|
||||||
SOCKADDR_IN serverinfo;
|
|
||||||
SOCKET noblock;
|
|
||||||
int numtransfers;
|
|
||||||
lclient(void);
|
|
||||||
int Init(LPHOSTENT, void*);
|
|
||||||
void Send(void);
|
|
||||||
void Recv(void);
|
|
||||||
void CheckConn(void);
|
|
||||||
};
|
|
||||||
|
|
||||||
typedef struct {
|
|
||||||
SOCKET tcpsocket;
|
|
||||||
//SOCKET udpsocket;
|
|
||||||
int numgbas;
|
|
||||||
HANDLE thread;
|
|
||||||
u8 type;
|
|
||||||
u8 server;
|
|
||||||
bool terminate;
|
|
||||||
bool connected;
|
|
||||||
bool speed;
|
|
||||||
bool active;
|
|
||||||
} LANLINKDATA;
|
|
||||||
|
|
||||||
extern void LinkUpdate(void);
|
|
||||||
extern void LinkChildStop(void);
|
|
||||||
extern void LinkChildSend(u16);
|
|
||||||
extern int openLinkLog(void);
|
|
||||||
extern void closeLinkLog();
|
|
||||||
extern void CloseLanLink(void);
|
|
||||||
extern char *MakeInstanceFilename(const char *Input);
|
|
||||||
|
|
||||||
extern LANLINKDATA lanlink;
|
|
||||||
extern FILE *linklogfile;
|
|
||||||
extern int vbaid;
|
|
||||||
extern int linklog;
|
|
||||||
extern bool adapter;
|
|
||||||
extern bool linkenable;
|
|
||||||
extern int linktimeout;
|
|
||||||
extern lclient lc;
|
|
||||||
extern int linkid;
|
|
||||||
|
|
||||||
#endif
|
|
|
@ -16,9 +16,9 @@
|
||||||
// along with this program; if not, write to the Free Software Foundation,
|
// along with this program; if not, write to the Free Software Foundation,
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
#include "GBA.h"
|
#include "agb/GBA.h"
|
||||||
#include "Globals.h"
|
#include "Globals.h"
|
||||||
#include "Gfx.h"
|
#include "agb/GBAGfx.h"
|
||||||
|
|
||||||
void mode0RenderLine()
|
void mode0RenderLine()
|
||||||
{
|
{
|
||||||
|
|
|
@ -16,9 +16,9 @@
|
||||||
// along with this program; if not, write to the Free Software Foundation,
|
// along with this program; if not, write to the Free Software Foundation,
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
#include "GBA.h"
|
#include "agb/GBA.h"
|
||||||
#include "Globals.h"
|
#include "Globals.h"
|
||||||
#include "Gfx.h"
|
#include "agb/GBAGfx.h"
|
||||||
|
|
||||||
void mode1RenderLine()
|
void mode1RenderLine()
|
||||||
{
|
{
|
||||||
|
|
|
@ -16,9 +16,9 @@
|
||||||
// along with this program; if not, write to the Free Software Foundation,
|
// along with this program; if not, write to the Free Software Foundation,
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
#include "GBA.h"
|
#include "agb/GBA.h"
|
||||||
#include "Globals.h"
|
#include "Globals.h"
|
||||||
#include "Gfx.h"
|
#include "agb/GBAGfx.h"
|
||||||
|
|
||||||
void mode2RenderLine()
|
void mode2RenderLine()
|
||||||
{
|
{
|
||||||
|
|
|
@ -16,9 +16,9 @@
|
||||||
// along with this program; if not, write to the Free Software Foundation,
|
// along with this program; if not, write to the Free Software Foundation,
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
#include "GBA.h"
|
#include "agb/GBA.h"
|
||||||
#include "Globals.h"
|
#include "Globals.h"
|
||||||
#include "Gfx.h"
|
#include "agb/GBAGfx.h"
|
||||||
|
|
||||||
void mode3RenderLine()
|
void mode3RenderLine()
|
||||||
{
|
{
|
||||||
|
|
|
@ -16,8 +16,8 @@
|
||||||
// along with this program; if not, write to the Free Software Foundation,
|
// along with this program; if not, write to the Free Software Foundation,
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
#include "GBA.h"
|
#include "agb/GBA.h"
|
||||||
#include "Gfx.h"
|
#include "agb/GBAGfx.h"
|
||||||
#include "Globals.h"
|
#include "Globals.h"
|
||||||
|
|
||||||
void mode4RenderLine()
|
void mode4RenderLine()
|
||||||
|
|
|
@ -16,9 +16,9 @@
|
||||||
// along with this program; if not, write to the Free Software Foundation,
|
// along with this program; if not, write to the Free Software Foundation,
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
#include "GBA.h"
|
#include "agb/GBA.h"
|
||||||
#include "Globals.h"
|
#include "Globals.h"
|
||||||
#include "Gfx.h"
|
#include "agb/GBAGfx.h"
|
||||||
|
|
||||||
void mode5RenderLine()
|
void mode5RenderLine()
|
||||||
{
|
{
|
||||||
|
|
|
@ -17,7 +17,7 @@
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
#include "System.h"
|
#include "System.h"
|
||||||
#include "GBA.h"
|
#include "agb/GBA.h"
|
||||||
#include "Globals.h"
|
#include "Globals.h"
|
||||||
#include "Port.h"
|
#include "Port.h"
|
||||||
#include "Util.h"
|
#include "Util.h"
|
||||||
|
|
|
@ -22,13 +22,13 @@
|
||||||
|
|
||||||
#include "Sound.h"
|
#include "Sound.h"
|
||||||
|
|
||||||
#include "GBA.h"
|
#include "agb/GBA.h"
|
||||||
#include "Globals.h"
|
#include "Globals.h"
|
||||||
#include "Util.h"
|
#include "Util.h"
|
||||||
#include "Port.h"
|
#include "Port.h"
|
||||||
|
|
||||||
#include "gb/gb_apu/Gb_Apu.h"
|
#include "dmg/gb_apu/Gb_Apu.h"
|
||||||
#include "gb/gb_apu/Multi_Buffer.h"
|
#include "dmg/gb_apu/Multi_Buffer.h"
|
||||||
|
|
||||||
extern bool stopState; // TODO: silence sound when true
|
extern bool stopState; // TODO: silence sound when true
|
||||||
|
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
// along with this program; if not, write to the Free Software Foundation,
|
// along with this program; if not, write to the Free Software Foundation,
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
#include "GBA.h"
|
#include "agb/GBA.h"
|
||||||
#include "Globals.h"
|
#include "Globals.h"
|
||||||
#include "Flash.h"
|
#include "Flash.h"
|
||||||
#include "Sram.h"
|
#include "Sram.h"
|
||||||
|
|
|
@ -29,7 +29,7 @@ extern "C" {
|
||||||
#include "NLS.h"
|
#include "NLS.h"
|
||||||
#include "Util.h"
|
#include "Util.h"
|
||||||
#include "Flash.h"
|
#include "Flash.h"
|
||||||
#include "GBA.h"
|
#include "agb/GBA.h"
|
||||||
#include "Globals.h"
|
#include "Globals.h"
|
||||||
#include "RTC.h"
|
#include "RTC.h"
|
||||||
#include "Port.h"
|
#include "Port.h"
|
||||||
|
|
|
@ -1 +0,0 @@
|
||||||
AGB files will go here once src folder is cleaned up.
|
|
|
@ -1,99 +0,0 @@
|
||||||
// VisualBoyAdvance - Nintendo Gameboy/GameboyAdvance (TM) emulator.
|
|
||||||
// Copyright (C) 1999-2003 Forgotten
|
|
||||||
// Copyright (C) 2004 Forgotten and the VBA development team
|
|
||||||
|
|
||||||
// This program is free software; you can redistribute it and/or modify
|
|
||||||
// it under the terms of the GNU General Public License as published by
|
|
||||||
// the Free Software Foundation; either version 2, or(at your option)
|
|
||||||
// any later version.
|
|
||||||
//
|
|
||||||
// This program is distributed in the hope that it will be useful,
|
|
||||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
// GNU General Public License for more details.
|
|
||||||
//
|
|
||||||
// You should have received a copy of the GNU General Public License
|
|
||||||
// along with this program; if not, write to the Free Software Foundation,
|
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
||||||
|
|
||||||
#include <stdio.h>
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
#include "GBA.h"
|
|
||||||
#include "Globals.h"
|
|
||||||
#include "Port.h"
|
|
||||||
|
|
||||||
#define debuggerWriteHalfWord(addr, value) \
|
|
||||||
WRITE16LE((u16*)&map[(addr)>>24].address[(addr) & map[(addr)>>24].mask], (value))
|
|
||||||
|
|
||||||
#define debuggerReadHalfWord(addr) \
|
|
||||||
READ16LE(((u16*)&map[(addr)>>24].address[(addr) & map[(addr)>>24].mask]))
|
|
||||||
|
|
||||||
static bool agbPrintEnabled = false;
|
|
||||||
static bool agbPrintProtect = false;
|
|
||||||
|
|
||||||
bool agbPrintWrite(u32 address, u16 value)
|
|
||||||
{
|
|
||||||
if(agbPrintEnabled) {
|
|
||||||
if(address == 0x9fe2ffe) { // protect
|
|
||||||
agbPrintProtect = (value != 0);
|
|
||||||
debuggerWriteHalfWord(address, value);
|
|
||||||
return true;
|
|
||||||
} else {
|
|
||||||
if(agbPrintProtect &&
|
|
||||||
((address >= 0x9fe20f8 && address <= 0x9fe20ff) // control structure
|
|
||||||
|| (address >= 0x8fd0000 && address <= 0x8fdffff)
|
|
||||||
|| (address >= 0x9fd0000 && address <= 0x9fdffff))) {
|
|
||||||
debuggerWriteHalfWord(address, value);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
void agbPrintReset()
|
|
||||||
{
|
|
||||||
agbPrintProtect = false;
|
|
||||||
}
|
|
||||||
|
|
||||||
void agbPrintEnable(bool enable)
|
|
||||||
{
|
|
||||||
agbPrintEnabled = enable;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool agbPrintIsEnabled()
|
|
||||||
{
|
|
||||||
return agbPrintEnabled;
|
|
||||||
}
|
|
||||||
|
|
||||||
extern void (*dbgOutput)(const char *, u32);
|
|
||||||
|
|
||||||
void agbPrintFlush()
|
|
||||||
{
|
|
||||||
u16 get = debuggerReadHalfWord(0x9fe20fc);
|
|
||||||
u16 put = debuggerReadHalfWord(0x9fe20fe);
|
|
||||||
|
|
||||||
u32 address = (debuggerReadHalfWord(0x9fe20fa) << 16);
|
|
||||||
if(address != 0xfd0000 && address != 0x1fd0000) {
|
|
||||||
dbgOutput("Did you forget to call AGBPrintInit?\n", 0);
|
|
||||||
// get rid of the text otherwise we will continue to be called
|
|
||||||
debuggerWriteHalfWord(0x9fe20fc, put);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
u8 *data = &rom[address];
|
|
||||||
|
|
||||||
while(get != put) {
|
|
||||||
char c = data[get++];
|
|
||||||
char s[2];
|
|
||||||
s[0] = c;
|
|
||||||
s[1] = 0;
|
|
||||||
|
|
||||||
if(systemVerbose & VERBOSE_AGBPRINT)
|
|
||||||
dbgOutput(s, 0);
|
|
||||||
if(c == '\n')
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
debuggerWriteHalfWord(0x9fe20fc, get);
|
|
||||||
}
|
|
|
@ -1,27 +0,0 @@
|
||||||
// -*- C++ -*-
|
|
||||||
// VisualBoyAdvance - Nintendo Gameboy/GameboyAdvance (TM) emulator.
|
|
||||||
// Copyright (C) 1999-2003 Forgotten
|
|
||||||
// Copyright (C) 2004 Forgotten and the VBA development team
|
|
||||||
|
|
||||||
// This program is free software; you can redistribute it and/or modify
|
|
||||||
// it under the terms of the GNU General Public License as published by
|
|
||||||
// the Free Software Foundation; either version 2, or(at your option)
|
|
||||||
// any later version.
|
|
||||||
//
|
|
||||||
// This program is distributed in the hope that it will be useful,
|
|
||||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
||||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
||||||
// GNU General Public License for more details.
|
|
||||||
//
|
|
||||||
// You should have received a copy of the GNU General Public License
|
|
||||||
// along with this program; if not, write to the Free Software Foundation,
|
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
||||||
|
|
||||||
#ifndef VBA_AGBPRINT_H
|
|
||||||
#define VBA_AGBPRINT_H
|
|
||||||
extern void agbPrintEnable(bool);
|
|
||||||
extern bool agbPrintIsEnabled();
|
|
||||||
extern void agbPrintReset();
|
|
||||||
extern bool agbPrintWrite(u32, u16);
|
|
||||||
extern void agbPrintFlush();
|
|
||||||
#endif
|
|
|
@ -23,7 +23,7 @@
|
||||||
|
|
||||||
#include "System.h"
|
#include "System.h"
|
||||||
#include "Port.h"
|
#include "Port.h"
|
||||||
#include "GBA.h"
|
#include "agb/GBA.h"
|
||||||
#include "armdis.h"
|
#include "armdis.h"
|
||||||
#include "elf.h"
|
#include "elf.h"
|
||||||
|
|
||||||
|
|
|
@ -20,9 +20,9 @@
|
||||||
#include <memory.h>
|
#include <memory.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
#include "GBA.h"
|
#include "agb/GBA.h"
|
||||||
#include "bios.h"
|
#include "bios.h"
|
||||||
#include "GBAinline.h"
|
#include "agb/GBAinline.h"
|
||||||
#include "Globals.h"
|
#include "Globals.h"
|
||||||
|
|
||||||
s16 sineTable[256] = {
|
s16 sineTable[256] = {
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
|
|
||||||
#include <memory.h>
|
#include <memory.h>
|
||||||
|
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "gbGlobals.h"
|
#include "gbGlobals.h"
|
||||||
#include "gbSGB.h"
|
#include "gbSGB.h"
|
||||||
|
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
// along with this program; if not, write to the Free Software Foundation,
|
// along with this program; if not, write to the Free Software Foundation,
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
|
|
||||||
u8 *gbMemoryMap[16];
|
u8 *gbMemoryMap[16];
|
||||||
|
|
||||||
|
|
|
@ -16,7 +16,7 @@
|
||||||
// along with this program; if not, write to the Free Software Foundation,
|
// along with this program; if not, write to the Free Software Foundation,
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "../Port.h"
|
#include "../Port.h"
|
||||||
#include "gbGlobals.h"
|
#include "gbGlobals.h"
|
||||||
#include "gbMemory.h"
|
#include "gbMemory.h"
|
||||||
|
|
|
@ -18,7 +18,7 @@
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <memory.h>
|
#include <memory.h>
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
|
|
||||||
u8 gbPrinterStatus = 0;
|
u8 gbPrinterStatus = 0;
|
||||||
int gbPrinterState = 0;
|
int gbPrinterState = 0;
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include "GBA.h"
|
#include "agb/GBA.h"
|
||||||
#include "Port.h"
|
#include "Port.h"
|
||||||
#include "elf.h"
|
#include "elf.h"
|
||||||
#include "NLS.h"
|
#include "NLS.h"
|
||||||
|
|
|
@ -20,7 +20,7 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
#include "GBA.h"
|
#include "agb/GBA.h"
|
||||||
#include "Port.h"
|
#include "Port.h"
|
||||||
#include "elf.h"
|
#include "elf.h"
|
||||||
#include "exprNode.h"
|
#include "exprNode.h"
|
||||||
|
|
|
@ -1,227 +0,0 @@
|
||||||
#include "gbafilter.h"
|
|
||||||
|
|
||||||
#include <math.h>
|
|
||||||
|
|
||||||
extern int systemColorDepth;
|
|
||||||
extern int systemRedShift;
|
|
||||||
extern int systemGreenShift;
|
|
||||||
extern int systemBlueShift;
|
|
||||||
|
|
||||||
extern u16 systemColorMap16[0x10000];
|
|
||||||
extern u32 systemColorMap32[0x10000];
|
|
||||||
|
|
||||||
static const unsigned char curve[32] = { 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0e, 0x10, 0x12,
|
|
||||||
0x14, 0x16, 0x18, 0x1c, 0x20, 0x28, 0x30, 0x38,
|
|
||||||
0x40, 0x48, 0x50, 0x58, 0x60, 0x68, 0x70, 0x80,
|
|
||||||
0x88, 0x90, 0xa0, 0xb0, 0xc0, 0xd0, 0xe0, 0xf0};
|
|
||||||
|
|
||||||
// output R G B
|
|
||||||
static const unsigned char influence[3 * 3] = { 16, 4, 4, // red
|
|
||||||
8, 16, 8, // green
|
|
||||||
0, 8, 16};// blue
|
|
||||||
|
|
||||||
inline void swap(short & a, short & b)
|
|
||||||
{
|
|
||||||
short temp = a;
|
|
||||||
a = b;
|
|
||||||
b = temp;
|
|
||||||
}
|
|
||||||
|
|
||||||
void gbafilter_pal(u16 * buf, int count)
|
|
||||||
{
|
|
||||||
short temp[3 * 3], s;
|
|
||||||
unsigned pix;
|
|
||||||
u8 red, green, blue;
|
|
||||||
|
|
||||||
while (count--)
|
|
||||||
{
|
|
||||||
pix = *buf;
|
|
||||||
|
|
||||||
s = curve[(pix >> systemGreenShift) & 0x1f];
|
|
||||||
temp[3] = s * influence[3];
|
|
||||||
temp[4] = s * influence[4];
|
|
||||||
temp[5] = s * influence[5];
|
|
||||||
|
|
||||||
s = curve[(pix >> systemRedShift) & 0x1f];
|
|
||||||
temp[0] = s * influence[0];
|
|
||||||
temp[1] = s * influence[1];
|
|
||||||
temp[2] = s * influence[2];
|
|
||||||
|
|
||||||
s = curve[(pix >> systemBlueShift) & 0x1f];
|
|
||||||
temp[6] = s * influence[6];
|
|
||||||
temp[7] = s * influence[7];
|
|
||||||
temp[8] = s * influence[8];
|
|
||||||
|
|
||||||
if (temp[0] < temp[3]) swap(temp[0], temp[3]);
|
|
||||||
if (temp[0] < temp[6]) swap(temp[0], temp[6]);
|
|
||||||
if (temp[3] < temp[6]) swap(temp[3], temp[6]);
|
|
||||||
temp[3] <<= 1;
|
|
||||||
temp[0] <<= 2;
|
|
||||||
temp[0] += temp[3] + temp[6];
|
|
||||||
|
|
||||||
red = ((int(temp[0]) * 160) >> 17) + 4;
|
|
||||||
if (red > 31) red = 31;
|
|
||||||
|
|
||||||
if (temp[2] < temp[5]) swap(temp[2], temp[5]);
|
|
||||||
if (temp[2] < temp[8]) swap(temp[2], temp[8]);
|
|
||||||
if (temp[5] < temp[8]) swap(temp[5], temp[8]);
|
|
||||||
temp[5] <<= 1;
|
|
||||||
temp[2] <<= 2;
|
|
||||||
temp[2] += temp[5] + temp[8];
|
|
||||||
|
|
||||||
blue = ((int(temp[2]) * 160) >> 17) + 4;
|
|
||||||
if (blue > 31) blue = 31;
|
|
||||||
|
|
||||||
if (temp[1] < temp[4]) swap(temp[1], temp[4]);
|
|
||||||
if (temp[1] < temp[7]) swap(temp[1], temp[7]);
|
|
||||||
if (temp[4] < temp[7]) swap(temp[4], temp[7]);
|
|
||||||
temp[4] <<= 1;
|
|
||||||
temp[1] <<= 2;
|
|
||||||
temp[1] += temp[4] + temp[7];
|
|
||||||
|
|
||||||
green = ((int(temp[1]) * 160) >> 17) + 4;
|
|
||||||
if (green > 31) green = 31;
|
|
||||||
|
|
||||||
pix = red << systemRedShift;
|
|
||||||
pix += green << systemGreenShift;
|
|
||||||
pix += blue << systemBlueShift;
|
|
||||||
|
|
||||||
*buf++ = pix;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void gbafilter_pal32(u32 * buf, int count)
|
|
||||||
{
|
|
||||||
short temp[3 * 3], s;
|
|
||||||
unsigned pix;
|
|
||||||
u8 red, green, blue;
|
|
||||||
|
|
||||||
while (count--)
|
|
||||||
{
|
|
||||||
pix = *buf;
|
|
||||||
|
|
||||||
s = curve[(pix >> systemGreenShift) & 0x1f];
|
|
||||||
temp[3] = s * influence[3];
|
|
||||||
temp[4] = s * influence[4];
|
|
||||||
temp[5] = s * influence[5];
|
|
||||||
|
|
||||||
s = curve[(pix >> systemRedShift) & 0x1f];
|
|
||||||
temp[0] = s * influence[0];
|
|
||||||
temp[1] = s * influence[1];
|
|
||||||
temp[2] = s * influence[2];
|
|
||||||
|
|
||||||
s = curve[(pix >> systemBlueShift) & 0x1f];
|
|
||||||
temp[6] = s * influence[6];
|
|
||||||
temp[7] = s * influence[7];
|
|
||||||
temp[8] = s * influence[8];
|
|
||||||
|
|
||||||
if (temp[0] < temp[3]) swap(temp[0], temp[3]);
|
|
||||||
if (temp[0] < temp[6]) swap(temp[0], temp[6]);
|
|
||||||
if (temp[3] < temp[6]) swap(temp[3], temp[6]);
|
|
||||||
temp[3] <<= 1;
|
|
||||||
temp[0] <<= 2;
|
|
||||||
temp[0] += temp[3] + temp[6];
|
|
||||||
|
|
||||||
//red = ((int(temp[0]) * 160) >> 17) + 4;
|
|
||||||
red = ((int(temp[0]) * 160) >> 14) + 32;
|
|
||||||
|
|
||||||
if (temp[2] < temp[5]) swap(temp[2], temp[5]);
|
|
||||||
if (temp[2] < temp[8]) swap(temp[2], temp[8]);
|
|
||||||
if (temp[5] < temp[8]) swap(temp[5], temp[8]);
|
|
||||||
temp[5] <<= 1;
|
|
||||||
temp[2] <<= 2;
|
|
||||||
temp[2] += temp[5] + temp[8];
|
|
||||||
|
|
||||||
//blue = ((int(temp[2]) * 160) >> 17) + 4;
|
|
||||||
blue = ((int(temp[2]) * 160) >> 14) + 32;
|
|
||||||
|
|
||||||
if (temp[1] < temp[4]) swap(temp[1], temp[4]);
|
|
||||||
if (temp[1] < temp[7]) swap(temp[1], temp[7]);
|
|
||||||
if (temp[4] < temp[7]) swap(temp[4], temp[7]);
|
|
||||||
temp[4] <<= 1;
|
|
||||||
temp[1] <<= 2;
|
|
||||||
temp[1] += temp[4] + temp[7];
|
|
||||||
|
|
||||||
//green = ((int(temp[1]) * 160) >> 17) + 4;
|
|
||||||
green = ((int(temp[1]) * 160) >> 14) + 32;
|
|
||||||
|
|
||||||
//pix = red << redshift;
|
|
||||||
//pix += green << greenshift;
|
|
||||||
//pix += blue << blueshift;
|
|
||||||
|
|
||||||
pix = red << (systemRedShift - 3);
|
|
||||||
pix += green << (systemGreenShift - 3);
|
|
||||||
pix += blue << (systemBlueShift - 3);
|
|
||||||
|
|
||||||
*buf++ = pix;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// for palette mode to work with the three spoony filters in 32bpp depth
|
|
||||||
|
|
||||||
void gbafilter_pad(u8 * buf, int count)
|
|
||||||
{
|
|
||||||
union
|
|
||||||
{
|
|
||||||
struct
|
|
||||||
{
|
|
||||||
u8 r;
|
|
||||||
u8 g;
|
|
||||||
u8 b;
|
|
||||||
u8 a;
|
|
||||||
} part;
|
|
||||||
unsigned whole;
|
|
||||||
}
|
|
||||||
mask;
|
|
||||||
|
|
||||||
mask.whole = 0x1f << systemRedShift;
|
|
||||||
mask.whole += 0x1f << systemGreenShift;
|
|
||||||
mask.whole += 0x1f << systemBlueShift;
|
|
||||||
|
|
||||||
switch (systemColorDepth)
|
|
||||||
{
|
|
||||||
case 24:
|
|
||||||
while (count--)
|
|
||||||
{
|
|
||||||
*buf++ &= mask.part.r;
|
|
||||||
*buf++ &= mask.part.g;
|
|
||||||
*buf++ &= mask.part.b;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 32:
|
|
||||||
while (count--)
|
|
||||||
{
|
|
||||||
*((u32*)buf) &= mask.whole;
|
|
||||||
buf += 4;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
void UpdateSystemColorMaps(int lcd)
|
|
||||||
{
|
|
||||||
switch(systemColorDepth) {
|
|
||||||
case 16:
|
|
||||||
{
|
|
||||||
for(int i = 0; i < 0x10000; i++) {
|
|
||||||
systemColorMap16[i] = ((i & 0x1f) << systemRedShift) |
|
|
||||||
(((i & 0x3e0) >> 5) << systemGreenShift) |
|
|
||||||
(((i & 0x7c00) >> 10) << systemBlueShift);
|
|
||||||
}
|
|
||||||
if (lcd == 1) gbafilter_pal(systemColorMap16, 0x10000);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 24:
|
|
||||||
case 32:
|
|
||||||
{
|
|
||||||
for(int i = 0; i < 0x10000; i++) {
|
|
||||||
systemColorMap32[i] = ((i & 0x1f) << systemRedShift) |
|
|
||||||
(((i & 0x3e0) >> 5) << systemGreenShift) |
|
|
||||||
(((i & 0x7c00) >> 10) << systemBlueShift);
|
|
||||||
}
|
|
||||||
if (lcd == 1) gbafilter_pal32(systemColorMap32, 0x10000);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
|
@ -1,5 +0,0 @@
|
||||||
#include "System.h"
|
|
||||||
|
|
||||||
void gbafilter_pal(u16 * buf, int count);
|
|
||||||
void gbafilter_pal32(u32 * buf, int count);
|
|
||||||
void gbafilter_pad(u8 * buf, int count);
|
|
|
@ -42,7 +42,7 @@
|
||||||
# define write _write
|
# define write _write
|
||||||
#endif // _WIN32
|
#endif // _WIN32
|
||||||
|
|
||||||
#include "GBA.h"
|
#include "agb/GBA.h"
|
||||||
|
|
||||||
extern bool debugger;
|
extern bool debugger;
|
||||||
extern void CPUUpdateCPSR();
|
extern void CPUUpdateCPSR();
|
||||||
|
|
|
@ -23,15 +23,15 @@
|
||||||
#include "vba.h"
|
#include "vba.h"
|
||||||
#include "BugReport.h"
|
#include "BugReport.h"
|
||||||
|
|
||||||
#include "../agbprint.h"
|
#include "../agb/agbprint.h"
|
||||||
#include "../AutoBuild.h"
|
#include "../AutoBuild.h"
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "../Globals.h"
|
#include "../Globals.h"
|
||||||
#include "../Port.h"
|
#include "../Port.h"
|
||||||
#include "../RTC.h"
|
#include "../RTC.h"
|
||||||
#include "../Sound.h"
|
#include "../Sound.h"
|
||||||
#include "../gb/gbCheats.h"
|
#include "../dmg/gbCheats.h"
|
||||||
#include "../gb/gbGlobals.h"
|
#include "../dmg/gbGlobals.h"
|
||||||
|
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
#define new DEBUG_NEW
|
#define new DEBUG_NEW
|
||||||
|
|
|
@ -32,10 +32,10 @@
|
||||||
#include "FullscreenSettings.h"
|
#include "FullscreenSettings.h"
|
||||||
|
|
||||||
#include "../System.h"
|
#include "../System.h"
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "../Globals.h"
|
#include "../Globals.h"
|
||||||
#include "../Util.h"
|
#include "../Util.h"
|
||||||
#include "../gb/gbGlobals.h"
|
#include "../dmg/gbGlobals.h"
|
||||||
|
|
||||||
#include <memory.h>
|
#include <memory.h>
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,7 @@
|
||||||
|
|
||||||
// Internals
|
// Internals
|
||||||
#include "../System.h"
|
#include "../System.h"
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "../Globals.h"
|
#include "../Globals.h"
|
||||||
#include "../Sound.h"
|
#include "../Sound.h"
|
||||||
|
|
||||||
|
|
|
@ -25,7 +25,7 @@
|
||||||
|
|
||||||
#include "../System.h"
|
#include "../System.h"
|
||||||
#include "../armdis.h"
|
#include "../armdis.h"
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "../Globals.h"
|
#include "../Globals.h"
|
||||||
|
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
#include "vba.h"
|
#include "vba.h"
|
||||||
#include "ExportGSASnapshot.h"
|
#include "ExportGSASnapshot.h"
|
||||||
|
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "../NLS.h"
|
#include "../NLS.h"
|
||||||
|
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
|
|
|
@ -26,7 +26,7 @@
|
||||||
#include "../System.h"
|
#include "../System.h"
|
||||||
#include "../Cheats.h"
|
#include "../Cheats.h"
|
||||||
#include "../CheatSearch.h"
|
#include "../CheatSearch.h"
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "../Globals.h"
|
#include "../Globals.h"
|
||||||
|
|
||||||
#include "Reg.h"
|
#include "Reg.h"
|
||||||
|
|
|
@ -24,8 +24,8 @@
|
||||||
#include "GBDisassemble.h"
|
#include "GBDisassemble.h"
|
||||||
|
|
||||||
#include "../System.h"
|
#include "../System.h"
|
||||||
#include "../gb/GB.h"
|
#include "../dmg/GB.h"
|
||||||
#include "../gb/gbGlobals.h"
|
#include "../dmg/gbGlobals.h"
|
||||||
|
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
#define new DEBUG_NEW
|
#define new DEBUG_NEW
|
||||||
|
|
|
@ -29,7 +29,7 @@
|
||||||
#include "../System.h"
|
#include "../System.h"
|
||||||
#include "../NLS.h"
|
#include "../NLS.h"
|
||||||
#include "../Util.h"
|
#include "../Util.h"
|
||||||
#include "../gb/gbGlobals.h"
|
#include "../dmg/gbGlobals.h"
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#include <png.h>
|
#include <png.h>
|
||||||
|
|
|
@ -28,7 +28,7 @@
|
||||||
#include "WinResUtil.h"
|
#include "WinResUtil.h"
|
||||||
|
|
||||||
#include "../System.h"
|
#include "../System.h"
|
||||||
#include "../gb/gbGlobals.h"
|
#include "../dmg/gbGlobals.h"
|
||||||
|
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
#define new DEBUG_NEW
|
#define new DEBUG_NEW
|
||||||
|
|
|
@ -29,7 +29,7 @@
|
||||||
#include "../System.h"
|
#include "../System.h"
|
||||||
#include "../NLS.h"
|
#include "../NLS.h"
|
||||||
#include "../Util.h"
|
#include "../Util.h"
|
||||||
#include "../gb/gbGlobals.h"
|
#include "../dmg/gbGlobals.h"
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#include <png.h>
|
#include <png.h>
|
||||||
|
|
|
@ -26,7 +26,7 @@
|
||||||
#include "WinResUtil.h"
|
#include "WinResUtil.h"
|
||||||
|
|
||||||
#include "../System.h"
|
#include "../System.h"
|
||||||
#include "../gb/gbGlobals.h"
|
#include "../dmg/gbGlobals.h"
|
||||||
|
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
#define new DEBUG_NEW
|
#define new DEBUG_NEW
|
||||||
|
|
|
@ -29,7 +29,7 @@
|
||||||
#include "../System.h"
|
#include "../System.h"
|
||||||
#include "../NLS.h"
|
#include "../NLS.h"
|
||||||
#include "../Util.h"
|
#include "../Util.h"
|
||||||
#include "../gb/gbGlobals.h"
|
#include "../dmg/gbGlobals.h"
|
||||||
|
|
||||||
extern "C" {
|
extern "C" {
|
||||||
#include <png.h>
|
#include <png.h>
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
#include "vba.h"
|
#include "vba.h"
|
||||||
#include "GameOverrides.h"
|
#include "GameOverrides.h"
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
|
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
#define new DEBUG_NEW
|
#define new DEBUG_NEW
|
||||||
|
|
|
@ -24,9 +24,9 @@
|
||||||
#include "IOViewer.h"
|
#include "IOViewer.h"
|
||||||
|
|
||||||
#include "../System.h"
|
#include "../System.h"
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "../Globals.h"
|
#include "../Globals.h"
|
||||||
#include "../GBAinline.h"
|
#include "../agb/GBAinline.h"
|
||||||
#include "IOViewerRegs.h"
|
#include "IOViewerRegs.h"
|
||||||
|
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
|
|
|
@ -4,7 +4,7 @@
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
#include "vba.h"
|
#include "vba.h"
|
||||||
#include "LinkOptions.h"
|
#include "LinkOptions.h"
|
||||||
#include "../Link.h"
|
#include "../agb/GBALink.h"
|
||||||
|
|
||||||
extern int lspeed;
|
extern int lspeed;
|
||||||
extern lserver ls;
|
extern lserver ls;
|
||||||
|
|
|
@ -34,17 +34,17 @@
|
||||||
#include "../System.h"
|
#include "../System.h"
|
||||||
#include "../AutoBuild.h"
|
#include "../AutoBuild.h"
|
||||||
#include "../cheatSearch.h"
|
#include "../cheatSearch.h"
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "../Globals.h"
|
#include "../Globals.h"
|
||||||
#include "../Flash.h"
|
#include "../Flash.h"
|
||||||
#include "../Globals.h"
|
#include "../Globals.h"
|
||||||
#include "../gb/GB.h"
|
#include "../dmg/GB.h"
|
||||||
#include "../gb/gbCheats.h"
|
#include "../dmg/gbCheats.h"
|
||||||
#include "../gb/gbGlobals.h"
|
#include "../dmg/gbGlobals.h"
|
||||||
#include "../RTC.h"
|
#include "../RTC.h"
|
||||||
#include "../Sound.h"
|
#include "../Sound.h"
|
||||||
#include "../Util.h"
|
#include "../Util.h"
|
||||||
#include "../Link.h"
|
#include "../agb/GBALink.h"
|
||||||
|
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
#define new DEBUG_NEW
|
#define new DEBUG_NEW
|
||||||
|
|
|
@ -25,9 +25,9 @@
|
||||||
#include "Reg.h"
|
#include "Reg.h"
|
||||||
#include "WinResUtil.h"
|
#include "WinResUtil.h"
|
||||||
|
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "../Globals.h"
|
#include "../Globals.h"
|
||||||
#include "../gb/gbCheats.h"
|
#include "../dmg/gbCheats.h"
|
||||||
|
|
||||||
extern int emulating;
|
extern int emulating;
|
||||||
|
|
||||||
|
|
|
@ -29,13 +29,13 @@
|
||||||
#include "WinResUtil.h"
|
#include "WinResUtil.h"
|
||||||
#include "Logging.h"
|
#include "Logging.h"
|
||||||
|
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "../Globals.h"
|
#include "../Globals.h"
|
||||||
#include "../NLS.h"
|
#include "../NLS.h"
|
||||||
#include "../Sound.h"
|
#include "../Sound.h"
|
||||||
#include "../gb/GB.h"
|
#include "../dmg/GB.h"
|
||||||
#include "../gb/gbCheats.h"
|
#include "../dmg/gbCheats.h"
|
||||||
#include "../gb/gbGlobals.h"
|
#include "../dmg/gbGlobals.h"
|
||||||
|
|
||||||
extern int emulating;
|
extern int emulating;
|
||||||
|
|
||||||
|
|
|
@ -41,7 +41,7 @@
|
||||||
#include "WinResUtil.h"
|
#include "WinResUtil.h"
|
||||||
#include "Logging.h"
|
#include "Logging.h"
|
||||||
|
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "../Globals.h"
|
#include "../Globals.h"
|
||||||
#include "../Sound.h"
|
#include "../Sound.h"
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,7 @@
|
||||||
#include "WinResUtil.h"
|
#include "WinResUtil.h"
|
||||||
|
|
||||||
#include "../System.h"
|
#include "../System.h"
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "../Globals.h"
|
#include "../Globals.h"
|
||||||
#include "../NLS.h"
|
#include "../NLS.h"
|
||||||
#include "../Util.h"
|
#include "../Util.h"
|
||||||
|
|
|
@ -28,7 +28,7 @@
|
||||||
#include "WinResUtil.h"
|
#include "WinResUtil.h"
|
||||||
|
|
||||||
#include "../System.h"
|
#include "../System.h"
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "../Globals.h"
|
#include "../Globals.h"
|
||||||
|
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
|
|
|
@ -27,7 +27,7 @@
|
||||||
#include "WinResUtil.h"
|
#include "WinResUtil.h"
|
||||||
|
|
||||||
#include "../System.h"
|
#include "../System.h"
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "../Globals.h"
|
#include "../Globals.h"
|
||||||
#include "../NLS.h"
|
#include "../NLS.h"
|
||||||
#include "../Util.h"
|
#include "../Util.h"
|
||||||
|
|
|
@ -31,7 +31,7 @@
|
||||||
|
|
||||||
// Internals
|
// Internals
|
||||||
#include "../System.h"
|
#include "../System.h"
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "../Globals.h"
|
#include "../Globals.h"
|
||||||
#include "../Util.h"
|
#include "../Util.h"
|
||||||
#include "../dmg/gbGlobals.h"
|
#include "../dmg/gbGlobals.h"
|
||||||
|
|
|
@ -26,7 +26,7 @@
|
||||||
#include "WinResUtil.h"
|
#include "WinResUtil.h"
|
||||||
|
|
||||||
#include "../System.h"
|
#include "../System.h"
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "../Globals.h"
|
#include "../Globals.h"
|
||||||
|
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
|
|
|
@ -17,7 +17,7 @@
|
||||||
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
// Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
||||||
|
|
||||||
#include "stdafx.h"
|
#include "stdafx.h"
|
||||||
#include "..\Link.h"
|
#include "..\agb\GBALink.h"
|
||||||
|
|
||||||
static char buffer[2048];
|
static char buffer[2048];
|
||||||
static HKEY vbKey = NULL;
|
static HKEY vbKey = NULL;
|
||||||
|
|
|
@ -27,7 +27,7 @@
|
||||||
#include "WinResUtil.h"
|
#include "WinResUtil.h"
|
||||||
|
|
||||||
#include "../System.h"
|
#include "../System.h"
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "../Globals.h"
|
#include "../Globals.h"
|
||||||
#include "../NLS.h"
|
#include "../NLS.h"
|
||||||
#include "../Util.h"
|
#include "../Util.h"
|
||||||
|
|
|
@ -36,22 +36,22 @@
|
||||||
#include "rpi.h"
|
#include "rpi.h"
|
||||||
|
|
||||||
#include "../System.h"
|
#include "../System.h"
|
||||||
#include "../agbprint.h"
|
#include "../agb/agbprint.h"
|
||||||
#include "../cheatSearch.h"
|
#include "../cheatSearch.h"
|
||||||
#include "../GBA.h"
|
#include "../agb/GBA.h"
|
||||||
#include "../Globals.h"
|
#include "../Globals.h"
|
||||||
#include "../RTC.h"
|
#include "../RTC.h"
|
||||||
#include "../Sound.h"
|
#include "../Sound.h"
|
||||||
#include "../Util.h"
|
#include "../Util.h"
|
||||||
#include "../gb/gbGlobals.h"
|
#include "../dmg/gbGlobals.h"
|
||||||
#include "../gb/gbPrinter.h"
|
#include "../dmg/gbPrinter.h"
|
||||||
|
|
||||||
/* Link
|
/* Link
|
||||||
---------------------*/
|
---------------------*/
|
||||||
#include "../Link.h"
|
#include "../agb/GBALink.h"
|
||||||
/* ---------------- */
|
/* ---------------- */
|
||||||
|
|
||||||
#include "../gbafilter.h"
|
#include "../agb/gbafilter.h"
|
||||||
|
|
||||||
#ifdef SDL
|
#ifdef SDL
|
||||||
#pragma comment( lib, "SDL" )
|
#pragma comment( lib, "SDL" )
|
||||||
|
|
Loading…
Reference in New Issue