Merge newcore branch into master/trunk. Correct lots of warning. (now warning are threat as error by default)
Signed-off-by: Godzil <godzil@godzil.net>
This commit is contained in:
parent
211b1f86c8
commit
bc65a7a4f0
5
.gitignore
vendored
Normal file
5
.gitignore
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
#Temp files
|
||||||
|
/build*
|
||||||
|
|
||||||
|
*~
|
||||||
|
*.swp
|
||||||
@ -10,7 +10,7 @@
|
|||||||
# $Revision$
|
# $Revision$
|
||||||
|
|
||||||
|
|
||||||
cmake_minimum_required (VERSION 2.4)
|
cmake_minimum_required (VERSION 2.6)
|
||||||
project (TINES)
|
project (TINES)
|
||||||
|
|
||||||
add_subdirectory (src)
|
add_subdirectory (src)
|
||||||
|
|||||||
@ -38,6 +38,9 @@ endif (APPLE)
|
|||||||
# Link & Compile flags
|
# Link & Compile flags
|
||||||
##########################
|
##########################
|
||||||
|
|
||||||
|
set (CMAKE_C_FLAGS "-Wall -Wextra -Wno-unused-parameter -Werror ${PLATFORM_FLAGS}")
|
||||||
|
set (CMAKE_CXX_FLAGS "-Wall -Wextra -Wno-unused-parameter -Werror ${PLATFORM_FLAGS}")
|
||||||
|
|
||||||
add_definitions (-DNO_DECIMAL -DFAST_RDOP)
|
add_definitions (-DNO_DECIMAL -DFAST_RDOP)
|
||||||
|
|
||||||
SET ( CMAKE_EXE_LINKER_FLAGS "-mmacosx-version-min=10.4")
|
SET ( CMAKE_EXE_LINKER_FLAGS "-mmacosx-version-min=10.4")
|
||||||
@ -105,10 +108,10 @@ if (TARGET_TI68k)
|
|||||||
elseif (APPLE AND ${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
|
elseif (APPLE AND ${CMAKE_SYSTEM_NAME} MATCHES "Darwin")
|
||||||
add_subdirectory(os/macos)
|
add_subdirectory(os/macos)
|
||||||
elseif (UNIX)
|
elseif (UNIX)
|
||||||
add_subdirectory(os/win32)
|
add_subdirectory(os/unix)
|
||||||
else (TARGET_TI68k)
|
else (TARGET_TI68k)
|
||||||
#So we target UNIX like OS
|
#So we target UNIX like OS
|
||||||
add_subdirectory(os/unix)
|
add_subdirectory(os/win32)
|
||||||
endif (TARGET_TI68k)
|
endif (TARGET_TI68k)
|
||||||
|
|
||||||
|
|
||||||
@ -126,7 +129,7 @@ endif (USE_EFENCE)
|
|||||||
|
|
||||||
if (USE_ALLEGRO)
|
if (USE_ALLEGRO)
|
||||||
target_link_libraries(tines debug alld-main)
|
target_link_libraries(tines debug alld-main)
|
||||||
target_link_libraries(tines optimized alleg-main)
|
# target_link_libraries(tines)
|
||||||
if (APPLE)
|
if (APPLE)
|
||||||
find_library(COCOALIB Cocoa)
|
find_library(COCOALIB Cocoa)
|
||||||
target_link_libraries(tines ${COCOALIB})
|
target_link_libraries(tines ${COCOALIB})
|
||||||
|
|||||||
@ -9,4 +9,5 @@
|
|||||||
# $HeadURL$
|
# $HeadURL$
|
||||||
# $Revision$
|
# $Revision$
|
||||||
|
|
||||||
add_library(apu SndAlleg.c Sound.c)
|
add_library(apu SndUnixT.c Sound.c)
|
||||||
|
#add_library(apu SndAlleg.c Sound.c)
|
||||||
|
|||||||
@ -43,7 +43,7 @@ static int MasterSwitch = (1<<SND_CHANNELS)-1;
|
|||||||
static int LoopFreq = 25;
|
static int LoopFreq = 25;
|
||||||
static int NoiseGen = 1;
|
static int NoiseGen = 1;
|
||||||
static int Suspended = 0;
|
static int Suspended = 0;
|
||||||
|
static int SoundRun = 0;
|
||||||
static struct
|
static struct
|
||||||
{
|
{
|
||||||
int Type; /* Channel type (SND_*) */
|
int Type; /* Channel type (SND_*) */
|
||||||
@ -351,6 +351,7 @@ int InitSound(int Rate,int Verbose)
|
|||||||
pthread_detach(ThreadID);
|
pthread_detach(ThreadID);
|
||||||
|
|
||||||
/* Done */
|
/* Done */
|
||||||
|
SoundRun = 1;
|
||||||
if(Verbose) puts("OK");
|
if(Verbose) puts("OK");
|
||||||
return(SoundRate=Rate);
|
return(SoundRate=Rate);
|
||||||
}
|
}
|
||||||
@ -359,11 +360,14 @@ int InitSound(int Rate,int Verbose)
|
|||||||
/** Shut DSP down. **/
|
/** Shut DSP down. **/
|
||||||
/*************************************************************/
|
/*************************************************************/
|
||||||
void TrashSound(void)
|
void TrashSound(void)
|
||||||
|
{
|
||||||
|
if (SoundRun == 1)
|
||||||
{
|
{
|
||||||
StopSound();
|
StopSound();
|
||||||
console_printf(Console_Default, "%s: Kill thread...\n", __func__);
|
console_printf(Console_Default, "%s: Kill thread...\n", __func__);
|
||||||
if(ThreadID) pthread_cancel(ThreadID);
|
if(ThreadID) pthread_cancel(ThreadID);
|
||||||
|
}
|
||||||
|
SoundRun = 0;
|
||||||
SoundRate = 0;
|
SoundRate = 0;
|
||||||
ThreadID = 0;
|
ThreadID = 0;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -10,8 +10,6 @@
|
|||||||
/** commercially. Please, notify me, if you make any **/
|
/** commercially. Please, notify me, if you make any **/
|
||||||
/** changes to this file. **/
|
/** changes to this file. **/
|
||||||
/*************************************************************/
|
/*************************************************************/
|
||||||
#ifdef UNIX
|
|
||||||
|
|
||||||
#include "Sound.h"
|
#include "Sound.h"
|
||||||
|
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
@ -21,6 +19,8 @@
|
|||||||
#include <pthread.h>
|
#include <pthread.h>
|
||||||
#include <sys/ioctl.h>
|
#include <sys/ioctl.h>
|
||||||
|
|
||||||
|
#include <os_dependent.h>
|
||||||
|
|
||||||
#ifdef SUN_AUDIO
|
#ifdef SUN_AUDIO
|
||||||
|
|
||||||
#include <sys/audioio.h>
|
#include <sys/audioio.h>
|
||||||
@ -106,7 +106,7 @@ static struct
|
|||||||
int Count; /* Phase counter */
|
int Count; /* Phase counter */
|
||||||
} CH[SND_CHANNELS];
|
} CH[SND_CHANNELS];
|
||||||
|
|
||||||
static void UnixSetWave(int Channel,signed char *Data,int Length,int Rate);
|
static void UnixSetWave(int Channel, signed char *Data,int Length,int Freq);
|
||||||
static void UnixSetSound(int Channel,int NewType);
|
static void UnixSetSound(int Channel,int NewType);
|
||||||
static void UnixDrum(int Type,int Force);
|
static void UnixDrum(int Type,int Force);
|
||||||
static void UnixSetChannels(int Volume,int Switch);
|
static void UnixSetChannels(int Volume,int Switch);
|
||||||
@ -221,6 +221,9 @@ static void *DSPLoop(void *Arg)
|
|||||||
unsigned char Buf[SND_BUFSIZE];
|
unsigned char Buf[SND_BUFSIZE];
|
||||||
register int J,I,K,L,M,N,L1,L2,A1,A2,V;
|
register int J,I,K,L,M,N,L1,L2,A1,A2,V;
|
||||||
int FreqCount;
|
int FreqCount;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
L = N = A2 = 0;
|
||||||
|
|
||||||
for(J=0;J<SND_CHANNELS;J++)
|
for(J=0;J<SND_CHANNELS;J++)
|
||||||
{
|
{
|
||||||
@ -421,7 +424,7 @@ static void *DSPLoop(void *Arg)
|
|||||||
/* We'll block here until next DMA buffer becomes free. It happens
|
/* We'll block here until next DMA buffer becomes free. It happens
|
||||||
** once per (1<<SND_BITS)/SoundRate seconds.
|
** once per (1<<SND_BITS)/SoundRate seconds.
|
||||||
*/
|
*/
|
||||||
write(SoundFD,Buf,SND_BUFSIZE);
|
ret = write(SoundFD,Buf,SND_BUFSIZE);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -531,13 +534,13 @@ void UnixSetSound(int Channel,int NewType)
|
|||||||
/** waveform to be an instrument or set it to the waveform **/
|
/** waveform to be an instrument or set it to the waveform **/
|
||||||
/** own playback rate. **/
|
/** own playback rate. **/
|
||||||
/*************************************************************/
|
/*************************************************************/
|
||||||
void UnixSetWave(int Channel,signed char *Data,int Length,int Rate)
|
void UnixSetWave(int Channel, signed char *Data, int Length, int Freq)
|
||||||
{
|
{
|
||||||
if((Channel<0)||(Channel>=SND_CHANNELS)||(Length<=0)) return;
|
if((Channel<0)||(Channel>=SND_CHANNELS)||(Length<=0)) return;
|
||||||
|
|
||||||
CH[Channel].Type = SND_WAVE;
|
CH[Channel].Type = SND_WAVE;
|
||||||
CH[Channel].Length = Length;
|
CH[Channel].Length = Length;
|
||||||
CH[Channel].Rate = Rate;
|
CH[Channel].Rate = Freq;
|
||||||
CH[Channel].Pos = 0;
|
CH[Channel].Pos = 0;
|
||||||
CH[Channel].Count = 0;
|
CH[Channel].Count = 0;
|
||||||
CH[Channel].Data = Data;
|
CH[Channel].Data = Data;
|
||||||
@ -550,5 +553,3 @@ void UnixDrum(int Type,int Force)
|
|||||||
{
|
{
|
||||||
/* This function is currently empty */
|
/* This function is currently empty */
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif /* UNIX */
|
|
||||||
|
|||||||
@ -36,7 +36,7 @@ struct SndDriverStruct SndDriver =
|
|||||||
(void (*)(int,int))0,
|
(void (*)(int,int))0,
|
||||||
(void (*)(int,int))0,
|
(void (*)(int,int))0,
|
||||||
(void (*)(int,int,int))0,
|
(void (*)(int,int,int))0,
|
||||||
(void (*)(int,const signed char *,int,int))0,
|
(void (*)(int,signed char *,int,int))0,
|
||||||
(const signed char *(*)(int))0
|
(const signed char *(*)(int))0
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -167,7 +167,7 @@ void SetChannels(int Volume,int Switch)
|
|||||||
/** waveform to be an instrument or set it to the waveform **/
|
/** waveform to be an instrument or set it to the waveform **/
|
||||||
/** own playback rate. **/
|
/** own playback rate. **/
|
||||||
/*************************************************************/
|
/*************************************************************/
|
||||||
void SetWave(int Channel,const signed char *Data,int Length,int Rate)
|
void SetWave(int Channel,signed char *Data,int Length,int Rate)
|
||||||
{
|
{
|
||||||
if((Channel<0)||(Length<=0)) return;
|
if((Channel<0)||(Length<=0)) return;
|
||||||
|
|
||||||
|
|||||||
@ -12,9 +12,12 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* TODO: Add Inst/MemAccess breakpoints */
|
||||||
|
|
||||||
/* Depending on the OS, one of these provide the malloc function */
|
/* Depending on the OS, one of these provide the malloc function */
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
#include <stdint.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
#include <os_dependent.h>
|
#include <os_dependent.h>
|
||||||
@ -26,14 +29,68 @@
|
|||||||
//#define TRACE_INSTRUCTIONS
|
//#define TRACE_INSTRUCTIONS
|
||||||
|
|
||||||
#ifdef TRACE_INSTRUCTIONS
|
#ifdef TRACE_INSTRUCTIONS
|
||||||
#define TRACEi(trace) do { console_printf(Console_Debug, "$%04X - ", cpu->reg_PC - 1); console_printf_d trace ; console_printf(Console_Debug, "\n"); } while(0)
|
#define TRACEi(trace) do { console_printf(Console_Debug, ">> $%04X - ", cpu->reg_PC-1); console_printf_d trace ; console_printf(Console_Debug, "\n"); } while(0)
|
||||||
#define TRACEiE(trace) do { console_printf(Console_Debug, "$%04X - ", cpu->reg_PC - 1); console_printf_d trace ; console_printf(Console_Debug, "\n"); } while(0)
|
#define TRACEiE(trace) do { console_printf(Console_Debug, ">> $%04X - ", cpu->reg_PC-1); console_printf_d trace ; console_printf(Console_Debug, "\n"); } while(0)
|
||||||
#else
|
#else
|
||||||
#define TRACEi(trace) { }
|
#define TRACEi(trace) { }
|
||||||
//#define TRACEiE(trace) { }
|
//#define TRACEiE(trace) { }
|
||||||
#define TRACEiE(trace) do { console_printf(Console_Debug, "$%04X - ", cpu->reg_PC - 1); console_printf_d trace ; console_printf(Console_Debug, "\n"); } while(0)
|
#define TRACEiE(trace) do { console_printf(Console_Debug, ">> $%04X - ", cpu->reg_PC-1); console_printf_d trace ; console_printf(Console_Debug, "\n"); } while(0)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* IP_ == "Instruction Parameter"
|
||||||
|
* nP: No parameters
|
||||||
|
* iM: Immediate
|
||||||
|
* iX: Indirect by X
|
||||||
|
* iY: Indirect by Y
|
||||||
|
* zP: Zero Page
|
||||||
|
* zX: Zero Page Indexec by X
|
||||||
|
* zY: Zero Page Indexec by Y
|
||||||
|
* iD: Indirect Double
|
||||||
|
* aB: Absolute
|
||||||
|
* aX: Absolute by X
|
||||||
|
* aY: Absolute by Y
|
||||||
|
* rE: Relative
|
||||||
|
*/
|
||||||
|
#define IP_nP "N"
|
||||||
|
#define IP_iM "I"
|
||||||
|
#define IP_iX "X"
|
||||||
|
#define IP_iY "Y"
|
||||||
|
#define IP_zP "0"
|
||||||
|
#define IP_zX "z"
|
||||||
|
#define IP_zY "Z"
|
||||||
|
#define IP_iD "D"
|
||||||
|
#define IP_aB "A"
|
||||||
|
#define IP_aX "x"
|
||||||
|
#define IP_aY "y"
|
||||||
|
#define IP_rE "R"
|
||||||
|
|
||||||
|
#define IP_nPc 'N'
|
||||||
|
#define IP_iMc 'I'
|
||||||
|
#define IP_iXc 'X'
|
||||||
|
#define IP_iYc 'Y'
|
||||||
|
#define IP_zPc '0'
|
||||||
|
#define IP_zXc 'z'
|
||||||
|
#define IP_zYc 'Z'
|
||||||
|
#define IP_iDc 'D'
|
||||||
|
#define IP_aBc 'A'
|
||||||
|
#define IP_aXc 'x'
|
||||||
|
#define IP_aYc 'y'
|
||||||
|
#define IP_rEc 'R'
|
||||||
|
|
||||||
|
#define IPf_nP ""
|
||||||
|
#define IPf_iM " $%02X"
|
||||||
|
#define IPf_iX " ($%02X,X)"
|
||||||
|
#define IPf_iY " ($%02X),Y"
|
||||||
|
#define IPf_zP " $%02X"
|
||||||
|
#define IPf_zX " $%02X,X"
|
||||||
|
#define IPf_zY " $%02X,Y"
|
||||||
|
#define IPf_iD " ($%02X%02X)"
|
||||||
|
#define IPf_aB " $%02X%02X"
|
||||||
|
#define IPf_aX " $%02X%02X,X"
|
||||||
|
#define IPf_aY " $%02X%02X,Y"
|
||||||
|
#define IPf_rE " $%02X%02X"
|
||||||
|
|
||||||
#define _INTERNAL_QUICK6502_CORECPU_
|
#define _INTERNAL_QUICK6502_CORECPU_
|
||||||
#include "corecpu.h"
|
#include "corecpu.h"
|
||||||
|
|
||||||
@ -49,15 +106,15 @@
|
|||||||
#define MEMORY_READ_ZP() cpu->memory_page0_read(cpu->memory_opcode_read(cpu->reg_PC++))
|
#define MEMORY_READ_ZP() cpu->memory_page0_read(cpu->memory_opcode_read(cpu->reg_PC++))
|
||||||
|
|
||||||
#define MEMORY_READ_IX() cpu->memory_read( (cpu->memory_page0_read(cpu->memory_opcode_read(cpu->reg_PC ) + cpu->reg_X ) & 0xFF) |\
|
#define MEMORY_READ_IX() cpu->memory_read( (cpu->memory_page0_read(cpu->memory_opcode_read(cpu->reg_PC ) + cpu->reg_X ) & 0xFF) |\
|
||||||
(cpu->memory_page0_read(cpu->memory_opcode_read(cpu->reg_PC++) + cpu->reg_X + 1) << 8) )
|
(cpu->memory_page0_read(cpu->memory_opcode_read(cpu->reg_PC ) + cpu->reg_X + 1) << 8) ); cpu->reg_PC++
|
||||||
#define MEMORY_READ_IY() cpu->memory_read( ( cpu->memory_page0_read(cpu->memory_opcode_read(cpu->reg_PC ) ) |\
|
#define MEMORY_READ_IY() cpu->memory_read( ( cpu->memory_page0_read(cpu->memory_opcode_read(cpu->reg_PC ) ) |\
|
||||||
(cpu->memory_page0_read(cpu->memory_opcode_read(cpu->reg_PC++) + 1) << 8) ) + cpu->reg_Y )
|
(cpu->memory_page0_read(cpu->memory_opcode_read(cpu->reg_PC ) + 1) << 8) ) + cpu->reg_Y ); cpu->reg_PC++
|
||||||
|
|
||||||
#define MEMORY_READ_ZX() cpu->memory_page0_read( (cpu->memory_opcode_read(cpu->reg_PC++) + cpu->reg_X) )
|
#define MEMORY_READ_ZX() cpu->memory_page0_read( (cpu->memory_opcode_read(cpu->reg_PC++) + cpu->reg_X) )
|
||||||
#define MEMORY_READ_ZY() cpu->memory_page0_read( (cpu->memory_opcode_read(cpu->reg_PC++) + cpu->reg_Y) )
|
#define MEMORY_READ_ZY() cpu->memory_page0_read( (cpu->memory_opcode_read(cpu->reg_PC++) + cpu->reg_Y) )
|
||||||
|
|
||||||
#define MEMORY_READ_AB() cpu->memory_read( ((cpu->memory_opcode_read(cpu->reg_PC++) ) |\
|
#define MEMORY_READ_AB() cpu->memory_read( ((cpu->memory_opcode_read(cpu->reg_PC ) ) |\
|
||||||
(cpu->memory_opcode_read(cpu->reg_PC++) << 8) ))
|
(cpu->memory_opcode_read(cpu->reg_PC+1) << 8) )); cpu->reg_PC += 2
|
||||||
|
|
||||||
#define MEMORY_READ_AX() cpu->memory_read( ((op1 ) |\
|
#define MEMORY_READ_AX() cpu->memory_read( ((op1 ) |\
|
||||||
(op2 << 8) ) + cpu->reg_X)
|
(op2 << 8) ) + cpu->reg_X)
|
||||||
@ -68,26 +125,26 @@
|
|||||||
#define MEMORY_WRITE_ZP(val) cpu->memory_page0_write(cpu->memory_opcode_read(cpu->reg_PC++), val)
|
#define MEMORY_WRITE_ZP(val) cpu->memory_page0_write(cpu->memory_opcode_read(cpu->reg_PC++), val)
|
||||||
|
|
||||||
#define MEMORY_WRITE_IX(val) cpu->memory_write( (cpu->memory_page0_read(cpu->memory_opcode_read(cpu->reg_PC ) + cpu->reg_X ) & 0xFF) |\
|
#define MEMORY_WRITE_IX(val) cpu->memory_write( (cpu->memory_page0_read(cpu->memory_opcode_read(cpu->reg_PC ) + cpu->reg_X ) & 0xFF) |\
|
||||||
(cpu->memory_page0_read(cpu->memory_opcode_read(cpu->reg_PC++) + cpu->reg_X + 1) << 8) , val)
|
(cpu->memory_page0_read(cpu->memory_opcode_read(cpu->reg_PC ) + cpu->reg_X + 1) << 8) , val); cpu->reg_PC++
|
||||||
#define MEMORY_WRITE_IY(val) cpu->memory_write( ( cpu->memory_page0_read(cpu->memory_opcode_read(cpu->reg_PC ) ) |\
|
#define MEMORY_WRITE_IY(val) cpu->memory_write( ( cpu->memory_page0_read(cpu->memory_opcode_read(cpu->reg_PC ) ) |\
|
||||||
(cpu->memory_page0_read(cpu->memory_opcode_read(cpu->reg_PC++) + 1) << 8) ) + cpu->reg_Y , val)
|
(cpu->memory_page0_read(cpu->memory_opcode_read(cpu->reg_PC ) + 1) << 8) ) + cpu->reg_Y , val); cpu->reg_PC++
|
||||||
|
|
||||||
#define MEMORY_WRITE_ZX(val) cpu->memory_page0_write( (cpu->memory_opcode_read(cpu->reg_PC++) + cpu->reg_X), val)
|
#define MEMORY_WRITE_ZX(val) cpu->memory_page0_write( (cpu->memory_opcode_read(cpu->reg_PC++) + cpu->reg_X), val)
|
||||||
#define MEMORY_WRITE_ZY(val) cpu->memory_page0_write( (cpu->memory_opcode_read(cpu->reg_PC++) + cpu->reg_Y), val)
|
#define MEMORY_WRITE_ZY(val) cpu->memory_page0_write( (cpu->memory_opcode_read(cpu->reg_PC++) + cpu->reg_Y), val)
|
||||||
|
|
||||||
#define MEMORY_WRITE_AB(val) cpu->memory_write( ((cpu->memory_opcode_read(cpu->reg_PC++) ) |\
|
#define MEMORY_WRITE_AB(val) cpu->memory_write( ((cpu->memory_opcode_read(cpu->reg_PC ) ) |\
|
||||||
(cpu->memory_opcode_read(cpu->reg_PC++) << 8) ), val)
|
(cpu->memory_opcode_read(cpu->reg_PC+1) << 8) ), val); cpu->reg_PC += 2
|
||||||
|
|
||||||
#define MEMORY_WRITE_AX(val) cpu->memory_write( ((cpu->memory_opcode_read(cpu->reg_PC++) ) |\
|
#define MEMORY_WRITE_AX(val) cpu->memory_write( ((cpu->memory_opcode_read(cpu->reg_PC ) ) |\
|
||||||
(cpu->memory_opcode_read(cpu->reg_PC++) << 8) ) + cpu->reg_X, val)
|
(cpu->memory_opcode_read(cpu->reg_PC+1) << 8) ) + cpu->reg_X, val); cpu->reg_PC += 2
|
||||||
#define MEMORY_WRITE_AY(val) cpu->memory_write( ((cpu->memory_opcode_read(cpu->reg_PC++) ) |\
|
#define MEMORY_WRITE_AY(val) cpu->memory_write( ((cpu->memory_opcode_read(cpu->reg_PC ) ) |\
|
||||||
(cpu->memory_opcode_read(cpu->reg_PC++) << 8) ) + cpu->reg_Y, val)
|
(cpu->memory_opcode_read(cpu->reg_PC+1) << 8) ) + cpu->reg_Y, val); cpu->reg_PC += 2
|
||||||
|
|
||||||
|
|
||||||
#define PUSH_S(value) cpu->memory_stack_write(0x100 | (cpu->reg_S--), value)
|
#define PUSH_S(value) cpu->memory_stack_write(0x100 | (cpu->reg_S--), value)
|
||||||
#define POP_S() (cpu->memory_stack_read (0x100 | (++cpu->reg_S) ))
|
#define POP_S() (cpu->memory_stack_read (0x100 | (++cpu->reg_S) ))
|
||||||
|
|
||||||
#ifdef NO_DECIMAL
|
#ifdef Q6502_NO_DECIMAL
|
||||||
|
|
||||||
#define ADC_OPERATION(read) do {\
|
#define ADC_OPERATION(read) do {\
|
||||||
unsigned short tmp = 0; unsigned char v = read; \
|
unsigned short tmp = 0; unsigned char v = read; \
|
||||||
@ -110,7 +167,7 @@
|
|||||||
} while(0)
|
} while(0)
|
||||||
|
|
||||||
#else
|
#else
|
||||||
#error Quick6502 doesn't actually support DECIMAL mode
|
#error Quick6502 doesn t actually support DECIMAL mode
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
@ -346,7 +403,7 @@ void quick6502_int(quick6502_cpu *cpu, quick6502_signal signal)
|
|||||||
PUSH_S((cpu->reg_PC >> 8) & 0xFF );
|
PUSH_S((cpu->reg_PC >> 8) & 0xFF );
|
||||||
PUSH_S((cpu->reg_PC ) & 0xFF );
|
PUSH_S((cpu->reg_PC ) & 0xFF );
|
||||||
PUSH_S( cpu->reg_P );
|
PUSH_S( cpu->reg_P );
|
||||||
cpu->reg_P = cpu->reg_P | Q6502_I_FLAG & ~Q6502_B_FLAG;
|
cpu->reg_P = (cpu->reg_P | Q6502_I_FLAG) & ~Q6502_B_FLAG;
|
||||||
|
|
||||||
cpu->reg_PC = (cpu->memory_read(Q6502_NMI_LOW)) | (cpu->memory_read(Q6502_NMI_HIGH)<<8);
|
cpu->reg_PC = (cpu->memory_read(Q6502_NMI_LOW)) | (cpu->memory_read(Q6502_NMI_HIGH)<<8);
|
||||||
|
|
||||||
@ -363,10 +420,10 @@ void quick6502_int(quick6502_cpu *cpu, quick6502_signal signal)
|
|||||||
void quick6502_dump(quick6502_cpu *cpu, FILE * fp)
|
void quick6502_dump(quick6502_cpu *cpu, FILE * fp)
|
||||||
{
|
{
|
||||||
short i;
|
short i;
|
||||||
char instr[20];
|
char instr[100];
|
||||||
/* Display registers */
|
/* Display registers */
|
||||||
fprintf(fp,
|
fprintf(fp,
|
||||||
"Quick6502: PC:$%04X A:$%02X X:$%02X Y:$%02X S:$%02X P:$%02X P:[%c%c%c%c%c%c%c%c]\n",
|
"## Quick6502: PC:$%04X A:$%02X X:$%02X Y:$%02X S:$%02X P:$%02X [%c%c%c%c%c%c%c%c]\n",
|
||||||
cpu->reg_PC, cpu->reg_A, cpu->reg_X, cpu->reg_Y, cpu->reg_S, cpu->reg_P,
|
cpu->reg_PC, cpu->reg_A, cpu->reg_X, cpu->reg_Y, cpu->reg_S, cpu->reg_P,
|
||||||
cpu->reg_P&Q6502_N_FLAG ? 'N':'.',
|
cpu->reg_P&Q6502_N_FLAG ? 'N':'.',
|
||||||
cpu->reg_P&Q6502_V_FLAG ? 'V':'.',
|
cpu->reg_P&Q6502_V_FLAG ? 'V':'.',
|
||||||
@ -379,28 +436,59 @@ void quick6502_dump(quick6502_cpu *cpu, FILE * fp)
|
|||||||
);
|
);
|
||||||
|
|
||||||
/* Display stack */
|
/* Display stack */
|
||||||
fprintf(fp, "Quick6502: Stack: [ ");
|
fprintf(fp, "## Quick6502: Stack: [ ");
|
||||||
for (i = cpu->reg_S+1; i < 0x100; i++)
|
for (i = cpu->reg_S+1; i < 0x100; i++)
|
||||||
{
|
{
|
||||||
fprintf(fp, "$%02X ", cpu->memory_opcode_read(0x100 | i));
|
fprintf(fp, "$%02X ", cpu->memory_read(0x100 | i));
|
||||||
}
|
}
|
||||||
fprintf(fp, "] Run:%c Cycle:%ld\n", cpu->running?'Y':'N', cpu->cycle_done);
|
fprintf(fp, "] Run:%c Cycle:%ld\n", cpu->running?'Y':'N', cpu->cycle_done);
|
||||||
|
|
||||||
quick6502_getinstruction(cpu, cpu->reg_PC, instr);
|
fprintf(fp, "## Quick6502: InstrMem: [ ");
|
||||||
fprintf(fp, "Quick6502: Instruction at PC: %s\n", instr);
|
for (i = 0; i < 0x5; i++)
|
||||||
|
{
|
||||||
|
fprintf(fp, "$%02X ", cpu->memory_opcode_read(cpu->reg_PC + i));
|
||||||
|
}
|
||||||
|
fprintf(fp, "]\n");
|
||||||
|
|
||||||
|
quick6502_getinstruction(cpu, (1==1), cpu->reg_PC, instr, NULL);
|
||||||
|
fprintf(fp, "## $%04X: %s\n", cpu->reg_PC, instr);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Get current instruction name at specified address and put it into buffer */
|
typedef enum InstructionNameTag
|
||||||
void quick6502_getinstruction(quick6502_cpu *cpu, unsigned short addr, char *buffer)
|
|
||||||
{
|
{
|
||||||
buffer[0] = 0;
|
n_ILG = 0, n_NOP,
|
||||||
}
|
n_CLI, n_SEI, n_CLC, n_SEC, n_CLD, n_SED, n_CLV,
|
||||||
|
n_LDA, n_LDX, n_LDY, n_STA, n_STX, n_STY,
|
||||||
|
n_TXA, n_TAX, n_TAY, n_TYA, n_TSX, n_TXS,
|
||||||
|
n_PHA, n_PLA, n_PHP, n_PLP,
|
||||||
|
n_DEX, n_DEY, n_INX, n_INY, n_DEC, n_INC,
|
||||||
|
n_JSR, n_RTS, n_JMP, n_BRK, n_RTI,
|
||||||
|
n_BCC, n_BCS, n_BEQ, n_BNE, n_BHI, n_BPL, n_BVS, n_BVC, n_BMI,
|
||||||
|
n_EOR, n_AND, n_BIT, n_ORA, n_ADC, n_SBC,
|
||||||
|
n_ROL, n_ROR, n_ASL, n_LSR,
|
||||||
|
n_CMP, n_CPX, n_CPY,
|
||||||
|
} InstructionNameTag;
|
||||||
|
|
||||||
|
char *InstructionName[] =
|
||||||
|
{
|
||||||
|
"ILLEGAL", "NOP",
|
||||||
|
"CLI", "SEI", "CLC", "SEC", "CLD", "SED", "CLV",
|
||||||
|
"LDA", "LDX", "LDY", "STA", "STX", "STY",
|
||||||
|
"TXA", "TAX", "TAY", "TYA", "TSX", "TXS",
|
||||||
|
"PHA", "PLA", "PHP", "PLP",
|
||||||
|
"DEX", "DEY", "INX", "INY", "DEC", "INC",
|
||||||
|
"JSR", "RTS", "JMP", "BRK", "RTI",
|
||||||
|
"BCC", "BCS", "BEQ", "BNE", "BHI", "BPL", "BVS", "BVC", "BVS",
|
||||||
|
"EOR", "AND", "BIT", "ORA", "ADC", "SBC",
|
||||||
|
"ROL", "ROR", "ASL", "LSR",
|
||||||
|
"CMP", "CPX", "CPY",
|
||||||
|
};
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Free the CPU
|
* Free the CPU
|
||||||
*
|
*
|
||||||
* This function will free the CPU only if it's not currently used, it will
|
* This function will free the CPU only if it's not currently used, it will
|
||||||
* return !0 if everything goes well and 0 if the free is impossible
|
* return 0 if everything goes well and !0 if the free is impossible
|
||||||
*/
|
*/
|
||||||
int quick6502_free(quick6502_cpu *cpu)
|
int quick6502_free(quick6502_cpu *cpu)
|
||||||
{
|
{
|
||||||
@ -447,52 +535,52 @@ INSTRUCTION(ILLEG)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** 58 : CLI - CLear Interrupt **/
|
/** 58 : CLI - CLear Interrupt **/
|
||||||
INSTRUCTION(CLIiM)
|
INSTRUCTION(CLInP)
|
||||||
{
|
{
|
||||||
TRACEi(("CLC"));
|
TRACEi(("CLI"));
|
||||||
cpu->reg_P &= ~Q6502_I_FLAG;
|
cpu->reg_P &= ~Q6502_I_FLAG;
|
||||||
}
|
}
|
||||||
/** 78 : SEI - SEt Interrupt **/
|
/** 78 : SEI - SEt Interrupt **/
|
||||||
INSTRUCTION(SEIiM)
|
INSTRUCTION(SEInP)
|
||||||
{
|
{
|
||||||
TRACEi(("SEI"));
|
TRACEi(("SEI"));
|
||||||
cpu->reg_P |= Q6502_I_FLAG;
|
cpu->reg_P |= Q6502_I_FLAG;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** 18 : CLC - CLear Carry **/
|
/** 18 : CLC - CLear Carry **/
|
||||||
INSTRUCTION(CLCiM)
|
INSTRUCTION(CLCnP)
|
||||||
{
|
{
|
||||||
TRACEi(("CLC"));
|
TRACEi(("CLC"));
|
||||||
cpu->reg_P &= ~Q6502_C_FLAG;
|
cpu->reg_P &= ~Q6502_C_FLAG;
|
||||||
}
|
}
|
||||||
/** 38 : SEC - SEt Carry **/
|
/** 38 : SEC - SEt Carry **/
|
||||||
INSTRUCTION(SECiM)
|
INSTRUCTION(SECnP)
|
||||||
{
|
{
|
||||||
TRACEi(("SEC"));
|
TRACEi(("SEC"));
|
||||||
cpu->reg_P |= Q6502_C_FLAG;
|
cpu->reg_P |= Q6502_C_FLAG;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** D8 : CLD - CLear Decimal **/
|
/** D8 : CLD - CLear Decimal **/
|
||||||
INSTRUCTION(CLDiM)
|
INSTRUCTION(CLDnP)
|
||||||
{
|
{
|
||||||
TRACEi(("CLD"));
|
TRACEi(("CLD"));
|
||||||
cpu->reg_P &= ~Q6502_D_FLAG;
|
cpu->reg_P &= ~Q6502_D_FLAG;
|
||||||
}
|
}
|
||||||
/** F8 : SED - SEt Decimal **/
|
/** F8 : SED - SEt Decimal **/
|
||||||
INSTRUCTION(SEDiM)
|
INSTRUCTION(SEDnP)
|
||||||
{
|
{
|
||||||
TRACEi(("SED"));
|
TRACEi(("SED"));
|
||||||
cpu->reg_P |= Q6502_D_FLAG;
|
cpu->reg_P |= Q6502_D_FLAG;
|
||||||
}
|
}
|
||||||
/** B8 : CLV - CLear oVerflo **/
|
/** B8 : CLV - CLear oVerflo **/
|
||||||
INSTRUCTION(CLViM)
|
INSTRUCTION(CLVnP)
|
||||||
{
|
{
|
||||||
TRACEi(("CLV"));
|
TRACEi(("CLV"));
|
||||||
cpu->reg_P &= ~Q6502_V_FLAG;
|
cpu->reg_P &= ~Q6502_V_FLAG;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** EA : NOP - NO oPeration **/
|
/** EA : NOP - NO oPeration **/
|
||||||
INSTRUCTION(NOPiM)
|
INSTRUCTION(NOPnP)
|
||||||
{
|
{
|
||||||
TRACEi(("NOP"));
|
TRACEi(("NOP"));
|
||||||
}
|
}
|
||||||
@ -752,7 +840,7 @@ INSTRUCTION(STYaB)
|
|||||||
/**** Register functions ****/
|
/**** Register functions ****/
|
||||||
|
|
||||||
/** AA : TAX - Transfer A to X **/
|
/** AA : TAX - Transfer A to X **/
|
||||||
INSTRUCTION(TAXiM)
|
INSTRUCTION(TAXnP)
|
||||||
{
|
{
|
||||||
TRACEi(("TAX"));
|
TRACEi(("TAX"));
|
||||||
cpu->reg_X = cpu->reg_A;
|
cpu->reg_X = cpu->reg_A;
|
||||||
@ -760,7 +848,7 @@ INSTRUCTION(TAXiM)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** 8A : TXA - Transfer X to A **/
|
/** 8A : TXA - Transfer X to A **/
|
||||||
INSTRUCTION(TXAiM)
|
INSTRUCTION(TXAnP)
|
||||||
{
|
{
|
||||||
TRACEi(("TXA"));
|
TRACEi(("TXA"));
|
||||||
cpu->reg_A = cpu->reg_X;
|
cpu->reg_A = cpu->reg_X;
|
||||||
@ -768,7 +856,7 @@ INSTRUCTION(TXAiM)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** A8 : TAY - Transfer A to Y **/
|
/** A8 : TAY - Transfer A to Y **/
|
||||||
INSTRUCTION(TAYiM)
|
INSTRUCTION(TAYnP)
|
||||||
{
|
{
|
||||||
TRACEi(("TAY"));
|
TRACEi(("TAY"));
|
||||||
cpu->reg_Y = cpu->reg_A;
|
cpu->reg_Y = cpu->reg_A;
|
||||||
@ -776,7 +864,7 @@ INSTRUCTION(TAYiM)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** 98 : TYA - Transfer Y to A **/
|
/** 98 : TYA - Transfer Y to A **/
|
||||||
INSTRUCTION(TYAiM)
|
INSTRUCTION(TYAnP)
|
||||||
{
|
{
|
||||||
TRACEi(("TYA"));
|
TRACEi(("TYA"));
|
||||||
cpu->reg_A = cpu->reg_Y;
|
cpu->reg_A = cpu->reg_Y;
|
||||||
@ -784,7 +872,7 @@ INSTRUCTION(TYAiM)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* BA : TSX - Transfer S to X **/
|
/* BA : TSX - Transfer S to X **/
|
||||||
INSTRUCTION(TSXiM)
|
INSTRUCTION(TSXnP)
|
||||||
{
|
{
|
||||||
TRACEi(("TSX"));
|
TRACEi(("TSX"));
|
||||||
cpu->reg_X = cpu->reg_S;
|
cpu->reg_X = cpu->reg_S;
|
||||||
@ -792,7 +880,7 @@ INSTRUCTION(TSXiM)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** 9A : TXS - Transfer X to S **/
|
/** 9A : TXS - Transfer X to S **/
|
||||||
INSTRUCTION(TXSiM)
|
INSTRUCTION(TXSnP)
|
||||||
{
|
{
|
||||||
TRACEi(("TXS"));
|
TRACEi(("TXS"));
|
||||||
cpu->reg_S = cpu->reg_X;
|
cpu->reg_S = cpu->reg_X;
|
||||||
@ -801,7 +889,7 @@ INSTRUCTION(TXSiM)
|
|||||||
/**** Simple register operation instructions ****/
|
/**** Simple register operation instructions ****/
|
||||||
|
|
||||||
/** CA : DEX - DEcrement X **/
|
/** CA : DEX - DEcrement X **/
|
||||||
INSTRUCTION(DEXiM)
|
INSTRUCTION(DEXnP)
|
||||||
{
|
{
|
||||||
TRACEi(("DEX"));
|
TRACEi(("DEX"));
|
||||||
cpu->reg_X --;
|
cpu->reg_X --;
|
||||||
@ -809,7 +897,7 @@ INSTRUCTION(DEXiM)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** 88 : DEY - DEcrement Y **/
|
/** 88 : DEY - DEcrement Y **/
|
||||||
INSTRUCTION(DEYiM)
|
INSTRUCTION(DEYnP)
|
||||||
{
|
{
|
||||||
TRACEi(("DEY"));
|
TRACEi(("DEY"));
|
||||||
cpu->reg_Y --;
|
cpu->reg_Y --;
|
||||||
@ -817,7 +905,7 @@ INSTRUCTION(DEYiM)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** E8 : INX - INcrement X **/
|
/** E8 : INX - INcrement X **/
|
||||||
INSTRUCTION(INXiM)
|
INSTRUCTION(INXnP)
|
||||||
{
|
{
|
||||||
TRACEi(("INX"));
|
TRACEi(("INX"));
|
||||||
cpu->reg_X ++;
|
cpu->reg_X ++;
|
||||||
@ -825,7 +913,7 @@ INSTRUCTION(INXiM)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** C8 : INY - INcrement Y **/
|
/** C8 : INY - INcrement Y **/
|
||||||
INSTRUCTION(INYiM)
|
INSTRUCTION(INYnP)
|
||||||
{
|
{
|
||||||
TRACEi(("INY"));
|
TRACEi(("INY"));
|
||||||
cpu->reg_Y ++;
|
cpu->reg_Y ++;
|
||||||
@ -835,14 +923,14 @@ INSTRUCTION(INYiM)
|
|||||||
/**** Stack related instructions ****/
|
/**** Stack related instructions ****/
|
||||||
|
|
||||||
/** 48 : PHA - PusH A */
|
/** 48 : PHA - PusH A */
|
||||||
INSTRUCTION(PHAiM)
|
INSTRUCTION(PHAnP)
|
||||||
{
|
{
|
||||||
TRACEi(("PHA"));
|
TRACEi(("PHA"));
|
||||||
PUSH_S(cpu->reg_A);
|
PUSH_S(cpu->reg_A);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** 68 : PLA - PuLl A */
|
/** 68 : PLA - PuLl A */
|
||||||
INSTRUCTION(PLAiM)
|
INSTRUCTION(PLAnP)
|
||||||
{
|
{
|
||||||
TRACEi(("PLA"));
|
TRACEi(("PLA"));
|
||||||
cpu->reg_A = POP_S();
|
cpu->reg_A = POP_S();
|
||||||
@ -850,14 +938,14 @@ INSTRUCTION(PLAiM)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** 08 : PHP - PusH P */
|
/** 08 : PHP - PusH P */
|
||||||
INSTRUCTION(PHPiM)
|
INSTRUCTION(PHPnP)
|
||||||
{
|
{
|
||||||
TRACEi(("PHP"));
|
TRACEi(("PHP"));
|
||||||
PUSH_S((cpu->reg_P | Q6502_R_FLAG | Q6502_B_FLAG));
|
PUSH_S((cpu->reg_P | Q6502_R_FLAG | Q6502_B_FLAG));
|
||||||
}
|
}
|
||||||
|
|
||||||
/** 28 : PLP - PuLl P */
|
/** 28 : PLP - PuLl P */
|
||||||
INSTRUCTION(PLPiM)
|
INSTRUCTION(PLPnP)
|
||||||
{
|
{
|
||||||
TRACEi(("PLP"));
|
TRACEi(("PLP"));
|
||||||
cpu->reg_P = POP_S() & ~(Q6502_R_FLAG | Q6502_B_FLAG);
|
cpu->reg_P = POP_S() & ~(Q6502_R_FLAG | Q6502_B_FLAG);
|
||||||
@ -880,10 +968,11 @@ INSTRUCTION(JSRaB)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** 60 : RTS - ReTurn from Subrutine */
|
/** 60 : RTS - ReTurn from Subrutine */
|
||||||
INSTRUCTION(RTSiM)
|
INSTRUCTION(RTSnP)
|
||||||
{
|
{
|
||||||
TRACEi(("RTS"));
|
TRACEi(("RTS"));
|
||||||
cpu->reg_PC = POP_S() | (POP_S() << 8);
|
cpu->reg_PC = POP_S();
|
||||||
|
cpu->reg_PC |= (POP_S() << 8);
|
||||||
cpu->reg_PC ++;
|
cpu->reg_PC ++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -891,7 +980,7 @@ INSTRUCTION(RTSiM)
|
|||||||
INSTRUCTION(JMPaB)
|
INSTRUCTION(JMPaB)
|
||||||
{
|
{
|
||||||
TRACEi(("JMP $%02X%02X", cpu->memory_opcode_read(cpu->reg_PC+1), cpu->memory_opcode_read(cpu->reg_PC)));
|
TRACEi(("JMP $%02X%02X", cpu->memory_opcode_read(cpu->reg_PC+1), cpu->memory_opcode_read(cpu->reg_PC)));
|
||||||
cpu->reg_PC = cpu->memory_opcode_read(cpu->reg_PC++) | (cpu->memory_opcode_read(cpu->reg_PC) << 8);
|
cpu->reg_PC = cpu->memory_opcode_read(cpu->reg_PC) | (cpu->memory_opcode_read(cpu->reg_PC+1) << 8);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** 6C : JMP ($xxxx) - JuMP inconditionaly to ($xxxx) **/
|
/** 6C : JMP ($xxxx) - JuMP inconditionaly to ($xxxx) **/
|
||||||
@ -904,7 +993,7 @@ INSTRUCTION(JMPiD)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** 00 : BRK - BReaK **/
|
/** 00 : BRK - BReaK **/
|
||||||
INSTRUCTION(BRKiM)
|
INSTRUCTION(BRKnP)
|
||||||
{
|
{
|
||||||
TRACEi(("BRK"));
|
TRACEi(("BRK"));
|
||||||
cpu->reg_PC++;
|
cpu->reg_PC++;
|
||||||
@ -917,11 +1006,12 @@ INSTRUCTION(BRKiM)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** 40 : RTI - ReTurn from Interruption **/
|
/** 40 : RTI - ReTurn from Interruption **/
|
||||||
INSTRUCTION(RTIiM)
|
INSTRUCTION(RTInP)
|
||||||
{
|
{
|
||||||
TRACEi(("RTI"));
|
TRACEi(("RTI"));
|
||||||
cpu->reg_P = POP_S();
|
cpu->reg_P = POP_S();
|
||||||
cpu->reg_PC = POP_S() | (POP_S() << 8);
|
cpu->reg_PC = POP_S();
|
||||||
|
cpu->reg_PC |= (POP_S() << 8);
|
||||||
|
|
||||||
if (cpu->int_pending != 0)
|
if (cpu->int_pending != 0)
|
||||||
{
|
{
|
||||||
@ -935,7 +1025,7 @@ INSTRUCTION(BCCrE)
|
|||||||
TRACEi(("BCC $%04X", cpu->reg_PC + (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1));
|
TRACEi(("BCC $%04X", cpu->reg_PC + (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1));
|
||||||
if (!(cpu->reg_P & Q6502_C_FLAG))
|
if (!(cpu->reg_P & Q6502_C_FLAG))
|
||||||
{
|
{
|
||||||
cpu->reg_PC += (signed char) cpu->memory_opcode_read(cpu->reg_PC++) + 1;
|
cpu->reg_PC += (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1;
|
||||||
/* Need to set timing */
|
/* Need to set timing */
|
||||||
|
|
||||||
/* +1 is same page */
|
/* +1 is same page */
|
||||||
@ -952,7 +1042,7 @@ INSTRUCTION(BCSrE)
|
|||||||
TRACEi(("BCS $%04X", cpu->reg_PC + (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1));
|
TRACEi(("BCS $%04X", cpu->reg_PC + (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1));
|
||||||
if (cpu->reg_P & Q6502_C_FLAG)
|
if (cpu->reg_P & Q6502_C_FLAG)
|
||||||
{
|
{
|
||||||
cpu->reg_PC += (signed char) cpu->memory_opcode_read(cpu->reg_PC ++) + 1;
|
cpu->reg_PC += (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1;
|
||||||
/* Need to set timing */
|
/* Need to set timing */
|
||||||
|
|
||||||
/* +1 is same page */
|
/* +1 is same page */
|
||||||
@ -969,7 +1059,7 @@ INSTRUCTION(BEQrE)
|
|||||||
TRACEi(("BEQ $%04X", cpu->reg_PC + (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1));
|
TRACEi(("BEQ $%04X", cpu->reg_PC + (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1));
|
||||||
if (cpu->reg_P & Q6502_Z_FLAG)
|
if (cpu->reg_P & Q6502_Z_FLAG)
|
||||||
{
|
{
|
||||||
cpu->reg_PC += (signed char) cpu->memory_opcode_read(cpu->reg_PC ++) + 1;
|
cpu->reg_PC += (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1;
|
||||||
/* Need to set timing */
|
/* Need to set timing */
|
||||||
|
|
||||||
/* +1 is same page */
|
/* +1 is same page */
|
||||||
@ -986,7 +1076,7 @@ INSTRUCTION(BMIrE)
|
|||||||
TRACEi(("BMI $%04X", cpu->reg_PC + (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1));
|
TRACEi(("BMI $%04X", cpu->reg_PC + (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1));
|
||||||
if (cpu->reg_P & Q6502_N_FLAG)
|
if (cpu->reg_P & Q6502_N_FLAG)
|
||||||
{
|
{
|
||||||
cpu->reg_PC += (signed char) cpu->memory_opcode_read(cpu->reg_PC ++) + 1;
|
cpu->reg_PC += (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1;
|
||||||
/* Need to set timing */
|
/* Need to set timing */
|
||||||
|
|
||||||
/* +1 is same page */
|
/* +1 is same page */
|
||||||
@ -1003,7 +1093,7 @@ INSTRUCTION(BNErE)
|
|||||||
TRACEi(("BNE $%04X", cpu->reg_PC + (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1));
|
TRACEi(("BNE $%04X", cpu->reg_PC + (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1));
|
||||||
if (!(cpu->reg_P & Q6502_Z_FLAG))
|
if (!(cpu->reg_P & Q6502_Z_FLAG))
|
||||||
{
|
{
|
||||||
cpu->reg_PC += (signed char) cpu->memory_opcode_read(cpu->reg_PC ++) + 1;
|
cpu->reg_PC += (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1;
|
||||||
/* Need to set timing */
|
/* Need to set timing */
|
||||||
|
|
||||||
/* +1 is same page */
|
/* +1 is same page */
|
||||||
@ -1020,7 +1110,7 @@ INSTRUCTION(BPLrE)
|
|||||||
TRACEi(("BPL $%04X", cpu->reg_PC + (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1));
|
TRACEi(("BPL $%04X", cpu->reg_PC + (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1));
|
||||||
if (!(cpu->reg_P & Q6502_N_FLAG))
|
if (!(cpu->reg_P & Q6502_N_FLAG))
|
||||||
{
|
{
|
||||||
cpu->reg_PC += (signed char) cpu->memory_opcode_read(cpu->reg_PC ++) + 1;
|
cpu->reg_PC += (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1;
|
||||||
/* Need to set timing */
|
/* Need to set timing */
|
||||||
|
|
||||||
/* +1 is same page */
|
/* +1 is same page */
|
||||||
@ -1037,7 +1127,7 @@ INSTRUCTION(BVCrE)
|
|||||||
TRACEi(("BVC $%04X", cpu->reg_PC + (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1));
|
TRACEi(("BVC $%04X", cpu->reg_PC + (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1));
|
||||||
if (!(cpu->reg_P & Q6502_V_FLAG))
|
if (!(cpu->reg_P & Q6502_V_FLAG))
|
||||||
{
|
{
|
||||||
cpu->reg_PC += (signed char) cpu->memory_opcode_read(cpu->reg_PC ++) + 1;
|
cpu->reg_PC += (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1;
|
||||||
/* Need to set timing */
|
/* Need to set timing */
|
||||||
|
|
||||||
/* +1 is same page */
|
/* +1 is same page */
|
||||||
@ -1054,7 +1144,7 @@ INSTRUCTION(BVSrE)
|
|||||||
TRACEi(("BVS $%04X", cpu->reg_PC + (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1));
|
TRACEi(("BVS $%04X", cpu->reg_PC + (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1));
|
||||||
if (cpu->reg_P & Q6502_V_FLAG)
|
if (cpu->reg_P & Q6502_V_FLAG)
|
||||||
{
|
{
|
||||||
cpu->reg_PC += (signed char) cpu->memory_opcode_read(cpu->reg_PC ++) + 1;
|
cpu->reg_PC += (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1;
|
||||||
/* Need to set timing */
|
/* Need to set timing */
|
||||||
|
|
||||||
/* +1 is same page */
|
/* +1 is same page */
|
||||||
@ -1515,28 +1605,28 @@ INSTRUCTION(BITaB)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/** 2A : ROL A **/
|
/** 2A : ROL A **/
|
||||||
INSTRUCTION(ROLiM)
|
INSTRUCTION(ROLnP)
|
||||||
{
|
{
|
||||||
TRACEi(("ROL A"));
|
TRACEi(("ROL A"));
|
||||||
ROL_OPERATION(cpu->reg_A);
|
ROL_OPERATION(cpu->reg_A);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** 6A : ROR A **/
|
/** 6A : ROR A **/
|
||||||
INSTRUCTION(RORiM)
|
INSTRUCTION(RORnP)
|
||||||
{
|
{
|
||||||
TRACEi(("ROR A"));
|
TRACEi(("ROR A"));
|
||||||
ROR_OPERATION(cpu->reg_A);
|
ROR_OPERATION(cpu->reg_A);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** 0A : ASL A **/
|
/** 0A : ASL A **/
|
||||||
INSTRUCTION(ASLiM)
|
INSTRUCTION(ASLnP)
|
||||||
{
|
{
|
||||||
TRACEi(("ASL A"));
|
TRACEi(("ASL A"));
|
||||||
ASL_OPERATION(cpu->reg_A);
|
ASL_OPERATION(cpu->reg_A);
|
||||||
}
|
}
|
||||||
|
|
||||||
/** 4A : LSR A **/
|
/** 4A : LSR A **/
|
||||||
INSTRUCTION(LSRiM)
|
INSTRUCTION(LSRnP)
|
||||||
{
|
{
|
||||||
TRACEi(("LSR A"));
|
TRACEi(("LSR A"));
|
||||||
LSR_OPERATION(cpu->reg_A);
|
LSR_OPERATION(cpu->reg_A);
|
||||||
@ -1800,34 +1890,346 @@ INSTRUCTION(INCzX)
|
|||||||
NZ_FLAG_UPDATE(val);
|
NZ_FLAG_UPDATE(val);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* */
|
/* iM: Immediate
|
||||||
|
* iX: Indirect by X
|
||||||
|
* iY: Indirect by Y
|
||||||
|
* zP: Zero Page
|
||||||
|
* zX: Zero Page Indexec by X
|
||||||
|
* zY: Zero Page Indexec by Y
|
||||||
|
* iD: Indirect Double
|
||||||
|
* aB: Absolute
|
||||||
|
* aX: Absolute by X
|
||||||
|
* aY: Absolute by Y
|
||||||
|
*/
|
||||||
static InstructionFunction InstructionTable[256] =
|
static InstructionFunction InstructionTable[256] =
|
||||||
{
|
{
|
||||||
/* 00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F */
|
/* 00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F */
|
||||||
/* 00 */ I_BRKiM, I_ORAiX, I_ILLEG, I_ILLEG, I_ILLEG, I_ORAzP, I_ASLzP, I_ILLEG, I_PHPiM, I_ORAiM, I_ASLiM, I_ILLEG, I_ILLEG, I_ORAaB, I_ASLaB, I_ILLEG,
|
/* 00 */ I_BRKnP, I_ORAiX, I_ILLEG, I_ILLEG, I_ILLEG, I_ORAzP, I_ASLzP, I_ILLEG, I_PHPnP, I_ORAiM, I_ASLnP, I_ILLEG, I_ILLEG, I_ORAaB, I_ASLaB, I_ILLEG,
|
||||||
/* 10 */ I_BPLrE, I_ORAiY, I_ILLEG, I_ILLEG, I_ILLEG, I_ORAzX, I_ASLzX, I_ILLEG, I_CLCiM, I_ORAaY, I_ILLEG, I_ILLEG, I_ILLEG, I_ORAaX, I_ASLaX, I_ILLEG,
|
/* 10 */ I_BPLrE, I_ORAiY, I_ILLEG, I_ILLEG, I_ILLEG, I_ORAzX, I_ASLzX, I_ILLEG, I_CLCnP, I_ORAaY, I_ILLEG, I_ILLEG, I_ILLEG, I_ORAaX, I_ASLaX, I_ILLEG,
|
||||||
/* 20 */ I_JSRaB, I_ANDiX, I_ILLEG, I_ILLEG, I_BITzP, I_ANDzP, I_ROLzP, I_ILLEG, I_PLPiM, I_ANDiM, I_ROLiM, I_ILLEG, I_BITaB, I_ANDaB, I_ROLaB, I_ILLEG,
|
/* 20 */ I_JSRaB, I_ANDiX, I_ILLEG, I_ILLEG, I_BITzP, I_ANDzP, I_ROLzP, I_ILLEG, I_PLPnP, I_ANDiM, I_ROLnP, I_ILLEG, I_BITaB, I_ANDaB, I_ROLaB, I_ILLEG,
|
||||||
/* 30 */ I_BMIrE, I_ANDiY, I_ILLEG, I_ILLEG, I_ILLEG, I_ANDzX, I_ROLzX, I_ILLEG, I_SECiM, I_ANDaY, I_ILLEG, I_ILLEG, I_ILLEG, I_ANDaX, I_ROLaX, I_ILLEG,
|
/* 30 */ I_BMIrE, I_ANDiY, I_ILLEG, I_ILLEG, I_ILLEG, I_ANDzX, I_ROLzX, I_ILLEG, I_SECnP, I_ANDaY, I_ILLEG, I_ILLEG, I_ILLEG, I_ANDaX, I_ROLaX, I_ILLEG,
|
||||||
/* 40 */ I_RTIiM, I_EORiX, I_ILLEG, I_ILLEG, I_ILLEG, I_EORzP, I_LSRzP, I_ILLEG, I_PHAiM, I_EORiM, I_LSRiM, I_ILLEG, I_JMPaB, I_EORaB, I_LSRaB, I_ILLEG,
|
/* 40 */ I_RTInP, I_EORiX, I_ILLEG, I_ILLEG, I_ILLEG, I_EORzP, I_LSRzP, I_ILLEG, I_PHAnP, I_EORiM, I_LSRnP, I_ILLEG, I_JMPaB, I_EORaB, I_LSRaB, I_ILLEG,
|
||||||
/* 50 */ I_BVCrE, I_EORiY, I_ILLEG, I_ILLEG, I_ILLEG, I_EORzX, I_LSRzX, I_ILLEG, I_CLIiM, I_EORaY, I_ILLEG, I_ILLEG, I_ILLEG, I_EORaX, I_LSRaX, I_ILLEG,
|
/* 50 */ I_BVCrE, I_EORiY, I_ILLEG, I_ILLEG, I_ILLEG, I_EORzX, I_LSRzX, I_ILLEG, I_CLInP, I_EORaY, I_ILLEG, I_ILLEG, I_ILLEG, I_EORaX, I_LSRaX, I_ILLEG,
|
||||||
/* 60 */ I_RTSiM, I_ADCiX, I_ILLEG, I_ILLEG, I_ILLEG, I_ADCzP, I_RORzP, I_ILLEG, I_PLAiM, I_ADCiM, I_RORiM, I_ILLEG, I_JMPiD, I_ADCaB, I_RORaB, I_ILLEG,
|
/* 60 */ I_RTSnP, I_ADCiX, I_ILLEG, I_ILLEG, I_ILLEG, I_ADCzP, I_RORzP, I_ILLEG, I_PLAnP, I_ADCiM, I_RORnP, I_ILLEG, I_JMPiD, I_ADCaB, I_RORaB, I_ILLEG,
|
||||||
/* 70 */ I_BVSrE, I_ADCiY, I_ILLEG, I_ILLEG, I_ILLEG, I_ADCzX, I_RORzX, I_ILLEG, I_SEIiM, I_ADCaY, I_ILLEG, I_ILLEG, I_ILLEG, I_ADCaX, I_RORaX, I_ILLEG,
|
/* 70 */ I_BVSrE, I_ADCiY, I_ILLEG, I_ILLEG, I_ILLEG, I_ADCzX, I_RORzX, I_ILLEG, I_SEInP, I_ADCaY, I_ILLEG, I_ILLEG, I_ILLEG, I_ADCaX, I_RORaX, I_ILLEG,
|
||||||
/* 80 */ I_ILLEG, I_STAiX, I_ILLEG, I_ILLEG, I_STYzP, I_STAzP, I_STXzP, I_ILLEG, I_DEYiM, I_ILLEG, I_TXAiM, I_ILLEG, I_STYaB, I_STAaB, I_STXaB, I_ILLEG,
|
/* 80 */ I_ILLEG, I_STAiX, I_ILLEG, I_ILLEG, I_STYzP, I_STAzP, I_STXzP, I_ILLEG, I_DEYnP, I_ILLEG, I_TXAnP, I_ILLEG, I_STYaB, I_STAaB, I_STXaB, I_ILLEG,
|
||||||
/* 90 */ I_BCCrE, I_STAiY, I_ILLEG, I_ILLEG, I_STYzX, I_STAzX, I_STXzY, I_ILLEG, I_TYAiM, I_STAaY, I_TXSiM, I_ILLEG, I_ILLEG, I_STAaX, I_ILLEG, I_ILLEG,
|
/* 90 */ I_BCCrE, I_STAiY, I_ILLEG, I_ILLEG, I_STYzX, I_STAzX, I_STXzY, I_ILLEG, I_TYAnP, I_STAaY, I_TXSnP, I_ILLEG, I_ILLEG, I_STAaX, I_ILLEG, I_ILLEG,
|
||||||
/* A0 */ I_LDYiM, I_LDAiX, I_LDXiM, I_ILLEG, I_LDYzP, I_LDAzP, I_LDXzP, I_ILLEG, I_TAYiM, I_LDAiM, I_TAXiM, I_ILLEG, I_LDYaB, I_LDAaB, I_LDXaB, I_ILLEG,
|
/* A0 */ I_LDYiM, I_LDAiX, I_LDXiM, I_ILLEG, I_LDYzP, I_LDAzP, I_LDXzP, I_ILLEG, I_TAYnP, I_LDAiM, I_TAXnP, I_ILLEG, I_LDYaB, I_LDAaB, I_LDXaB, I_ILLEG,
|
||||||
/* B0 */ I_BCSrE, I_LDAiY, I_ILLEG, I_ILLEG, I_LDYzX, I_LDAzX, I_LDXzY, I_ILLEG, I_CLViM, I_LDAaY, I_TSXiM, I_ILLEG, I_LDYaX, I_LDAaX, I_LDXaY, I_ILLEG,
|
/* B0 */ I_BCSrE, I_LDAiY, I_ILLEG, I_ILLEG, I_LDYzX, I_LDAzX, I_LDXzY, I_ILLEG, I_CLVnP, I_LDAaY, I_TSXnP, I_ILLEG, I_LDYaX, I_LDAaX, I_LDXaY, I_ILLEG,
|
||||||
/* C0 */ I_CPYiM, I_CMPiX, I_ILLEG, I_ILLEG, I_CPYzP, I_CMPzP, I_DECzP, I_ILLEG, I_INYiM, I_CMPiM, I_DEXiM, I_ILLEG, I_CPYaB, I_CMPaB, I_DECaB, I_ILLEG,
|
/* C0 */ I_CPYiM, I_CMPiX, I_ILLEG, I_ILLEG, I_CPYzP, I_CMPzP, I_DECzP, I_ILLEG, I_INYnP, I_CMPiM, I_DEXnP, I_ILLEG, I_CPYaB, I_CMPaB, I_DECaB, I_ILLEG,
|
||||||
/* D0 */ I_BNErE, I_CMPiY, I_ILLEG, I_ILLEG, I_ILLEG, I_CMPzX, I_DECzX, I_ILLEG, I_CLDiM, I_CMPaY, I_ILLEG, I_ILLEG, I_ILLEG, I_CMPaX, I_DECaX, I_ILLEG,
|
/* D0 */ I_BNErE, I_CMPiY, I_ILLEG, I_ILLEG, I_ILLEG, I_CMPzX, I_DECzX, I_ILLEG, I_CLDnP, I_CMPaY, I_ILLEG, I_ILLEG, I_ILLEG, I_CMPaX, I_DECaX, I_ILLEG,
|
||||||
/* E0 */ I_CPXiM, I_SBCiX, I_ILLEG, I_ILLEG, I_CPXzP, I_SBCzP, I_INCzP, I_ILLEG, I_INXiM, I_SBCiM, I_NOPiM, I_ILLEG, I_CPXaB, I_SBCaB, I_INCaB, I_ILLEG,
|
/* E0 */ I_CPXiM, I_SBCiX, I_ILLEG, I_ILLEG, I_CPXzP, I_SBCzP, I_INCzP, I_ILLEG, I_INXnP, I_SBCiM, I_NOPnP, I_ILLEG, I_CPXaB, I_SBCaB, I_INCaB, I_ILLEG,
|
||||||
/* F0 */ I_BEQrE, I_SBCiY, I_ILLEG, I_ILLEG, I_ILLEG, I_SBCzX, I_INCzX, I_ILLEG, I_SEDiM, I_SBCaY, I_ILLEG, I_ILLEG, I_ILLEG, I_SBCaX, I_INCaX, I_ILLEG
|
/* F0 */ I_BEQrE, I_SBCiY, I_ILLEG, I_ILLEG, I_ILLEG, I_SBCzX, I_INCzX, I_ILLEG, I_SEDnP, I_SBCaY, I_ILLEG, I_ILLEG, I_ILLEG, I_SBCaX, I_INCaX, I_ILLEG
|
||||||
/* 00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F */
|
/* 00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#ifdef MINE
|
||||||
|
|
||||||
|
typedef enum InstructionType
|
||||||
|
{
|
||||||
|
t_IMM = 0, t_IDX, t_IDY, t_ABS,
|
||||||
|
t_REL, t_ZEP, t_ZPX, t_ZPY,
|
||||||
|
t_ABX, t_ABY, t_IND, t_NOP,
|
||||||
|
} InstructionType;
|
||||||
|
|
||||||
|
static InstructionType InstructionTypeTable[256] =
|
||||||
|
{
|
||||||
|
/* 00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F */
|
||||||
|
/* 00 */ t_NOP, t_IDX, t_IMM, t_IMM, t_IMM, t_ZEP, t_ZEP, t_IMM, t_NOP, t_IMM, t_NOP, t_IMM, t_IMM, t_ABS, t_ABS, t_IMM,
|
||||||
|
/* 10 */ t_REL, t_IDY, t_IMM, t_IMM, t_IMM, t_ZPX, t_ZPX, t_IMM, t_NOP, t_ABY, t_IMM, t_IMM, t_IMM, t_ABX, t_ABX, t_IMM,
|
||||||
|
/* 20 */ t_ABS, t_IDX, t_IMM, t_IMM, t_ZEP, t_ZEP, t_ZEP, t_IMM, t_NOP, t_IMM, t_NOP, t_IMM, t_ABS, t_ABS, t_ABS, t_IMM,
|
||||||
|
/* 30 */ t_REL, t_IDY, t_IMM, t_IMM, t_IMM, t_ZPX, t_ZPX, t_IMM, t_NOP, t_ABY, t_IMM, t_IMM, t_IMM, t_ABX, t_ABX, t_IMM,
|
||||||
|
/* 40 */ t_NOP, t_IDX, t_IMM, t_IMM, t_IMM, t_ZEP, t_ZEP, t_IMM, t_NOP, t_IMM, t_NOP, t_IMM, t_ABS, t_ABS, t_ABS, t_IMM,
|
||||||
|
/* 50 */ t_REL, t_IDY, t_IMM, t_IMM, t_IMM, t_ZPX, t_ZPX, t_IMM, t_NOP, t_ABY, t_IMM, t_IMM, t_IMM, t_ABX, t_ABX, t_IMM,
|
||||||
|
/* 60 */ t_NOP, t_IDX, t_IMM, t_IMM, t_IMM, t_ZEP, t_ZEP, t_IMM, t_NOP, t_IMM, t_NOP, t_IMM, t_IND, t_ABS, t_ABS, t_IMM,
|
||||||
|
/* 70 */ t_REL, t_IDY, t_IMM, t_IMM, t_IMM, t_ZPX, t_ZPX, t_IMM, t_NOP, t_ABY, t_IMM, t_IMM, t_IMM, t_ABX, t_ABX, t_IMM,
|
||||||
|
/* 80 */ t_IMM, t_IDX, t_IMM, t_IMM, t_ZEP, t_ZEP, t_ZEP, t_IMM, t_NOP, t_IMM, t_NOP, t_IMM, t_ABS, t_ABS, t_ABS, t_IMM,
|
||||||
|
/* 90 */ t_REL, t_IDY, t_IMM, t_IMM, t_ZPX, t_ZPX, t_ZPY, t_IMM, t_NOP, t_ABY, t_NOP, t_IMM, t_IMM, t_ABX, t_IMM, t_IMM,
|
||||||
|
/* A0 */ t_IMM, t_IDX, t_IMM, t_IMM, t_ZEP, t_ZEP, t_ZEP, t_IMM, t_NOP, t_IMM, t_NOP, t_IMM, t_ABS, t_ABS, t_ABS, t_IMM,
|
||||||
|
/* B0 */ t_REL, t_IDY, t_IMM, t_IMM, t_ZPX, t_ZPX, t_ZPY, t_IMM, t_NOP, t_ABY, t_NOP, t_IMM, t_ABX, t_ABX, t_ABY, t_IMM,
|
||||||
|
/* C0 */ t_IMM, t_IDX, t_IMM, t_IMM, t_ZEP, t_ZEP, t_ZEP, t_IMM, t_NOP, t_IMM, t_NOP, t_IMM, t_ABS, t_ABS, t_ABS, t_IMM,
|
||||||
|
/* D0 */ t_REL, t_IDY, t_IMM, t_IMM, t_IMM, t_ZPX, t_ZPX, t_IMM, t_NOP, t_ABY, t_IMM, t_IMM, t_IMM, t_ABX, t_ABX, t_IMM,
|
||||||
|
/* E0 */ t_IMM, t_IDX, t_IMM, t_IMM, t_ZEP, t_ZEP, t_ZEP, t_IMM, t_NOP, t_IMM, t_IMM, t_IMM, t_ABS, t_ABS, t_ABS, t_IMM,
|
||||||
|
/* F0 */ t_REL, t_IDY, t_IMM, t_IMM, t_IMM, t_ZPX, t_ZPX, t_IMM, t_NOP, t_ABY, t_IMM, t_IMM, t_IMM, t_ABX, t_ABX, t_IMM
|
||||||
|
/* 00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F */
|
||||||
|
};
|
||||||
|
|
||||||
|
static InstructionNameTag InstructionNameTable[256] =
|
||||||
|
{
|
||||||
|
/* 00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F */
|
||||||
|
/* 00 */ n_BRK, n_ORA, n_ILG, n_ILG, n_ILG, n_ORA, n_ASL, n_ILG, n_PHP, n_ORA, n_ASL, n_ILG, n_ILG, n_ORA, n_ASL, n_ILG,
|
||||||
|
/* 10 */ n_BPL, n_ORA, n_ILG, n_ILG, n_ILG, n_ORA, n_ASL, n_ILG, n_CLC, n_ORA, n_ILG, n_ILG, n_ILG, n_ORA, n_ASL, n_ILG,
|
||||||
|
/* 20 */ n_JSR, n_AND, n_ILG, n_ILG, n_BIT, n_AND, n_ROL, n_ILG, n_PLP, n_AND, n_ROL, n_ILG, n_BIT, n_AND, n_ROL, n_ILG,
|
||||||
|
/* 30 */ n_BMI, n_AND, n_ILG, n_ILG, n_ILG, n_AND, n_ROL, n_ILG, n_SEC, n_AND, n_ILG, n_ILG, n_ILG, n_AND, n_ROL, n_ILG,
|
||||||
|
/* 40 */ n_RTI, n_EOR, n_ILG, n_ILG, n_ILG, n_EOR, n_LSR, n_ILG, n_PHA, n_EOR, n_LSR, n_ILG, n_JMP, n_EOR, n_LSR, n_ILG,
|
||||||
|
/* 50 */ n_BVC, n_EOR, n_ILG, n_ILG, n_ILG, n_EOR, n_LSR, n_ILG, n_CLI, n_EOR, n_ILG, n_ILG, n_ILG, n_EOR, n_LSR, n_ILG,
|
||||||
|
/* 60 */ n_RTS, n_ADC, n_ILG, n_ILG, n_ILG, n_ADC, n_ROR, n_ILG, n_PLA, n_ADC, n_ROR, n_ILG, n_JMP, n_ADC, n_ROR, n_ILG,
|
||||||
|
/* 70 */ n_BVS, n_ADC, n_ILG, n_ILG, n_ILG, n_ADC, n_ROR, n_ILG, n_SEI, n_ADC, n_ILG, n_ILG, n_ILG, n_ADC, n_ROR, n_ILG,
|
||||||
|
/* 80 */ n_ILG, n_STA, n_ILG, n_ILG, n_STY, n_STA, n_STX, n_ILG, n_DEY, n_ILG, n_TXA, n_ILG, n_STY, n_STA, n_STX, n_ILG,
|
||||||
|
/* 90 */ n_BCC, n_STA, n_ILG, n_ILG, n_STY, n_STA, n_STX, n_ILG, n_TYA, n_STA, n_TXS, n_ILG, n_ILG, n_STA, n_ILG, n_ILG,
|
||||||
|
/* A0 */ n_LDY, n_LDA, n_LDX, n_ILG, n_LDY, n_LDA, n_LDX, n_ILG, n_TAY, n_LDA, n_TAX, n_ILG, n_LDY, n_LDA, n_LDX, n_ILG,
|
||||||
|
/* B0 */ n_BCS, n_LDA, n_ILG, n_ILG, n_LDY, n_LDA, n_LDX, n_ILG, n_CLV, n_LDA, n_TSX, n_ILG, n_LDY, n_LDA, n_LDX, n_ILG,
|
||||||
|
/* C0 */ n_CPY, n_CMP, n_ILG, n_ILG, n_CPY, n_CMP, n_DEC, n_ILG, n_INY, n_CMP, n_DEX, n_ILG, n_CPY, n_CMP, n_DEC, n_ILG,
|
||||||
|
/* D0 */ n_BNE, n_CMP, n_ILG, n_ILG, n_ILG, n_CMP, n_DEC, n_ILG, n_CLD, n_CMP, n_ILG, n_ILG, n_ILG, n_CMP, n_DEC, n_ILG,
|
||||||
|
/* E0 */ n_CPX, n_SBC, n_ILG, n_ILG, n_CPX, n_SBC, n_INC, n_ILG, n_INX, n_SBC, n_NOP, n_ILG, n_CPX, n_SBC, n_INC, n_ILG,
|
||||||
|
/* F0 */ n_BEQ, n_SBC, n_ILG, n_ILG, n_ILG, n_SBC, n_INC, n_ILG, n_SED, n_SBC, n_ILG, n_ILG, n_ILG, n_SBC, n_INC, n_ILG,
|
||||||
|
/* 00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F */
|
||||||
|
};
|
||||||
|
|
||||||
|
/** Get current instruction name at specified address and put it into buffer */
|
||||||
|
int quick6502_getinstruction(quick6502_cpu *cpu, char interpret,
|
||||||
|
unsigned short addr, char *buffer, int *strlength)
|
||||||
|
{
|
||||||
|
int len = 0, curlen;
|
||||||
|
int readbyte = 1;
|
||||||
|
char *str = buffer;
|
||||||
|
|
||||||
|
uint8_t opcode = cpu->memory_opcode_read(addr);
|
||||||
|
|
||||||
|
uint8_t value_u8;
|
||||||
|
uint16_t value_u16;
|
||||||
|
|
||||||
|
curlen = sprintf(str, "%s", InstructionName[InstructionNameTable[opcode]]);
|
||||||
|
str += curlen; len += curlen;
|
||||||
|
|
||||||
|
switch(InstructionTypeTable[opcode])
|
||||||
|
{
|
||||||
|
default: /* Nothing to do */
|
||||||
|
case t_NOP:
|
||||||
|
break;
|
||||||
|
|
||||||
|
case t_IMM:
|
||||||
|
curlen = sprintf(str, " #$%02X", cpu->memory_opcode_read(addr + 1));
|
||||||
|
str += curlen; len += curlen;
|
||||||
|
|
||||||
|
/* Nothing to interpret.. Really */
|
||||||
|
|
||||||
|
readbyte += 2;
|
||||||
|
|
||||||
|
break;
|
||||||
|
|
||||||
|
case t_IDX:
|
||||||
|
curlen = sprintf(str, " ($%02X, X)", cpu->memory_opcode_read(addr + 1));
|
||||||
|
str += curlen; len += curlen;
|
||||||
|
|
||||||
|
if (interpret)
|
||||||
|
{
|
||||||
|
value_u8 = cpu->memory_opcode_read( addr + 1 );
|
||||||
|
value_u16 = value_u8 + cpu->reg_X;
|
||||||
|
|
||||||
|
curlen = sprintf(str, " ; ($%02X + $%02X) -> ($%02X) -> $%02X%02X",
|
||||||
|
value_u8, cpu->reg_X,
|
||||||
|
value_u16 & 0xFF,
|
||||||
|
cpu->memory_page0_read(value_u16),
|
||||||
|
cpu->memory_page0_read(value_u16 + 1));
|
||||||
|
str += curlen; len += curlen;
|
||||||
|
}
|
||||||
|
|
||||||
|
readbyte += 1;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case t_IDY:
|
||||||
|
curlen = sprintf(str, " ($%02X), Y", cpu->memory_opcode_read(addr + 1));
|
||||||
|
str += curlen; len += curlen;
|
||||||
|
|
||||||
|
if (interpret)
|
||||||
|
{
|
||||||
|
value_u8 = cpu->memory_opcode_read( addr + 1 );
|
||||||
|
value_u16 = (cpu->memory_page0_read(value_u8 + 1) << 8) |
|
||||||
|
(cpu->memory_page0_read(value_u8) );
|
||||||
|
|
||||||
|
curlen = sprintf(str, " ; ($%02X) + $%02X -> $%04X + $%02X -> $%04X",
|
||||||
|
value_u8, cpu->reg_Y,
|
||||||
|
value_u16, cpu->reg_Y,
|
||||||
|
value_u16 + cpu->reg_Y
|
||||||
|
);
|
||||||
|
str += curlen; len += curlen;
|
||||||
|
}
|
||||||
|
|
||||||
|
readbyte += 1;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case t_ABS:
|
||||||
|
curlen = sprintf(str, " $%02X%02X", cpu->memory_opcode_read(addr + 2),
|
||||||
|
cpu->memory_opcode_read(addr + 1));
|
||||||
|
str += curlen; len += curlen;
|
||||||
|
|
||||||
|
/* Nothing to interpret.. Really */
|
||||||
|
|
||||||
|
readbyte += 2;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case t_REL:
|
||||||
|
value_u16 = 2 + addr + (signed char) cpu->memory_opcode_read(addr + 1);
|
||||||
|
curlen = sprintf(str, " $%04X", value_u16);
|
||||||
|
str += curlen; len += curlen;
|
||||||
|
|
||||||
|
/* Nothing to interpret.. Really */
|
||||||
|
|
||||||
|
readbyte += 1;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case t_ZEP:
|
||||||
|
curlen = sprintf(str, " $%02X", cpu->memory_opcode_read(addr + 1));
|
||||||
|
str += curlen; len += curlen;
|
||||||
|
|
||||||
|
/* Nothing to interpret.. Really */
|
||||||
|
|
||||||
|
readbyte += 1;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case t_ZPX:
|
||||||
|
curlen = sprintf(str, " $%02X, X", cpu->memory_opcode_read(addr + 1));
|
||||||
|
str += curlen; len += curlen;
|
||||||
|
|
||||||
|
if (interpret)
|
||||||
|
{
|
||||||
|
curlen = sprintf(str, " ; $%02X + $%02x -> $%02X",
|
||||||
|
cpu->memory_opcode_read(addr + 1), cpu->reg_X,
|
||||||
|
(cpu->memory_opcode_read(addr + 1) + cpu->reg_X) & 0xFF);
|
||||||
|
str += curlen; len += curlen;
|
||||||
|
}
|
||||||
|
|
||||||
|
readbyte += 1;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case t_ZPY:
|
||||||
|
curlen = sprintf(str, " $%02X, Y", cpu->memory_opcode_read(addr + 1));
|
||||||
|
str += curlen; len += curlen;
|
||||||
|
|
||||||
|
if (interpret)
|
||||||
|
{
|
||||||
|
curlen = sprintf(str, " ; $%02X + $%02x -> $%02X",
|
||||||
|
cpu->memory_opcode_read(addr + 1), cpu->reg_Y,
|
||||||
|
(cpu->memory_opcode_read(addr + 1) + cpu->reg_Y) & 0xFF);
|
||||||
|
str += curlen; len += curlen;
|
||||||
|
}
|
||||||
|
|
||||||
|
readbyte += 1;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case t_ABX:
|
||||||
|
curlen = sprintf(str, " $%02X%02X, X", cpu->memory_opcode_read(addr + 2),
|
||||||
|
cpu->memory_opcode_read(addr + 1));
|
||||||
|
str += curlen; len += curlen;
|
||||||
|
|
||||||
|
if (interpret)
|
||||||
|
{
|
||||||
|
value_u16 = (cpu->memory_opcode_read(addr + 2) << 8) |
|
||||||
|
cpu->memory_opcode_read(addr + 1);
|
||||||
|
curlen = sprintf(str, " ; $%04X + $%02X -> $%04X", value_u16,
|
||||||
|
cpu->reg_X, value_u16 + cpu->reg_X);
|
||||||
|
str += curlen; len += curlen;
|
||||||
|
}
|
||||||
|
|
||||||
|
readbyte += 2;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case t_ABY:
|
||||||
|
curlen = sprintf(str, " $%02X%02X, Y", cpu->memory_opcode_read(addr + 2),
|
||||||
|
cpu->memory_opcode_read(addr + 1));
|
||||||
|
str += curlen; len += curlen;
|
||||||
|
|
||||||
|
if (interpret)
|
||||||
|
{
|
||||||
|
value_u16 = (cpu->memory_opcode_read(addr + 2) << 8) |
|
||||||
|
cpu->memory_opcode_read(addr + 1);
|
||||||
|
curlen = sprintf(str, " ; $%04X + $%02X -> $%04X", value_u16,
|
||||||
|
cpu->reg_Y, value_u16 + cpu->reg_Y);
|
||||||
|
str += curlen; len += curlen;
|
||||||
|
}
|
||||||
|
|
||||||
|
readbyte += 2;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case t_IND:
|
||||||
|
curlen = sprintf(str, " ($%02X%02X)", cpu->memory_opcode_read(addr + 2),
|
||||||
|
cpu->memory_opcode_read(addr + 1));
|
||||||
|
str += curlen; len += curlen;
|
||||||
|
|
||||||
|
if (interpret)
|
||||||
|
{
|
||||||
|
value_u16 = (cpu->memory_opcode_read(addr + 2) << 8) |
|
||||||
|
cpu->memory_opcode_read(addr + 1);
|
||||||
|
value_u16 = cpu->memory_read(value_u16) |
|
||||||
|
(cpu->memory_read( ( value_u16 & 0xFF00 ) |
|
||||||
|
( ( value_u16 + 1 ) & 0x00FF ) ) << 8 );
|
||||||
|
curlen = sprintf(str, " ; ($%02X%02X) -> $%04X",
|
||||||
|
cpu->memory_opcode_read(addr + 2),
|
||||||
|
cpu->memory_opcode_read(addr + 1),
|
||||||
|
cpu->memory_opcode_read(addr));
|
||||||
|
str += curlen; len += curlen;
|
||||||
|
}
|
||||||
|
|
||||||
|
readbyte += 2;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (strlength != NULL)
|
||||||
|
*strlength = len;
|
||||||
|
|
||||||
|
return readbyte;
|
||||||
|
}
|
||||||
|
|
||||||
|
#else
|
||||||
|
static char InstructionParameters[256][10] =
|
||||||
|
{
|
||||||
|
/* 00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F */
|
||||||
|
/* 00 */ IP_iM "BRK", IP_iX "ORA", IP_iM "ILG", IP_iM "ILG", IP_iM "ILG", IP_zP "ORA", IP_zP "ASL", IP_iM "ILG", IP_iM "PHP", IP_iM "ORA", IP_iM "ASL", IP_iM "ILG", IP_iM "ILG", IP_aB "ORA", IP_aB "ASL", IP_iM "ILG",
|
||||||
|
/* 10 */ IP_rE "BPL", IP_iY "ORA", IP_iM "ILG", IP_iM "ILG", IP_iM "ILG", IP_zX "ORA", IP_zX "ASL", IP_iM "ILG", IP_iM "CLC", IP_aY "ORA", IP_iM "ILG", IP_iM "ILG", IP_iM "ILG", IP_aX "ORA", IP_aX "ASL", IP_iM "ILG",
|
||||||
|
/* 20 */ IP_aB "JSR", IP_iX "AND", IP_iM "ILG", IP_iM "ILG", IP_zP "BIT", IP_zP "AND", IP_zP "ROL", IP_iM "ILG", IP_iM "PLP", IP_iM "AND", IP_iM "ROL", IP_iM "ILG", IP_aB "BIT", IP_aB "AND", IP_aB "ROL", IP_iM "ILG",
|
||||||
|
/* 30 */ IP_rE "BMI", IP_iY "AND", IP_iM "ILG", IP_iM "ILG", IP_iM "ILG", IP_zX "AND", IP_zX "ROL", IP_iM "ILG", IP_iM "SEC", IP_aY "AND", IP_iM "ILG", IP_iM "ILG", IP_iM "ILG", IP_aX "AND", IP_aX "ROL", IP_iM "ILG",
|
||||||
|
/* 40 */ IP_iM "RTI", IP_iX "EOR", IP_iM "ILG", IP_iM "ILG", IP_iM "ILG", IP_zP "EOR", IP_zP "LSR", IP_iM "ILG", IP_iM "PHA", IP_iM "EOR", IP_iM "LSR", IP_iM "ILG", IP_aB "JMP", IP_aB "EOR", IP_aB "LSR", IP_iM "ILG",
|
||||||
|
/* 50 */ IP_rE "BVC", IP_iY "EOR", IP_iM "ILG", IP_iM "ILG", IP_iM "ILG", IP_zX "EOR", IP_zX "LSR", IP_iM "ILG", IP_iM "CLI", IP_aY "EOR", IP_iM "ILG", IP_iM "ILG", IP_iM "ILG", IP_aX "EOR", IP_aX "LSR", IP_iM "ILG",
|
||||||
|
/* 60 */ IP_iM "RTS", IP_iX "ADC", IP_iM "ILG", IP_iM "ILG", IP_iM "ILG", IP_zP "ADC", IP_zP "ROR", IP_iM "ILG", IP_iM "PLA", IP_iM "ADC", IP_iM "ROR", IP_iM "ILG", IP_iD "JMP", IP_aB "ADC", IP_aB "ROR", IP_iM "ILG",
|
||||||
|
/* 70 */ IP_rE "BVS", IP_iY "ADC", IP_iM "ILG", IP_iM "ILG", IP_iM "ILG", IP_zX "ADC", IP_zX "ROR", IP_iM "ILG", IP_iM "SEI", IP_aY "ADC", IP_iM "ILG", IP_iM "ILG", IP_iM "ILG", IP_aX "ADC", IP_aX "ROR", IP_iM "ILG",
|
||||||
|
/* 80 */ IP_iM "ILG", IP_iX "STA", IP_iM "ILG", IP_iM "ILG", IP_zP "STY", IP_zP "STA", IP_zP "STX", IP_iM "ILG", IP_iM "DEY", IP_iM "ILG", IP_iM "TXA", IP_iM "ILG", IP_aB "STY", IP_aB "STA", IP_aB "STX", IP_iM "ILG",
|
||||||
|
/* 90 */ IP_rE "BCC", IP_iY "STA", IP_iM "ILG", IP_iM "ILG", IP_zX "STY", IP_zX "STA", IP_zY "STX", IP_iM "ILG", IP_iM "TYA", IP_aY "STA", IP_iM "TXS", IP_iM "ILG", IP_iM "ILG", IP_aX "STA", IP_iM "ILG", IP_iM "ILG",
|
||||||
|
/* A0 */ IP_iM "LDY", IP_iX "LDA", IP_iM "LDX", IP_iM "ILG", IP_zP "LDY", IP_zP "LDA", IP_zP "LDX", IP_iM "ILG", IP_iM "TAY", IP_iM "LDA", IP_iM "TAX", IP_iM "ILG", IP_aB "LDY", IP_aB "LDA", IP_aB "LDX", IP_iM "ILG",
|
||||||
|
/* B0 */ IP_rE "BCS", IP_iY "LDA", IP_iM "ILG", IP_iM "ILG", IP_zX "LDY", IP_zX "LDA", IP_zY "LDX", IP_iM "ILG", IP_iM "CLV", IP_aY "LDA", IP_iM "TSX", IP_iM "ILG", IP_aX "LDY", IP_aX "LDA", IP_aY "LDX", IP_iM "ILG",
|
||||||
|
/* C0 */ IP_iM "CPY", IP_iX "CMP", IP_iM "ILG", IP_iM "ILG", IP_zP "CPY", IP_zP "CMP", IP_zP "DEC", IP_iM "ILG", IP_iM "INY", IP_iM "CMP", IP_iM "DEX", IP_iM "ILG", IP_aB "CPY", IP_aB "CMP", IP_aB "DEC", IP_iM "ILG",
|
||||||
|
/* D0 */ IP_rE "BNE", IP_iY "CMP", IP_iM "ILG", IP_iM "ILG", IP_iM "ILG", IP_zX "CMP", IP_zX "DEC", IP_iM "ILG", IP_iM "CLD", IP_aY "CMP", IP_iM "ILG", IP_iM "ILG", IP_iM "ILG", IP_aX "CMP", IP_aX "DEC", IP_iM "ILG",
|
||||||
|
/* E0 */ IP_iM "CPX", IP_iX "SBC", IP_iM "ILG", IP_iM "ILG", IP_zP "CPX", IP_zP "SBC", IP_zP "INC", IP_iM "ILG", IP_iM "INX", IP_iM "SBC", IP_iM "NOP", IP_iM "ILG", IP_aB "CPX", IP_aB "SBC", IP_aB "INC", IP_iM "ILG",
|
||||||
|
/* F0 */ IP_rE "BEQ", IP_iY "SBC", IP_iM "ILG", IP_iM "ILG", IP_iM "ILG", IP_zX "SBC", IP_zX "INC", IP_iM "ILG", IP_iM "SED", IP_aY "SBC", IP_iM "ILG", IP_iM "ILG", IP_iM "ILG", IP_aX "SBC", IP_aX "INC", IP_iM "ILG"
|
||||||
|
/* 00 01 02 03 04 05 06 07 08 09 0A 0B 0C 0D 0E 0F */
|
||||||
|
};
|
||||||
|
|
||||||
|
/** Get current instruction name at specified address and put it into buffer */
|
||||||
|
int quick6502_getinstruction(quick6502_cpu *cpu, char interpret,
|
||||||
|
unsigned short addr, char *buffer, int *strlength)
|
||||||
|
{
|
||||||
|
unsigned char instr = cpu->memory_opcode_read(cpu->reg_PC);
|
||||||
|
unsigned char *instrText = InstructionParameters[instr];
|
||||||
|
|
||||||
|
buffer += strlen(strcpy(buffer, instrText[1]));
|
||||||
|
switch(instrText[0])
|
||||||
|
{
|
||||||
|
case IP_nPc: default: break;
|
||||||
|
case IP_iMc: buffer += strlen(sprintf(buffer, IPf_iM, cpu->memory_opcode_read(cpu->reg_PC + 1))); break;
|
||||||
|
case IP_iXc: buffer += strlen(sprintf(buffer, IPf_iX, cpu->memory_opcode_read(cpu->reg_PC + 1))); break;
|
||||||
|
case IP_iYc: buffer += strlen(sprintf(buffer, IPf_iY, cpu->memory_opcode_read(cpu->reg_PC + 1))); break;
|
||||||
|
case IP_zPc: buffer += strlen(sprintf(buffer, IPf_zP, cpu->memory_opcode_read(cpu->reg_PC + 1))); break;
|
||||||
|
case IP_zXc: buffer += strlen(sprintf(buffer, IPf_zX, cpu->memory_opcode_read(cpu->reg_PC + 1))); break;
|
||||||
|
case IP_zYc: buffer += strlen(sprintf(buffer, IPf_zY, cpu->memory_opcode_read(cpu->reg_PC + 1))); break;
|
||||||
|
case IP_iDc: buffer += strlen(sprintf(buffer, IPf_iD, cpu->memory_opcode_read(cpu->reg_PC + 2), cpu->memory_opcode_read(cpu->reg_PC + 1))); break;
|
||||||
|
case IP_aBc: buffer += strlen(sprintf(buffer, IPf_aB, cpu->memory_opcode_read(cpu->reg_PC + 2), cpu->memory_opcode_read(cpu->reg_PC + 1))); break;
|
||||||
|
case IP_aXc: buffer += strlen(sprintf(buffer, IPf_aX, cpu->memory_opcode_read(cpu->reg_PC + 2), cpu->memory_opcode_read(cpu->reg_PC + 1))); break;
|
||||||
|
case IP_aYc: buffer += strlen(sprintf(buffer, IPf_aY, cpu->memory_opcode_read(cpu->reg_PC + 2), cpu->memory_opcode_read(cpu->reg_PC + 1))); break;
|
||||||
|
case IP_rEc: buffer += strlen(sprintf(buffer, IPf_rE, cpu->reg_PC + (signed char) cpu->memory_opcode_read(cpu->reg_PC) + 1)); break;
|
||||||
|
}
|
||||||
|
|
||||||
|
*buffer = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
static inline int quick6502_exec_one(quick6502_cpu *cpu)
|
static inline int quick6502_exec_one(quick6502_cpu *cpu)
|
||||||
{
|
{
|
||||||
register byte opcode = cpu->memory_opcode_read(cpu->reg_PC++);
|
register byte opcode = cpu->memory_opcode_read(cpu->reg_PC);
|
||||||
|
|
||||||
|
//char instr[100];
|
||||||
|
//quick6502_dump(cpu, stdout);
|
||||||
|
cpu->reg_PC++;
|
||||||
TRACEi(("Quick6502: PC:$%04X A:$%02X X:$%02X Y:$%02X S:$%02X P:$%02X P:[%c%c%c%c%c%c%c%c]",
|
TRACEi(("Quick6502: PC:$%04X A:$%02X X:$%02X Y:$%02X S:$%02X P:$%02X P:[%c%c%c%c%c%c%c%c]",
|
||||||
cpu->reg_PC, cpu->reg_A, cpu->reg_X, cpu->reg_Y, cpu->reg_S, cpu->reg_P,
|
cpu->reg_PC, cpu->reg_A, cpu->reg_X, cpu->reg_Y, cpu->reg_S, cpu->reg_P,
|
||||||
cpu->reg_P&Q6502_N_FLAG ? 'N':'.',
|
cpu->reg_P&Q6502_N_FLAG ? 'N':'.',
|
||||||
@ -1838,8 +2240,11 @@ static inline int quick6502_exec_one(quick6502_cpu *cpu)
|
|||||||
cpu->reg_P&Q6502_I_FLAG ? 'I':'.',
|
cpu->reg_P&Q6502_I_FLAG ? 'I':'.',
|
||||||
cpu->reg_P&Q6502_Z_FLAG ? 'Z':'.',
|
cpu->reg_P&Q6502_Z_FLAG ? 'Z':'.',
|
||||||
cpu->reg_P&Q6502_C_FLAG ? 'C':'.'));
|
cpu->reg_P&Q6502_C_FLAG ? 'C':'.'));
|
||||||
|
|
||||||
InstructionTable[opcode](cpu);
|
InstructionTable[opcode](cpu);
|
||||||
|
//printf("--------------------------------------------------------------\n");
|
||||||
|
/*quick6502_getinstruction(cpu, (1==1), cpu->reg_PC, instr, NULL);
|
||||||
|
printf("%04X: %s\n", cpu->reg_PC, instr);*/
|
||||||
|
|
||||||
cpu->cycle_done += CycleTable[opcode];
|
cpu->cycle_done += CycleTable[opcode];
|
||||||
if (cpu->page_crossed) { cpu->cycle_done++; cpu->page_crossed = 0; }
|
if (cpu->page_crossed) { cpu->cycle_done++; cpu->page_crossed = 0; }
|
||||||
if (cpu->int_pending != 0)
|
if (cpu->int_pending != 0)
|
||||||
|
|||||||
@ -14,6 +14,7 @@
|
|||||||
#ifndef NESCARTS_H
|
#ifndef NESCARTS_H
|
||||||
#define NESCARTS_H
|
#define NESCARTS_H
|
||||||
|
|
||||||
|
#include <stdint.h>
|
||||||
#include <types.h>
|
#include <types.h>
|
||||||
|
|
||||||
#define iNES_MIRROR 0x01
|
#define iNES_MIRROR 0x01
|
||||||
@ -23,14 +24,14 @@
|
|||||||
|
|
||||||
typedef struct NesCart_
|
typedef struct NesCart_
|
||||||
{
|
{
|
||||||
unsigned long PROMSize, /* Size of PROM */
|
uint32_t PROMSize, /* Size of PROM */
|
||||||
VROMSize; /* Size of VROM */
|
VROMSize; /* Size of VROM */
|
||||||
char MapperID; /* Mapper Type */
|
char MapperID; /* Mapper Type */
|
||||||
byte Flags;
|
uint8_t Flags;
|
||||||
char *FileName;
|
char *FileName;
|
||||||
byte *File; /* Pointer on the file in memory */
|
uint8_t *File; /* Pointer on the file in memory */
|
||||||
byte *PROMBanks; /* Pointer on the first PROM */
|
uint8_t *PROMBanks; /* Pointer on the first PROM */
|
||||||
byte *VROMBanks; /* Pointer on the first VROM */
|
uint8_t *VROMBanks; /* Pointer on the first VROM */
|
||||||
} NesCart;
|
} NesCart;
|
||||||
|
|
||||||
void DumpCartProperties();
|
void DumpCartProperties();
|
||||||
|
|||||||
@ -93,7 +93,7 @@ void SetChannels(int Volume,int Switch);
|
|||||||
/** waveform to be an instrument or set it to the waveform **/
|
/** waveform to be an instrument or set it to the waveform **/
|
||||||
/** own playback rate. **/
|
/** own playback rate. **/
|
||||||
/*************************************************************/
|
/*************************************************************/
|
||||||
void SetWave(int Channel,const signed char *Data,int Length,int Rate);
|
void SetWave(int Channel,signed char *Data,int Length,int Rate);
|
||||||
|
|
||||||
/** GetWave() ************************************************/
|
/** GetWave() ************************************************/
|
||||||
/** Get current read position for the buffer set with the **/
|
/** Get current read position for the buffer set with the **/
|
||||||
@ -225,7 +225,7 @@ struct SndDriverStruct
|
|||||||
void (*Drum)(int Type,int Force);
|
void (*Drum)(int Type,int Force);
|
||||||
void (*SetChannels)(int Volume,int Switch);
|
void (*SetChannels)(int Volume,int Switch);
|
||||||
void (*Sound)(int Channel,int NewFreq,int NewVolume);
|
void (*Sound)(int Channel,int NewFreq,int NewVolume);
|
||||||
void (*SetWave)(int Channel,const signed char *Data,int Length,int Freq);
|
void (*SetWave)(int Channel,signed char *Data,int Length,int Freq);
|
||||||
const signed char *(*GetWave)(int Channel);
|
const signed char *(*GetWave)(int Channel);
|
||||||
};
|
};
|
||||||
extern struct SndDriverStruct SndDriver;
|
extern struct SndDriverStruct SndDriver;
|
||||||
|
|||||||
48
src/include/color.h
Normal file
48
src/include/color.h
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
/**
|
||||||
|
* ANSI Color definitiont - The Quick6502 Project
|
||||||
|
* include/color.h
|
||||||
|
*
|
||||||
|
* Created by Manoel Trapier on 25/06/10
|
||||||
|
* Copyright 2010 986 Corp. All rights reserved.
|
||||||
|
*
|
||||||
|
* $LastChangedDate:$
|
||||||
|
* $Author:$
|
||||||
|
* $HeadURL:$
|
||||||
|
* $Revision:$
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef COLOR_H
|
||||||
|
#define COLOR_H
|
||||||
|
|
||||||
|
#define ALLOW_COLORS
|
||||||
|
|
||||||
|
#ifdef ALLOW_COLORS
|
||||||
|
#define __C(c) "\x1B[" c "m"
|
||||||
|
#else
|
||||||
|
#define __C(c) ""
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define ANSI_COLOR __C
|
||||||
|
#define FBLACK ANSI_COLOR("30")
|
||||||
|
#define FRED ANSI_COLOR("31")
|
||||||
|
#define FGREEN ANSI_COLOR("32")
|
||||||
|
#define FYELLOW ANSI_COLOR("33")
|
||||||
|
#define FBLUE ANSI_COLOR("34")
|
||||||
|
#define FMAGENTA ANSI_COLOR("35")
|
||||||
|
#define FCYAN ANSI_COLOR("36")
|
||||||
|
#define FWHITE ANSI_COLOR("37")
|
||||||
|
|
||||||
|
#define BBLACK ANSI_COLOR("40")
|
||||||
|
#define BRED ANSI_COLOR("41")
|
||||||
|
#define BGREEN ANSI_COLOR("42")
|
||||||
|
#define BYELLOW ANSI_COLOR("43")
|
||||||
|
#define BBLUE ANSI_COLOR("44")
|
||||||
|
#define BMAGENTA ANSI_COLOR("45")
|
||||||
|
#define BCYAN ANSI_COLOR("46")
|
||||||
|
#define BWHITE ANSI_COLOR("47")
|
||||||
|
|
||||||
|
#define CNORMAL ANSI_COLOR("0")
|
||||||
|
|
||||||
|
#endif /* COLOR_H */
|
||||||
|
|
||||||
@ -18,22 +18,23 @@
|
|||||||
/* M6502 configuration
|
/* M6502 configuration
|
||||||
*
|
*
|
||||||
* Supported DEFINEs :
|
* Supported DEFINEs :
|
||||||
* NO_DECIMAL Quick6502 will not support BDC arithemtic (used for NES)
|
* Q6502_NO_DECIMAL Quick6502 will not support BDC arithemtic (used for NES)
|
||||||
* CMOS_6502 Quick6502 will act as a CMOS 6502 (Not actually used)
|
* Q6502_CMOS Quick6502 will act as a CMOS 6502 (Not actually used)
|
||||||
|
* Q6502_DEBUGGER Quick6502 will be build with debugguer support. Add some KB to the binary
|
||||||
|
* and may slowdown a bit the emulation.
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef CMOS_6502
|
#ifdef Q6502_CMOS
|
||||||
//#warning Quick6502 CMOS support is actually desactivated, desactivate it
|
//#warning Quick6502 CMOS support is actually desactivated, desactivate it
|
||||||
#undef CMOS_6502
|
#undef Q6502_CMOS
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef NO_DECIMAL
|
#ifndef Q6502_NO_DECIMAL
|
||||||
//#warning Quick6502 have actually no BCD support, fallback to no NO_DECIMAL
|
//#warning Quick6502 have actually no BCD support, fallback to no NO_DECIMAL
|
||||||
#define NO_DECIMAL
|
#define Q6502_NO_DECIMAL
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#include "types.h"
|
#include "types.h"
|
||||||
|
|
||||||
typedef byte (*quick6502_MemoryReadFunction)(unsigned short addr);
|
typedef byte (*quick6502_MemoryReadFunction)(unsigned short addr);
|
||||||
@ -63,6 +64,9 @@ typedef struct quick6502_cpu_
|
|||||||
/* Other config options */
|
/* Other config options */
|
||||||
byte running; /* This field is used to prevent cpu free if this cpu is running */
|
byte running; /* This field is used to prevent cpu free if this cpu is running */
|
||||||
byte page_crossed;
|
byte page_crossed;
|
||||||
|
|
||||||
|
/* TODO add support for Inst/MemAccess breakpoints */
|
||||||
|
|
||||||
} quick6502_cpu;
|
} quick6502_cpu;
|
||||||
|
|
||||||
typedef struct quick6502_cpuconfig_
|
typedef struct quick6502_cpuconfig_
|
||||||
@ -150,8 +154,10 @@ void quick6502_int(quick6502_cpu *cpu, quick6502_signal signal);
|
|||||||
void quick6502_dump(quick6502_cpu *cpu, FILE * fp);
|
void quick6502_dump(quick6502_cpu *cpu, FILE * fp);
|
||||||
|
|
||||||
/** Get current instruction name at specified address and put it into buffer */
|
/** Get current instruction name at specified address and put it into buffer */
|
||||||
void quick6502_getinstruction(quick6502_cpu *cpu, unsigned short addr, char *buffer);
|
#define MINE
|
||||||
|
|
||||||
|
int quick6502_getinstruction(quick6502_cpu *cpu, char interpret,
|
||||||
|
unsigned short addr, char *buffer, int *strlength);
|
||||||
/**
|
/**
|
||||||
* Free the CPU
|
* Free the CPU
|
||||||
*
|
*
|
||||||
|
|||||||
42
src/include/log.h
Normal file
42
src/include/log.h
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
/**
|
||||||
|
* Log Facility - The Quick6502 Project
|
||||||
|
* include/log.h
|
||||||
|
*
|
||||||
|
* Created by Manoel Trapier on 19/05/10
|
||||||
|
* Copyright 2010 986 Corp. All rights reserved.
|
||||||
|
*
|
||||||
|
* $LastChangedDate:$
|
||||||
|
* $Author:$
|
||||||
|
* $HeadURL:$
|
||||||
|
* $Revision:$
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef _LOG_H
|
||||||
|
#define _LOG_H
|
||||||
|
|
||||||
|
enum
|
||||||
|
{
|
||||||
|
LOG_ALWAYS = -1,
|
||||||
|
LOG_PANIC = 0,
|
||||||
|
LOG_ERROR,
|
||||||
|
LOG_WARNING,
|
||||||
|
LOG_NORMAL,
|
||||||
|
LOG_VERBOSE,
|
||||||
|
LOG_DEBUG,
|
||||||
|
};
|
||||||
|
|
||||||
|
#define TIME_STAMP_LOG
|
||||||
|
|
||||||
|
#define MAX_DEBUG_LEVEL LOG_PANIC
|
||||||
|
#define log(_level, _user, _fmt, ...) if ((_level <= MAX_DEBUG_LEVEL) || (_level <= LOG_PANIC)) do { log_real(_level, _user, _fmt, ##__VA_ARGS__); } while(0)
|
||||||
|
|
||||||
|
void log_real(int level, char *user, char *fmt, ...);
|
||||||
|
|
||||||
|
#define LOG(_level, _str, ...) if ((_level <= MAX_DEBUG_LEVEL) || (_level <= LOG_PANIC)) do { puts(_str); } while(0)
|
||||||
|
#define LOGCODE(_level, _user, _code) log(_level, _user, ""); \
|
||||||
|
if ((_level <= MAX_DEBUG_LEVEL) || (_level <= LOG_PANIC)) \
|
||||||
|
do { _code; printf("\n"); } while(0)
|
||||||
|
|
||||||
|
#endif /* _LOG_H */
|
||||||
|
|
||||||
@ -63,6 +63,6 @@ void InitMemory();
|
|||||||
byte ReadMemory(byte page, byte addr);
|
byte ReadMemory(byte page, byte addr);
|
||||||
void WriteMemory(byte page, byte addr, byte value);
|
void WriteMemory(byte page, byte addr, byte value);
|
||||||
|
|
||||||
void DumpMemoryState();
|
void DumpMemoryState(FILE *fp);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
125
src/log.c
Normal file
125
src/log.c
Normal file
@ -0,0 +1,125 @@
|
|||||||
|
/**
|
||||||
|
* Log Facility - The Quick6502 Project
|
||||||
|
* log.c
|
||||||
|
*
|
||||||
|
* Created by Manoel Trapier on 19/05/10
|
||||||
|
* Copyright 2010 986 Corp. All rights reserved.
|
||||||
|
*
|
||||||
|
* $LastChangedDate:$
|
||||||
|
* $Author:$
|
||||||
|
* $HeadURL:$
|
||||||
|
* $Revision:$
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <color.h>
|
||||||
|
#include <string.h>
|
||||||
|
#include <stdarg.h>
|
||||||
|
#include <log.h>
|
||||||
|
#include <sys/time.h>
|
||||||
|
#include <time.h>
|
||||||
|
|
||||||
|
#ifdef TIME_STAMP_LOG
|
||||||
|
void time_stamp_line(void)
|
||||||
|
{
|
||||||
|
/* Time "0" will be thefirst log line */
|
||||||
|
static char firstRun = 1;
|
||||||
|
static struct timeval firstTime;
|
||||||
|
struct timeval curTime;
|
||||||
|
|
||||||
|
int cMin, cSec;
|
||||||
|
long long cMSec;
|
||||||
|
|
||||||
|
/* Get datetime */
|
||||||
|
gettimeofday(&curTime, NULL);
|
||||||
|
|
||||||
|
if (firstRun == 1)
|
||||||
|
{
|
||||||
|
firstRun = 0;
|
||||||
|
firstTime.tv_sec = curTime.tv_sec;
|
||||||
|
firstTime.tv_usec = curTime.tv_usec;
|
||||||
|
}
|
||||||
|
|
||||||
|
cMSec = ((curTime.tv_sec - firstTime.tv_sec)* 1000) + (curTime.tv_usec - firstTime.tv_usec)/1000;
|
||||||
|
cSec = (cMSec/1000);
|
||||||
|
cMSec %= 1000;
|
||||||
|
|
||||||
|
cMin = cSec / 60;
|
||||||
|
|
||||||
|
cSec %= 60;
|
||||||
|
|
||||||
|
/* Put cursor at start of line */
|
||||||
|
printf("%c[s", 0x1B);
|
||||||
|
printf("%c[7000D", 0x1B);
|
||||||
|
printf("%c[1C", 0x1B);
|
||||||
|
printf(FWHITE"[" FYELLOW "%03d" FRED "." FBLUE "%02d" FRED "." FGREEN "%03lld" FWHITE "]" CNORMAL, cMin, cSec, cMSec);
|
||||||
|
printf("%c[u", 0x1B);
|
||||||
|
}
|
||||||
|
#endif /* TIME_STAMP_LOG */
|
||||||
|
|
||||||
|
void log_real(int level, char *user, char *fmt, ...)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
va_list va;
|
||||||
|
|
||||||
|
/* The LOG_PANIC must always be displayed */
|
||||||
|
if ((level <= MAX_DEBUG_LEVEL) || (level <= LOG_PANIC))
|
||||||
|
{
|
||||||
|
switch(level)
|
||||||
|
{
|
||||||
|
case LOG_PANIC: printf(BRED FWHITE); break;
|
||||||
|
case LOG_ERROR: printf(FRED); break;
|
||||||
|
case LOG_WARNING: printf(FYELLOW); break;
|
||||||
|
default:
|
||||||
|
case LOG_NORMAL: printf(FGREEN); break;
|
||||||
|
case LOG_VERBOSE: printf(FCYAN); break;
|
||||||
|
case LOG_DEBUG: printf(BBLUE FWHITE); break;
|
||||||
|
}
|
||||||
|
|
||||||
|
#ifdef TIME_STAMP_LOG
|
||||||
|
printf(" ");
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (user != NULL)
|
||||||
|
{
|
||||||
|
i = strlen(user);
|
||||||
|
if (i < 12)
|
||||||
|
{
|
||||||
|
i = 12 - i;
|
||||||
|
for (; i >= 0; i--)
|
||||||
|
putchar(' ');
|
||||||
|
}
|
||||||
|
printf("%s", user);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
switch(level)
|
||||||
|
{
|
||||||
|
case LOG_PANIC: printf(" PANIC"); break;
|
||||||
|
case LOG_ERROR: printf(" Error"); break;
|
||||||
|
case LOG_WARNING: printf(" Warning"); break;
|
||||||
|
default:
|
||||||
|
case LOG_NORMAL: printf(" Info"); break;
|
||||||
|
case LOG_VERBOSE: printf(" Verbose"); break;
|
||||||
|
case LOG_DEBUG: printf(" Debug"); break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
printf(CNORMAL ": ");
|
||||||
|
|
||||||
|
#ifdef TIME_STAMP_LOG
|
||||||
|
time_stamp_line();
|
||||||
|
#endif /* TIME_STAMP_LOG */
|
||||||
|
|
||||||
|
va_start(va, fmt);
|
||||||
|
vprintf(fmt, va);
|
||||||
|
va_end(va);
|
||||||
|
|
||||||
|
if (fmt[0] != 0)
|
||||||
|
{
|
||||||
|
printf("\n");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
100
src/main.c
100
src/main.c
@ -3,7 +3,7 @@
|
|||||||
* main.c
|
* main.c
|
||||||
*
|
*
|
||||||
* Created by Manoel TRAPIER.
|
* Created by Manoel TRAPIER.
|
||||||
* Copyright (c) 2003-2008 986Corp. All rights reserved.
|
* Copyright (c) 2003-2012 986Corp. All rights reserved.
|
||||||
*
|
*
|
||||||
* $LastChangedDate$
|
* $LastChangedDate$
|
||||||
* $Author$
|
* $Author$
|
||||||
@ -87,6 +87,8 @@ double APU_BASEFREQ = 1.7897725;
|
|||||||
# error Cannot use ISPAL with ISNTSC together !
|
# error Cannot use ISPAL with ISNTSC together !
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
//#define MEMORY_TEST
|
||||||
|
|
||||||
/* TI-NESulator Version */
|
/* TI-NESulator Version */
|
||||||
#define V_MAJOR 0
|
#define V_MAJOR 0
|
||||||
#define V_MINOR 40
|
#define V_MINOR 40
|
||||||
@ -140,6 +142,7 @@ volatile unsigned long FPS, IPS;
|
|||||||
PALETTE pal;
|
PALETTE pal;
|
||||||
|
|
||||||
short IRQScanHit = -1;
|
short IRQScanHit = -1;
|
||||||
|
short SZHit = -1;
|
||||||
|
|
||||||
/* palette */
|
/* palette */
|
||||||
unsigned long ColorPalette[ 8 * 63 ];
|
unsigned long ColorPalette[ 8 * 63 ];
|
||||||
@ -177,6 +180,7 @@ void SaveSaveRam(char *name)
|
|||||||
FILE *fp;
|
FILE *fp;
|
||||||
int i;
|
int i;
|
||||||
char fname[512];
|
char fname[512];
|
||||||
|
int ret;
|
||||||
strcpy(fname, name);
|
strcpy(fname, name);
|
||||||
strcat(fname, ".svt");
|
strcat(fname, ".svt");
|
||||||
if ((fp = fopen(fname, "wb")))
|
if ((fp = fopen(fname, "wb")))
|
||||||
@ -184,7 +188,7 @@ void SaveSaveRam(char *name)
|
|||||||
console_printf(Console_Default, "Saving savestate '%s'\n", fname);
|
console_printf(Console_Default, "Saving savestate '%s'\n", fname);
|
||||||
for( i = 0x60; i < 0x80; i++)
|
for( i = 0x60; i < 0x80; i++)
|
||||||
{
|
{
|
||||||
fwrite(get_page_ptr(i), 1, 0x100, fp);
|
ret = fwrite(get_page_ptr(i), 1, 0x100, fp);
|
||||||
}
|
}
|
||||||
|
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
@ -196,7 +200,7 @@ void LoadSaveRam(char *name)
|
|||||||
FILE *fp;
|
FILE *fp;
|
||||||
int i;
|
int i;
|
||||||
char fname[512];
|
char fname[512];
|
||||||
|
int ret;
|
||||||
strcpy(fname, name);
|
strcpy(fname, name);
|
||||||
strcat(fname, ".svt");
|
strcat(fname, ".svt");
|
||||||
if ((fp = fopen(fname, "rb")))
|
if ((fp = fopen(fname, "rb")))
|
||||||
@ -204,7 +208,7 @@ void LoadSaveRam(char *name)
|
|||||||
console_printf(Console_Default, "Loading savestate '%s'\n", fname);
|
console_printf(Console_Default, "Loading savestate '%s'\n", fname);
|
||||||
for( i = 0x60; i < 0x80; i++)
|
for( i = 0x60; i < 0x80; i++)
|
||||||
{
|
{
|
||||||
fread(get_page_ptr(i), 1, 0x0100, fp);
|
ret = fread(get_page_ptr(i), 1, 0x0100, fp);
|
||||||
}
|
}
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
|
|
||||||
@ -215,7 +219,7 @@ void LoadSaveRam(char *name)
|
|||||||
void LoadPalette(char *filename, PALETTE pal)
|
void LoadPalette(char *filename, PALETTE pal)
|
||||||
{
|
{
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
|
int ret;
|
||||||
unsigned char r, v, b, i;
|
unsigned char r, v, b, i;
|
||||||
console_printf(Console_Default, "%s: try to load pallette file '%s'", __func__, filename);
|
console_printf(Console_Default, "%s: try to load pallette file '%s'", __func__, filename);
|
||||||
if ((fp = fopen(filename, "rb")) != NULL)
|
if ((fp = fopen(filename, "rb")) != NULL)
|
||||||
@ -224,9 +228,9 @@ void LoadPalette(char *filename, PALETTE pal)
|
|||||||
for (i = 0; i < 64; i++)
|
for (i = 0; i < 64; i++)
|
||||||
{
|
{
|
||||||
|
|
||||||
fread(&r, 1, 1, fp);
|
ret = fread(&r, 1, 1, fp);
|
||||||
fread(&v, 1, 1, fp);
|
ret = fread(&v, 1, 1, fp);
|
||||||
fread(&b, 1, 1, fp);
|
ret = fread(&b, 1, 1, fp);
|
||||||
|
|
||||||
/* r = (r * 64) / 255;
|
/* r = (r * 64) / 255;
|
||||||
v = (v * 64) / 255;
|
v = (v * 64) / 255;
|
||||||
@ -255,7 +259,7 @@ void LoadPalette(char *filename, PALETTE pal)
|
|||||||
ColorPalette[i + (6 * 63)] = SET_RGB(r - 10, v + 05, b + 05);
|
ColorPalette[i + (6 * 63)] = SET_RGB(r - 10, v + 05, b + 05);
|
||||||
|
|
||||||
/* Red + Green + Blue emphase */
|
/* Red + Green + Blue emphase */
|
||||||
ColorPalette[i + (7 * 63)] = SET_RGB(r + 00, v + 00, b + 00);*/
|
ColorPalette[i + (7 * 63)] = SET_RGB(r + 00, v + 00, b + 00);
|
||||||
#else /* Else Use 8Bits */
|
#else /* Else Use 8Bits */
|
||||||
pal[i].r = r;
|
pal[i].r = r;
|
||||||
pal[i].g = v;
|
pal[i].g = v;
|
||||||
@ -284,16 +288,12 @@ void LoadPalette(char *filename, PALETTE pal)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void *signalhandler(int sig)
|
void signalhandler(int sig)
|
||||||
{
|
{
|
||||||
#if 0
|
|
||||||
static int state=0;
|
static int state=0;
|
||||||
|
|
||||||
byte F;
|
|
||||||
int J, I;
|
|
||||||
static char FA[8] = "NVRBDIZC";
|
|
||||||
char S[128];
|
|
||||||
char name[512];
|
char name[512];
|
||||||
|
|
||||||
static FILE *fp = NULL;
|
static FILE *fp = NULL;
|
||||||
sprintf(name, "crashdump-%d.txt", (int)time(NULL));
|
sprintf(name, "crashdump-%d.txt", (int)time(NULL));
|
||||||
if (state != 0)
|
if (state != 0)
|
||||||
@ -332,27 +332,17 @@ void *signalhandler(int sig)
|
|||||||
case SIGTERM: fprintf(fp,"Termination request"); break;
|
case SIGTERM: fprintf(fp,"Termination request"); break;
|
||||||
}
|
}
|
||||||
fprintf(fp,"\nAn error occured during the excution.\n Crash report information :\n");
|
fprintf(fp,"\nAn error occured during the excution.\n Crash report information :\n");
|
||||||
#ifdef DEBUG
|
|
||||||
DAsm(S, R->PC.W);
|
//quick6502_dump(cpu, fp);
|
||||||
#endif
|
|
||||||
fprintf(fp, "CPU: A:%02X P:%02X X:%02X Y:%02X S:%04X PC:%04X Flags:[",
|
//showlastop(fp);
|
||||||
R->A, R->P, R->X, R->Y, R->S + 0x0100, R->PC.W);
|
|
||||||
for (J = 0, F = R->P; J < 8; J++, F <<= 1)
|
|
||||||
fprintf(fp, "%c", F & 0x80 ? FA[J] : '.');
|
|
||||||
fprintf(fp, "]\nCPU: ");
|
|
||||||
fprintf(fp, "AT PC: [%02X - %s] AT SP: [%02X %02X %02X]\nLast execution :\n",
|
|
||||||
Rd6502(R->PC.W), S,
|
|
||||||
Rd6502(0x0100 + (byte) (R->S + 1)),
|
|
||||||
Rd6502(0x0100 + (byte) (R->S + 2)),
|
|
||||||
Rd6502(0x0100 + (byte) (R->S + 3)));
|
|
||||||
showlastop(fp);
|
|
||||||
// fprintf(fp, "PPU: CR1: 0x%02X (NT:%d AI:%d SP:%d BP:%d SS:%d NMI:%d)\n",ppu.ControlRegister1.b, ppu.ControlRegister1.s.NameTblAddr, ppu.ControlRegister1.s.AddrIncrmt, ppu.ControlRegister1.s.SptPattern, ppu.ControlRegister1.s.BgPattern, ppu.ControlRegister1.s.SpriteSize, ppu.ControlRegister1.s.VBlank_NMI);
|
// fprintf(fp, "PPU: CR1: 0x%02X (NT:%d AI:%d SP:%d BP:%d SS:%d NMI:%d)\n",ppu.ControlRegister1.b, ppu.ControlRegister1.s.NameTblAddr, ppu.ControlRegister1.s.AddrIncrmt, ppu.ControlRegister1.s.SptPattern, ppu.ControlRegister1.s.BgPattern, ppu.ControlRegister1.s.SpriteSize, ppu.ControlRegister1.s.VBlank_NMI);
|
||||||
// fprintf(fp, "PPU: CR2: 0x%02X (FBC/CI:%d SV:%d BV:%d SC:%d BC:%d DT:%d)\n",ppu.ControlRegister2.b,ppu.ControlRegister2.s.Colour,ppu.ControlRegister2.s.SpriteVisibility,ppu.ControlRegister2.s.BgVisibility,ppu.ControlRegister2.s.SpriteClipping,ppu.ControlRegister2.s.BgClipping,ppu.ControlRegister2.s.DisplayType);
|
// fprintf(fp, "PPU: CR2: 0x%02X (FBC/CI:%d SV:%d BV:%d SC:%d BC:%d DT:%d)\n",ppu.ControlRegister2.b,ppu.ControlRegister2.s.Colour,ppu.ControlRegister2.s.SpriteVisibility,ppu.ControlRegister2.s.BgVisibility,ppu.ControlRegister2.s.SpriteClipping,ppu.ControlRegister2.s.BgClipping,ppu.ControlRegister2.s.DisplayType);
|
||||||
// fprintf(fp, "PPU: SR: 0x%02X (VB:%d S0:%d SSC:%d VWF:%d)\n", ppu.StatusRegister.b,ppu.StatusRegister.s.VBlankOccur,ppu.StatusRegister.s.Sprite0Occur,ppu.StatusRegister.s.SprtCount,ppu.StatusRegister.s.VRAMProtect);
|
// fprintf(fp, "PPU: SR: 0x%02X (VB:%d S0:%d SSC:%d VWF:%d)\n", ppu.StatusRegister.b,ppu.StatusRegister.s.VBlankOccur,ppu.StatusRegister.s.Sprite0Occur,ppu.StatusRegister.s.SprtCount,ppu.StatusRegister.s.VRAMProtect);
|
||||||
// fprintf(fp, "PPU: M:%d ST:%d VRAMPtr:0x%04X T:0x%04X\n",ppu.MirrorDir,ppu.ScreenType,ppu.VRAMAddrReg2.W,ppu.TmpVRamPtr);
|
// fprintf(fp, "PPU: M:%d ST:%d VRAMPtr:0x%04X T:0x%04X\n",ppu.MirrorDir,ppu.ScreenType,ppu.VRAMAddrReg2.W,ppu.TmpVRamPtr);
|
||||||
|
|
||||||
//MapperDump(fp);
|
//MapperDump(fp);
|
||||||
|
#if 0
|
||||||
for(I = 0; I < 0xFFFF; I += 0x10)
|
for(I = 0; I < 0xFFFF; I += 0x10)
|
||||||
fprintf(fp, "%04X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X | %c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c\n",
|
fprintf(fp, "%04X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X %02X | %c%c%c%c%c%c%c%c%c%c%c%c%c%c%c%c\n",
|
||||||
I,
|
I,
|
||||||
@ -377,12 +367,12 @@ void *signalhandler(int sig)
|
|||||||
isprint(Rd6502(I+0x0D))?Rd6502(I+0x0D):'_',
|
isprint(Rd6502(I+0x0D))?Rd6502(I+0x0D):'_',
|
||||||
isprint(Rd6502(I+0x0E))?Rd6502(I+0x0E):'_',
|
isprint(Rd6502(I+0x0E))?Rd6502(I+0x0E):'_',
|
||||||
isprint(Rd6502(I+0x0F))?Rd6502(I+0x0F):'_');
|
isprint(Rd6502(I+0x0F))?Rd6502(I+0x0F):'_');
|
||||||
|
#endif
|
||||||
DumpMemoryState(fp);
|
DumpMemoryState(fp);
|
||||||
|
|
||||||
console_printf(Console_Error, "\nPlease join this informations when submiting crash report\n");
|
console_printf(Console_Error, "\nPlease join this informations when submiting crash report\n");
|
||||||
if (fp != stderr) fclose(fp);
|
if (fp != stderr) fclose(fp);
|
||||||
#endif
|
|
||||||
exit(-42);
|
exit(-42);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -410,7 +400,6 @@ void WrHook4000Multiplexer(byte addr, byte value)
|
|||||||
static byte Sq2_reg3 = 0;
|
static byte Sq2_reg3 = 0;
|
||||||
|
|
||||||
double SQ = 0.0;
|
double SQ = 0.0;
|
||||||
|
|
||||||
switch(addr)
|
switch(addr)
|
||||||
{
|
{
|
||||||
#ifdef USE_SOUND
|
#ifdef USE_SOUND
|
||||||
@ -623,8 +612,6 @@ byte RdHook4000Multiplexer(byte addr)
|
|||||||
|
|
||||||
case 0x15:
|
case 0x15:
|
||||||
ret = 0x1F;
|
ret = 0x1F;
|
||||||
break;
|
|
||||||
|
|
||||||
default:
|
default:
|
||||||
ret = 0x42;
|
ret = 0x42;
|
||||||
}
|
}
|
||||||
@ -645,7 +632,6 @@ void printUsage(int argc, char *argv[])
|
|||||||
int main(int argc, char *argv[])
|
int main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
unsigned char j, k;
|
|
||||||
unsigned char *MemoryPage;
|
unsigned char *MemoryPage;
|
||||||
quick6502_cpuconfig CpuConfig;
|
quick6502_cpuconfig CpuConfig;
|
||||||
|
|
||||||
@ -665,11 +651,11 @@ int main(int argc, char *argv[])
|
|||||||
2kB Internal RAM, mirrored 4 times
|
2kB Internal RAM, mirrored 4 times
|
||||||
--------------------------------------- $0000
|
--------------------------------------- $0000
|
||||||
*/
|
*/
|
||||||
console_init(Console_Default);
|
console_init(Console_Debug);
|
||||||
/* Print the banner */
|
/* Print the banner */
|
||||||
console_printf(Console_Default, "--------------------------------------------------------------------------------\n"
|
console_printf(Console_Default, "--------------------------------------------------------------------------------\n"
|
||||||
"Welcome to TI-NESulator v%d.%d - by Godzil\n"
|
"Welcome to TI-NESulator v%d.%d - by Godzil\n"
|
||||||
"Copyright 2003-2008 TRAPIER Manoel (godzil@godzil.net)\n"
|
"Copyright 2003-2012 TRAPIER Manoel (godzil@godzil.net)\n"
|
||||||
"%s\n%s\n%s\n"
|
"%s\n%s\n%s\n"
|
||||||
"--------------------------------------------------------------------------------\n\n",
|
"--------------------------------------------------------------------------------\n\n",
|
||||||
V_MAJOR,
|
V_MAJOR,
|
||||||
@ -679,15 +665,15 @@ int main(int argc, char *argv[])
|
|||||||
VS_AUTHOR);
|
VS_AUTHOR);
|
||||||
|
|
||||||
console_printf(Console_Default, "Install signal handlers...\t[");
|
console_printf(Console_Default, "Install signal handlers...\t[");
|
||||||
// signal(SIGABRT,signalhandler);
|
signal(SIGABRT, signalhandler);
|
||||||
console_printf(Console_Default, "A");
|
console_printf(Console_Default, "A");
|
||||||
// signal(SIGILL,signalhandler);
|
signal(SIGILL, signalhandler);
|
||||||
console_printf(Console_Default, "I");
|
console_printf(Console_Default, "I");
|
||||||
/*signal(SIGINT, signalhandler);*/
|
/*signal(SIGINT, signalhandler);*/
|
||||||
console_printf(Console_Default, ".");
|
console_printf(Console_Default, ".");
|
||||||
// signal(SIGSEGV,signalhandler);
|
signal(SIGSEGV, signalhandler);
|
||||||
console_printf(Console_Default, "S");
|
console_printf(Console_Default, "S");
|
||||||
// signal(SIGTERM,signalhandler);
|
signal(SIGTERM, signalhandler);
|
||||||
console_printf(Console_Default, "T]\n");
|
console_printf(Console_Default, "T]\n");
|
||||||
|
|
||||||
/* */
|
/* */
|
||||||
@ -812,6 +798,7 @@ int main(int argc, char *argv[])
|
|||||||
|
|
||||||
#define Value(s) (((s%0xFF) + (rand()%0xFF-128) )%0xFF)
|
#define Value(s) (((s%0xFF) + (rand()%0xFF-128) )%0xFF)
|
||||||
|
|
||||||
|
#ifdef MEMORY_TEST
|
||||||
console_printf(Console_Default, "Testing memory validity...\n");
|
console_printf(Console_Default, "Testing memory validity...\n");
|
||||||
|
|
||||||
map_sram();
|
map_sram();
|
||||||
@ -841,12 +828,13 @@ int main(int argc, char *argv[])
|
|||||||
if ((k=MemoryOpCodeRead(i)) != j)
|
if ((k=MemoryOpCodeRead(i)) != j)
|
||||||
console_printf(Console_Error, "Error opcode @ 0x%X [w:%d,r:%d]\n", i, j, k);
|
console_printf(Console_Error, "Error opcode @ 0x%X [w:%d,r:%d]\n", i, j, k);
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
/* SRAM (0x6000 : 0x2000 bytes ) */
|
/* SRAM (0x6000 : 0x2000 bytes ) */
|
||||||
MemoryPage = (unsigned char *)malloc (0x2000);
|
MemoryPage = (unsigned char *)malloc (0x2000);
|
||||||
|
|
||||||
set_page_ptr_8k(0x60, MemoryPage);
|
set_page_ptr_8k(0x60, MemoryPage);
|
||||||
|
|
||||||
|
#ifdef MEMORY_TEST
|
||||||
for(i = 0x6000; i < 0x8000; i ++)
|
for(i = 0x6000; i < 0x8000; i ++)
|
||||||
{
|
{
|
||||||
if (MemoryPage[i-0x6000] != (k = MemoryRead(i)))
|
if (MemoryPage[i-0x6000] != (k = MemoryRead(i)))
|
||||||
@ -875,6 +863,7 @@ int main(int argc, char *argv[])
|
|||||||
}
|
}
|
||||||
|
|
||||||
console_printf(Console_Default, "[ OK ]\n");
|
console_printf(Console_Default, "[ OK ]\n");
|
||||||
|
#endif
|
||||||
|
|
||||||
Cart = malloc( sizeof (NesCart));
|
Cart = malloc( sizeof (NesCart));
|
||||||
if (Cart == NULL)
|
if (Cart == NULL)
|
||||||
@ -887,8 +876,13 @@ int main(int argc, char *argv[])
|
|||||||
{
|
{
|
||||||
int fd;
|
int fd;
|
||||||
console_printf(Console_Default, "Loading FDS ROM...\t\t");
|
console_printf(Console_Default, "Loading FDS ROM...\t\t");
|
||||||
//fd = open("../data/disksys.rom", O_RDONLY);
|
fd = open("../data/disksys.rom", O_RDONLY);
|
||||||
fd = open("TI-NESulator.app/Contents/Resources/disksys.rom", O_RDONLY);
|
//fd = open("TI-NESulator.app/Contents/Resources/disksys.rom", O_RDONLY);
|
||||||
|
if (fd < 0)
|
||||||
|
{
|
||||||
|
console_printf(Console_Error, "Can't find FDS ROM...\n");
|
||||||
|
exit(-1);
|
||||||
|
}
|
||||||
|
|
||||||
FDSRom = mmap(NULL, 8*1024, PROT_READ, MAP_PRIVATE, fd, 0);
|
FDSRom = mmap(NULL, 8*1024, PROT_READ, MAP_PRIVATE, fd, 0);
|
||||||
console_printf(Console_Default, "%p [ OK ]\n", FDSRom);
|
console_printf(Console_Default, "%p [ OK ]\n", FDSRom);
|
||||||
@ -959,7 +953,7 @@ int main(int argc, char *argv[])
|
|||||||
exit(-1);
|
exit(-1);
|
||||||
}
|
}
|
||||||
|
|
||||||
DumpMemoryState();
|
DumpMemoryState(stdout);
|
||||||
|
|
||||||
if (Cart->Flags & iNES_4SCREEN)
|
if (Cart->Flags & iNES_4SCREEN)
|
||||||
{
|
{
|
||||||
@ -1033,7 +1027,7 @@ int main(int argc, char *argv[])
|
|||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
//END_OF_MAIN()
|
END_OF_MAIN()
|
||||||
|
|
||||||
/* Access directly to Memory pages *HACKISH* */
|
/* Access directly to Memory pages *HACKISH* */
|
||||||
extern byte *memory_pages[0xFF];
|
extern byte *memory_pages[0xFF];
|
||||||
@ -1091,7 +1085,7 @@ void Loop6502(quick6502_cpu *R)
|
|||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
if ( mapper_irqloop (ScanLine) )
|
if ( (mapper_irqloop) && ( mapper_irqloop (ScanLine) ) )
|
||||||
{
|
{
|
||||||
ret = Q6502_IRQ_SIGNAL;
|
ret = Q6502_IRQ_SIGNAL;
|
||||||
IRQScanHit = ScanLine;
|
IRQScanHit = ScanLine;
|
||||||
@ -1108,12 +1102,11 @@ void Loop6502(quick6502_cpu *R)
|
|||||||
ret = Q6502_NMI_SIGNAL;
|
ret = Q6502_NMI_SIGNAL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ScanLine == 239)
|
|
||||||
frame++;
|
|
||||||
|
|
||||||
if (ScanLine == (239 + VBLANK_TIME))
|
if (ScanLine == (239 + VBLANK_TIME))
|
||||||
{ /* End of VBlank Time */
|
{ /* End of VBlank Time */
|
||||||
|
frame++;
|
||||||
|
SZHit = -1;
|
||||||
|
IRQScanHit = -1;
|
||||||
/* Sync at 60FPS */
|
/* Sync at 60FPS */
|
||||||
/* Get current time in microseconds */
|
/* Get current time in microseconds */
|
||||||
gettimeofday(&timeEnd, NULL);
|
gettimeofday(&timeEnd, NULL);
|
||||||
@ -1129,7 +1122,7 @@ void Loop6502(quick6502_cpu *R)
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* If we press Page Up, we want to accelerate "time" */
|
/* If we press Page Up, we want to accelerate "time" */
|
||||||
if (!key[KEY_PGUP])
|
if ((!key[KEY_PGUP]) && (!key[KEY_Y]))
|
||||||
if ((WaitTime >= 0) && (WaitTime < 100000))
|
if ((WaitTime >= 0) && (WaitTime < 100000))
|
||||||
usleep(WaitTime);
|
usleep(WaitTime);
|
||||||
|
|
||||||
@ -1154,7 +1147,6 @@ void Loop6502(quick6502_cpu *R)
|
|||||||
else
|
else
|
||||||
ScanLine++;
|
ScanLine++;
|
||||||
|
|
||||||
|
|
||||||
//console_printf(Console_Default, "SL:%d HBT:%d VbT:%d\n", ScanLine, HBLANK_TIME, VBLANK_TIME);
|
//console_printf(Console_Default, "SL:%d HBT:%d VbT:%d\n", ScanLine, HBLANK_TIME, VBLANK_TIME);
|
||||||
if (keypressed())
|
if (keypressed())
|
||||||
{
|
{
|
||||||
|
|||||||
@ -50,12 +50,13 @@ void mapper_list ()
|
|||||||
int mapper_init (NesCart *cart)
|
int mapper_init (NesCart *cart)
|
||||||
{
|
{
|
||||||
Mapper *ptr = &(Mappers[0]);
|
Mapper *ptr = &(Mappers[0]);
|
||||||
console_printf (Console_Default, "Search for a compatible mapper ID #%X:\n", cart->MapperID);
|
console_printf (Console_Default, "Search for a compatible mapper ID #%d:\n", cart->MapperID);
|
||||||
while (ptr->name != NULL)
|
while (ptr->name != NULL)
|
||||||
{
|
{
|
||||||
if (ptr->id == cart->MapperID)
|
if (ptr->id == cart->MapperID)
|
||||||
{
|
{
|
||||||
console_printf (Console_Default, "Found mapper ID #%X - '%s'\n", ptr->id, ptr->name);
|
console_printf (Console_Default, "Found mapper ID #%d - '%s'\n", ptr->id, ptr->name);
|
||||||
|
if (ptr->init)
|
||||||
ptr->init (cart);
|
ptr->init (cart);
|
||||||
|
|
||||||
mapper_irqloop = ptr->irq;
|
mapper_irqloop = ptr->irq;
|
||||||
@ -65,5 +66,6 @@ int mapper_init (NesCart *cart)
|
|||||||
}
|
}
|
||||||
ptr++;
|
ptr++;
|
||||||
}
|
}
|
||||||
|
console_printf (Console_Default, "No compatible mapper found!\n");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -55,7 +55,7 @@ void aorom_MapperWriteHook(register byte Addr, register byte Value)
|
|||||||
|
|
||||||
aorom_load_bank = BankNb;
|
aorom_load_bank = BankNb;
|
||||||
|
|
||||||
//console_printf(Console_Default, "aorom: Asking bank %d (giving %d & %d) - mirror is %d\n",BankNb,BankNb,(Value<<1)+1,Value&0x0F);
|
console_printf(Console_Default, "aorom: Asking bank %d - NT is 0x%04X\n",BankNb,(Value&0x10)?0x2400:0x2000);
|
||||||
set_prom_bank_32k(0x8000,BankNb);
|
set_prom_bank_32k(0x8000,BankNb);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -116,7 +116,7 @@ void iremh3001_MapperDump(FILE *fp)
|
|||||||
iremh3001_vrom_slot[4],
|
iremh3001_vrom_slot[4],
|
||||||
iremh3001_vrom_slot[5],
|
iremh3001_vrom_slot[5],
|
||||||
iremh3001_vrom_slot[6],
|
iremh3001_vrom_slot[6],
|
||||||
iremh3001_prom_slot[7]);
|
iremh3001_vrom_slot[7]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -12,17 +12,17 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "norom.h"
|
#include "mmc1.h"
|
||||||
|
|
||||||
unsigned char MMC1_reg0;
|
uint8_t MMC1_reg0;
|
||||||
|
|
||||||
unsigned char MMC1_reg1;
|
uint8_t MMC1_reg1;
|
||||||
|
|
||||||
unsigned char MMC1_reg2;
|
uint8_t MMC1_reg2;
|
||||||
|
|
||||||
unsigned char MMC1_reg3;
|
uint8_t MMC1_reg3;
|
||||||
|
|
||||||
unsigned char mmc1_CurrentBank;
|
uint8_t mmc1_CurrentBank;
|
||||||
|
|
||||||
#define MMC1_R0_MIRROR 0x01
|
#define MMC1_R0_MIRROR 0x01
|
||||||
#define MMC1_R0_ONESCREEN 0x02
|
#define MMC1_R0_ONESCREEN 0x02
|
||||||
@ -135,7 +135,7 @@ Reg 0
|
|||||||
void mmc1_ApplyReg0Mod()
|
void mmc1_ApplyReg0Mod()
|
||||||
{
|
{
|
||||||
|
|
||||||
static unsigned char OldSwitchArea = MMC1_R0_PRGAREA;
|
static uint8_t OldSwitchArea = MMC1_R0_PRGAREA;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -182,9 +182,9 @@ void mmc1_ApplyReg0Mod()
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int VROMBankNb;
|
uint32_t VROMBankNb;
|
||||||
unsigned char Bit = 0;
|
uint8_t Bit = 0;
|
||||||
unsigned char BitBuf = 0;
|
uint8_t BitBuf = 0;
|
||||||
|
|
||||||
void mmc1_MapperWriteReg0(register byte Addr, register byte Value)
|
void mmc1_MapperWriteReg0(register byte Addr, register byte Value)
|
||||||
{
|
{
|
||||||
@ -321,7 +321,7 @@ void mmc1_MapperWriteReg3(register byte Addr, register byte Value)
|
|||||||
|
|
||||||
MMC1_reg3 = BitBuf;
|
MMC1_reg3 = BitBuf;
|
||||||
|
|
||||||
if (MMC1_reg3<<14 > Cart->PROMSize)
|
if ( ((uint32_t)MMC1_reg3 << 14) > Cart->PROMSize)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if ( (MMC1_reg0 & MMC1_R0_PRGSIZE) != 0 )
|
if ( (MMC1_reg0 & MMC1_R0_PRGSIZE) != 0 )
|
||||||
|
|||||||
@ -27,6 +27,7 @@ byte mmc4_RegF;
|
|||||||
#define LOG(s) { }
|
#define LOG(s) { }
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* MAPPER WARNING: This mapper need to attach to the PPU memory... Need more work on this parts.. */
|
||||||
|
|
||||||
void mmc4_MapperWriteRegA(register byte Addr, register byte Value)
|
void mmc4_MapperWriteRegA(register byte Addr, register byte Value)
|
||||||
{
|
{
|
||||||
|
|||||||
@ -32,10 +32,12 @@ Mapper Mappers[] = {
|
|||||||
|
|
||||||
{ 1 , "MMC1", mmc1_InitMapper, norom_MapperIRQ, mmc1_MapperDump },
|
{ 1 , "MMC1", mmc1_InitMapper, norom_MapperIRQ, mmc1_MapperDump },
|
||||||
{ 4 , "MMC3", mmc3_InitMapper, mmc3_MapperIRQ, mmc3_MapperDump },
|
{ 4 , "MMC3", mmc3_InitMapper, mmc3_MapperIRQ, mmc3_MapperDump },
|
||||||
{ 10, "MMC4", mmc3_InitMapper, norom_MapperIRQ, mmc4_MapperDump },
|
{ 10, "MMC4", mmc4_InitMapper, norom_MapperIRQ, mmc4_MapperDump },
|
||||||
|
|
||||||
{ 65, "Irem H3001", iremh3001_InitMapper, iremh3001_MapperIRQ, iremh3001_MapperDump },
|
{ 65, "Irem H3001", iremh3001_InitMapper, iremh3001_MapperIRQ, iremh3001_MapperDump },
|
||||||
|
|
||||||
|
|
||||||
|
{ 100, "Floppy Disk System", NULL, norom_MapperIRQ, norom_MapperDump },
|
||||||
/* EOL tag */
|
/* EOL tag */
|
||||||
{ 0, NULL, NULL, NULL, NULL }
|
{ 0, NULL, NULL, NULL, NULL }
|
||||||
};
|
};
|
||||||
|
|||||||
@ -40,7 +40,7 @@ byte memory_pages_attr[0x100];
|
|||||||
func_rdhook rdh_table[0x100];
|
func_rdhook rdh_table[0x100];
|
||||||
func_wrhook wrh_table[0x100];
|
func_wrhook wrh_table[0x100];
|
||||||
|
|
||||||
//#define DEBUG
|
#define DEBUG
|
||||||
#undef DEBUG
|
#undef DEBUG
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
|
|||||||
@ -9,4 +9,4 @@
|
|||||||
# $HeadURL$
|
# $HeadURL$
|
||||||
# $Revision$
|
# $Revision$
|
||||||
|
|
||||||
add_library(oslib loadfile.c)
|
add_library(oslib loadfile.c graphics.c sound.c io.c)
|
||||||
|
|||||||
29
src/os/unix/graphics.c
Normal file
29
src/os/unix/graphics.c
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
/*
|
||||||
|
* Graphic Manager - The TI-NESulator Project
|
||||||
|
* os/macos/graphics.c
|
||||||
|
*
|
||||||
|
* Created by Manoel TRAPIER on 08/05/08.
|
||||||
|
* Copyright (c) 2003-2008 986Corp. All rights reserved.
|
||||||
|
*
|
||||||
|
* $LastChangedDate$
|
||||||
|
* $Author$
|
||||||
|
* $HeadURL$
|
||||||
|
* $Revision$
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#include <os_dependent.h>
|
||||||
|
|
||||||
|
int graphics_init()
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int graphics_drawpixel(long x, long y, long color)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int graphics_blit(long x, long y, long w, long h)
|
||||||
|
{
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
61
src/os/unix/io.c
Normal file
61
src/os/unix/io.c
Normal file
@ -0,0 +1,61 @@
|
|||||||
|
/*
|
||||||
|
* IO Manager - The TI-NESulator Project
|
||||||
|
* os/macos/graphics.c
|
||||||
|
*
|
||||||
|
* Created by Manoël Trapier on 04/01/09.
|
||||||
|
* Copyright (c) 2003-2009 986 Corp. All rights reserved.
|
||||||
|
*
|
||||||
|
* $LastChangedDate$
|
||||||
|
* $Author$
|
||||||
|
* $HeadURL$
|
||||||
|
* $Revision$
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdarg.h>
|
||||||
|
|
||||||
|
#include <os_dependent.h>
|
||||||
|
|
||||||
|
char LevelChar[] = { 'E', 'W', 'A', 'N', 'V', 'D'};
|
||||||
|
|
||||||
|
ConsoleLevel console_ActualLevel = Console_Default;
|
||||||
|
|
||||||
|
/* Actually nothing to do */
|
||||||
|
int console_init(ConsoleLevel DefaultLevel)
|
||||||
|
{
|
||||||
|
console_ActualLevel = DefaultLevel;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Actually a simple printf with levels */
|
||||||
|
int console_vprintf(const ConsoleLevel level, const char *format, va_list ap)
|
||||||
|
{
|
||||||
|
if (console_ActualLevel >= level)
|
||||||
|
vprintf(format, ap);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int console_printf(const ConsoleLevel level, const char *format, ...)
|
||||||
|
{
|
||||||
|
int ret = 0;
|
||||||
|
va_list ap;
|
||||||
|
va_start(ap, format);
|
||||||
|
|
||||||
|
ret = console_vprintf(level, format, ap);
|
||||||
|
|
||||||
|
va_end(ap);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int console_printf_d(const char *format, ...)
|
||||||
|
{
|
||||||
|
va_list ap;
|
||||||
|
va_start(ap, format);
|
||||||
|
|
||||||
|
console_vprintf (Console_Debug, format, ap);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
0
src/os/unix/sound.c
Normal file
0
src/os/unix/sound.c
Normal file
@ -355,8 +355,8 @@ void ppu_dumpPalette(int x, int y)
|
|||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
textout(Buffer, font, "Bg Palette", x , y, 5);
|
textout_ex(Buffer, font, "Bg Palette", x , y, 5, 0);
|
||||||
textout(Buffer, font, "Sprt Palette", x + 90, y, 5);
|
textout_ex(Buffer, font, "Sprt Palette", x + 90, y, 5, 0);
|
||||||
|
|
||||||
rect(Buffer, x+0, y+20, x+4 * 20 + 2, y + 4 * 20 + 22, 0);
|
rect(Buffer, x+0, y+20, x+4 * 20 + 2, y + 4 * 20 + 22, 0);
|
||||||
rect(Buffer, x+90, y+20, x+90 + 4 * 20 + 2, y + 4 * 20 + 22, 0);
|
rect(Buffer, x+90, y+20, x+90 + 4 * 20 + 2, y + 4 * 20 + 22, 0);
|
||||||
|
|||||||
@ -25,6 +25,7 @@
|
|||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
#include <stdint.h>
|
||||||
|
|
||||||
#define __TINES_PPU_INTERNAL__
|
#define __TINES_PPU_INTERNAL__
|
||||||
#include <ppu/ppu.h>
|
#include <ppu/ppu.h>
|
||||||
@ -47,6 +48,7 @@ volatile extern unsigned long IPS, FPS;
|
|||||||
|
|
||||||
extern unsigned long ColorPalette[ 9 * 63 ];
|
extern unsigned long ColorPalette[ 9 * 63 ];
|
||||||
extern short IRQScanHit;
|
extern short IRQScanHit;
|
||||||
|
extern short SZHit;
|
||||||
|
|
||||||
BITMAP *VideoBuffer; /* The ppu will only write pixel to this, and then bliting
|
BITMAP *VideoBuffer; /* The ppu will only write pixel to this, and then bliting
|
||||||
this on the screen "surface" */
|
this on the screen "surface" */
|
||||||
@ -272,8 +274,9 @@ int ppu_init()
|
|||||||
|
|
||||||
void ppu_updateSpriteScanlineTable()
|
void ppu_updateSpriteScanlineTable()
|
||||||
{
|
{
|
||||||
int i, line, j, k;
|
int32_t i,j,k;
|
||||||
volatile int sprite_x, sprite_y, sprite_idx, sprite_attr;
|
int line;
|
||||||
|
volatile int32_t sprite_x, sprite_y, sprite_idx, sprite_attr;
|
||||||
|
|
||||||
int curline;
|
int curline;
|
||||||
|
|
||||||
@ -312,11 +315,11 @@ void ppu_updateSpriteScanlineTable()
|
|||||||
if (((sprite_x+8) < 0) && ((sprite_x-8) > 256))
|
if (((sprite_x+8) < 0) && ((sprite_x-8) > 256))
|
||||||
continue; /* this sprite isn't either displayable */
|
continue; /* this sprite isn't either displayable */
|
||||||
/* Now test if this sprite can be put in the sprite list */
|
/* Now test if this sprite can be put in the sprite list */
|
||||||
for (j = 0; j <= PPU_NbSpriteByScanLine[curline]; j++)
|
for (j = 0; j <= (int32_t)PPU_NbSpriteByScanLine[curline]; j++)
|
||||||
{
|
{
|
||||||
/* sprite are ordered by their y value, so, the first time that
|
/* sprite are ordered by their y value, so, the first time that
|
||||||
we have lower y value is where we need to put the sprite */
|
we have lower y value is where we need to put the sprite */
|
||||||
if (sprite_x < PPU_SCANLINESPRITE_GET_X(PPU_SpriteByScanLine[curline][j]))
|
if (sprite_x < (int32_t)PPU_SCANLINESPRITE_GET_X(PPU_SpriteByScanLine[curline][j]))
|
||||||
{
|
{
|
||||||
/* move the j eme item and next to the right in the list, trashing
|
/* move the j eme item and next to the right in the list, trashing
|
||||||
if needed the rightest item. */
|
if needed the rightest item. */
|
||||||
@ -477,21 +480,23 @@ _AAA BCDD DDDE EEEE
|
|||||||
|
|
||||||
int ppu_hblank(int scanline)
|
int ppu_hblank(int scanline)
|
||||||
{
|
{
|
||||||
int i, j;
|
uint32_t i, j;
|
||||||
byte pixelColor = 0x42;
|
byte pixelColor = 0x42;
|
||||||
byte BgColor = 0x42;
|
byte BgColor = 0x42;
|
||||||
byte SpriteColor = 0x42;
|
byte SpriteColor = 0x42;
|
||||||
unsigned short addr;
|
uint16_t addr;
|
||||||
byte value;
|
byte value;
|
||||||
unsigned short tmp_HHT = 0;
|
uint16_t tmp_HHT = 0;
|
||||||
unsigned short tmp_VVTFV = 0;
|
uint16_t tmp_VVTFV = 0;
|
||||||
unsigned long CurrentSprite;
|
uint32_t CurrentSprite;
|
||||||
byte SpriteVFlip;
|
byte SpriteVFlip;
|
||||||
|
|
||||||
if (scanline == 0)
|
if (scanline == 0)
|
||||||
{
|
{
|
||||||
ppu_bgColor = ppu_readMemory(0x3F,00);
|
ppu_bgColor = ppu_readMemory(0x3F,00);
|
||||||
|
|
||||||
|
rectfill(Buffer, 256, 0, 277, 260, ppu_bgColor);
|
||||||
|
|
||||||
if ((ppu_spriteVisibility != 0) || (ppu_backgroundVisibility != 0))
|
if ((ppu_spriteVisibility != 0) || (ppu_backgroundVisibility != 0))
|
||||||
ppu_updateCounters();
|
ppu_updateCounters();
|
||||||
}
|
}
|
||||||
@ -621,7 +626,12 @@ int ppu_hblank(int scanline)
|
|||||||
if ((PPU_SCANLINESPRITE_GET_ATTRS(CurrentSprite) & 0x04) &&
|
if ((PPU_SCANLINESPRITE_GET_ATTRS(CurrentSprite) & 0x04) &&
|
||||||
(SpriteColor != 0x00) && (BgColor != 0x00))
|
(SpriteColor != 0x00) && (BgColor != 0x00))
|
||||||
{
|
{
|
||||||
ppu_spriteZeroHit = 1;
|
if (!ppu_spriteZeroHit)
|
||||||
|
{
|
||||||
|
ppu_spriteZeroHit = (ppu_backgroundVisibility)?1:0;
|
||||||
|
if (ppu_spriteZeroHit)
|
||||||
|
SZHit = scanline;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if ( ( (PPU_SCANLINESPRITE_GET_ATTRS(CurrentSprite) & PPU_SPRITE_FLAGS_BGPRIO) && (BgColor == 0x0000)) ||
|
if ( ( (PPU_SCANLINESPRITE_GET_ATTRS(CurrentSprite) & PPU_SPRITE_FLAGS_BGPRIO) && (BgColor == 0x0000)) ||
|
||||||
(!(PPU_SCANLINESPRITE_GET_ATTRS(CurrentSprite) & PPU_SPRITE_FLAGS_BGPRIO)) )
|
(!(PPU_SCANLINESPRITE_GET_ATTRS(CurrentSprite) & PPU_SPRITE_FLAGS_BGPRIO)) )
|
||||||
@ -645,7 +655,6 @@ int ppu_hblank(int scanline)
|
|||||||
|
|
||||||
//blit(VideoBuffer, screen, 0, scanline, 0, scanline, 256, 1);
|
//blit(VideoBuffer, screen, 0, scanline, 0, scanline, 256, 1);
|
||||||
|
|
||||||
|
|
||||||
if (ppu_backgroundVisibility == 1)
|
if (ppu_backgroundVisibility == 1)
|
||||||
{
|
{
|
||||||
|
|
||||||
@ -697,8 +706,7 @@ E = HT
|
|||||||
if (scanline == 239)
|
if (scanline == 239)
|
||||||
{
|
{
|
||||||
ppu_inVBlankTime = 1;
|
ppu_inVBlankTime = 1;
|
||||||
|
textprintf_ex(Buffer, font, 260, 3, 4, 0, "FPS : %ld (CPU@~%2.2fMhz : %d%%)", FPS, (float) (((float) IPS) / 1000000.0), (int) ((((float) IPS) / 1770000.0) * 100.0));
|
||||||
textprintf(Buffer, font, 260, 3, 4, "FPS : %ld (CPU@~%2.2fMhz : %d%%)", FPS, (float) (((float) IPS) / 1000000.0), (int) ((((float) IPS) / 1770000.0) * 100.0));
|
|
||||||
|
|
||||||
blit(VideoBuffer, Buffer, 0, 0, 0, 0, 256, 240);
|
blit(VideoBuffer, Buffer, 0, 0, 0, 0, 256, 240);
|
||||||
blit(Buffer, screen, 0, 0, 0, 0, 512+256, 512);
|
blit(Buffer, screen, 0, 0, 0, 0, 512+256, 512);
|
||||||
@ -706,14 +714,27 @@ E = HT
|
|||||||
return ppu_execNMIonVBlank;
|
return ppu_execNMIonVBlank;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (scanline == SZHit)
|
||||||
|
{
|
||||||
|
line(Buffer, 257, scanline, 267, scanline, 0x12);
|
||||||
|
line(Buffer, 257, scanline, 260, scanline-2, 0x12);
|
||||||
|
line(Buffer, 257, scanline, 260, scanline+2, 0x12);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (scanline == IRQScanHit)
|
||||||
|
{
|
||||||
|
line(Buffer, 267, scanline, 277, scanline, 0x13);
|
||||||
|
line(Buffer, 267, scanline, 270, scanline-2, 0x13);
|
||||||
|
line(Buffer, 267, scanline, 270, scanline+2, 0x13);
|
||||||
|
}
|
||||||
|
|
||||||
if (key[KEY_B])
|
if (key[KEY_B])
|
||||||
{
|
{
|
||||||
blit(VideoBuffer, Buffer, 0, 0, 0, 0, 256, 240);
|
blit(VideoBuffer, Buffer, 0, 0, 0, 0, 256, 240);
|
||||||
blit(Buffer, screen, 0, 0, 0, 0, 512 + 256, 480);
|
blit(Buffer, screen, 0, 0, 0, 0, 512 + 256, 480);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (scanline == (239 + VBLANK_TIME)+0)
|
||||||
if (scanline == (239 + VBLANK_TIME))
|
|
||||||
{
|
{
|
||||||
ppu_inVBlankTime = 0;
|
ppu_inVBlankTime = 0;
|
||||||
ppu_spriteZeroHit = 0;
|
ppu_spriteZeroHit = 0;
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user