summaryrefslogtreecommitdiff
path: root/src/cpuaddr.h
diff options
context:
space:
mode:
authorToad King2012-06-14 03:21:06 -0400
committerToad King2012-06-14 03:21:06 -0400
commit6fb0c7a7a53e1eba7a0f5dc5b1ade312a0d76119 (patch)
tree885cf7f507139b795ba7b2a6fb829dc044da39dd /src/cpuaddr.h
downloadsnes9x2002-6fb0c7a7a53e1eba7a0f5dc5b1ade312a0d76119.tar.gz
snes9x2002-6fb0c7a7a53e1eba7a0f5dc5b1ade312a0d76119.tar.bz2
snes9x2002-6fb0c7a7a53e1eba7a0f5dc5b1ade312a0d76119.zip
initial pocketsnes commit
Diffstat (limited to 'src/cpuaddr.h')
-rw-r--r--src/cpuaddr.h325
1 files changed, 325 insertions, 0 deletions
diff --git a/src/cpuaddr.h b/src/cpuaddr.h
new file mode 100644
index 0000000..1fc5640
--- /dev/null
+++ b/src/cpuaddr.h
@@ -0,0 +1,325 @@
+/*
+ * 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.
+ */
+
+#ifdef CPUASM
+#define _CPUADDR_H_
+#endif
+
+#ifndef _CPUADDR_H_
+#define _CPUADDR_H_
+
+EXTERN_C long OpAddress;
+
+STATIC inline void Immediate8 ()
+{
+ OpAddress = ICPU.ShiftedPB + CPU.PC - CPU.PCBase;
+ CPU.PC++;
+}
+
+STATIC inline void Immediate16 ()
+{
+ OpAddress = ICPU.ShiftedPB + CPU.PC - CPU.PCBase;
+ CPU.PC += 2;
+}
+
+STATIC inline void Relative ()
+{
+ signed char s9xInt8 = *CPU.PC++;
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeed;
+#endif
+ OpAddress = ((int) (CPU.PC - CPU.PCBase) + s9xInt8) & 0xffff;
+}
+
+STATIC inline void RelativeLong ()
+{
+#ifdef FAST_LSB_WORD_ACCESS
+ OpAddress = *(uint16 *) CPU.PC;
+#else
+ OpAddress = *CPU.PC + (*(CPU.PC + 1) << 8);
+#endif
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeedx2 + ONE_CYCLE;
+#endif
+ CPU.PC += 2;
+ OpAddress += (CPU.PC - CPU.PCBase);
+ OpAddress &= 0xffff;
+}
+
+STATIC inline void AbsoluteIndexedIndirect ()
+{
+#ifdef FAST_LSB_WORD_ACCESS
+ OpAddress = (Registers.X.W + *(uint16 *) CPU.PC) & 0xffff;
+#else
+ OpAddress = (Registers.X.W + *CPU.PC + (*(CPU.PC + 1) << 8)) & 0xffff;
+#endif
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeedx2;
+#endif
+ CPU.PC += 2;
+ OpAddress = S9xGetWord (ICPU.ShiftedPB + OpAddress);
+}
+
+STATIC inline void AbsoluteIndirectLong ()
+{
+#ifdef FAST_LSB_WORD_ACCESS
+ OpAddress = *(uint16 *) CPU.PC;
+#else
+ OpAddress = *CPU.PC + (*(CPU.PC + 1) << 8);
+#endif
+
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeedx2;
+#endif
+ CPU.PC += 2;
+ OpAddress = S9xGetWord (OpAddress) | (S9xGetByte (OpAddress + 2) << 16);
+}
+
+STATIC inline void AbsoluteIndirect ()
+{
+#ifdef FAST_LSB_WORD_ACCESS
+ OpAddress = *(uint16 *) CPU.PC;
+#else
+ OpAddress = *CPU.PC + (*(CPU.PC + 1) << 8);
+#endif
+
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeedx2;
+#endif
+ CPU.PC += 2;
+ OpAddress = S9xGetWord (OpAddress) + ICPU.ShiftedPB;
+}
+
+STATIC inline void Absolute ()
+{
+#ifdef FAST_LSB_WORD_ACCESS
+ OpAddress = *(uint16 *) CPU.PC + ICPU.ShiftedDB;
+#else
+ OpAddress = *CPU.PC + (*(CPU.PC + 1) << 8) + ICPU.ShiftedDB;
+#endif
+ CPU.PC += 2;
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeedx2;
+#endif
+}
+
+STATIC inline void AbsoluteLong ()
+{
+#ifdef FAST_LSB_WORD_ACCESS
+ OpAddress = (*(uint32 *) CPU.PC) & 0xffffff;
+#else
+ OpAddress = *CPU.PC + (*(CPU.PC + 1) << 8) + (*(CPU.PC + 2) << 16);
+#endif
+ CPU.PC += 3;
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeedx2 + CPU.MemSpeed;
+#endif
+}
+
+STATIC inline void Direct( void)
+{
+ OpAddress = (*CPU.PC++ + Registers.D.W) & 0xffff;
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeed;
+#endif
+// if (Registers.DL != 0) CPU.Cycles += ONE_CYCLE;
+}
+
+STATIC inline void DirectIndirectIndexed ()
+{
+ OpAddress = (*CPU.PC++ + Registers.D.W) & 0xffff;
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeed;
+#endif
+
+ OpAddress = ICPU.ShiftedDB + S9xGetWord (OpAddress) + Registers.Y.W;
+
+// if (Registers.DL != 0) CPU.Cycles += ONE_CYCLE;
+ // XXX: always add one if STA
+ // XXX: else Add one cycle if crosses page boundary
+}
+
+STATIC inline void DirectIndirectIndexedLong ()
+{
+ OpAddress = (*CPU.PC++ + Registers.D.W) & 0xffff;
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeed;
+#endif
+
+ OpAddress = S9xGetWord (OpAddress) + (S9xGetByte (OpAddress + 2) << 16) +
+ Registers.Y.W;
+// if (Registers.DL != 0) CPU.Cycles += ONE_CYCLE;
+}
+
+STATIC inline void DirectIndexedIndirect( void)
+{
+ OpAddress = (*CPU.PC++ + Registers.D.W + Registers.X.W) & 0xffff;
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeed;
+#endif
+
+ OpAddress = S9xGetWord (OpAddress) + ICPU.ShiftedDB;
+
+#ifdef VAR_CYCLES
+// if (Registers.DL != 0)
+// CPU.Cycles += TWO_CYCLES;
+// else
+ CPU.Cycles += ONE_CYCLE;
+#endif
+}
+
+STATIC inline void DirectIndexedX ()
+{
+ OpAddress = (*CPU.PC++ + Registers.D.W + Registers.X.W) & 0xffff;
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeed;
+#endif
+
+#ifdef VAR_CYCLES
+// if (Registers.DL != 0)
+// CPU.Cycles += TWO_CYCLES;
+// else
+ CPU.Cycles += ONE_CYCLE;
+#endif
+}
+
+STATIC inline void DirectIndexedY ()
+{
+ OpAddress = (*CPU.PC++ + Registers.D.W + Registers.Y.W) & 0xffff;
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeed;
+#endif
+
+#ifdef VAR_CYCLES
+// if (Registers.DL != 0)
+// CPU.Cycles += TWO_CYCLES;
+// else
+ CPU.Cycles += ONE_CYCLE;
+#endif
+}
+
+STATIC inline void AbsoluteIndexedX ()
+{
+#ifdef FAST_LSB_WORD_ACCESS
+ OpAddress = ICPU.ShiftedDB + *(uint16 *) CPU.PC + Registers.X.W;
+#else
+ OpAddress = ICPU.ShiftedDB + *CPU.PC + (*(CPU.PC + 1) << 8) +
+ Registers.X.W;
+#endif
+ CPU.PC += 2;
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeedx2;
+#endif
+ // XXX: always add one cycle for ROL, LSR, etc
+ // XXX: else is cross page boundary add one cycle
+}
+
+STATIC inline void AbsoluteIndexedY ()
+{
+#ifdef FAST_LSB_WORD_ACCESS
+ OpAddress = ICPU.ShiftedDB + *(uint16 *) CPU.PC + Registers.Y.W;
+#else
+ OpAddress = ICPU.ShiftedDB + *CPU.PC + (*(CPU.PC + 1) << 8) +
+ Registers.Y.W;
+#endif
+ CPU.PC += 2;
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeedx2;
+#endif
+ // XXX: always add cycle for STA
+ // XXX: else is cross page boundary add one cycle
+}
+
+STATIC inline void AbsoluteLongIndexedX ()
+{
+#ifdef FAST_LSB_WORD_ACCESS
+ OpAddress = (*(uint32 *) CPU.PC + Registers.X.W) & 0xffffff;
+#else
+ OpAddress = (*CPU.PC + (*(CPU.PC + 1) << 8) + (*(CPU.PC + 2) << 16) + Registers.X.W) & 0xffffff;
+#endif
+ CPU.PC += 3;
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeedx2 + CPU.MemSpeed;
+#endif
+}
+
+STATIC inline void DirectIndirect ()
+{
+ OpAddress = (*CPU.PC++ + Registers.D.W) & 0xffff;
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeed;
+#endif
+ OpAddress = S9xGetWord (OpAddress) + ICPU.ShiftedDB;
+
+// if (Registers.DL != 0) CPU.Cycles += ONE_CYCLE;
+}
+
+STATIC inline void DirectIndirectLong ()
+{
+ OpAddress = (*CPU.PC++ + Registers.D.W) & 0xffff;
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeed;
+#endif
+ OpAddress = S9xGetWord (OpAddress) +
+ (S9xGetByte (OpAddress + 2) << 16);
+// if (Registers.DL != 0) CPU.Cycles += ONE_CYCLE;
+}
+
+STATIC inline void StackRelative ()
+{
+ OpAddress = (*CPU.PC++ + Registers.S.W) & 0xffff;
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeed;
+ CPU.Cycles += ONE_CYCLE;
+#endif
+}
+
+STATIC inline void StackRelativeIndirectIndexed ()
+{
+ OpAddress = (*CPU.PC++ + Registers.S.W) & 0xffff;
+#ifdef VAR_CYCLES
+ CPU.Cycles += CPU.MemSpeed;
+ CPU.Cycles += TWO_CYCLES;
+#endif
+ OpAddress = (S9xGetWord (OpAddress) + ICPU.ShiftedDB +
+ Registers.Y.W) & 0xffffff;
+}
+#endif