2019-07-30 08:05:21 +00:00
|
|
|
//
|
|
|
|
// main.c
|
|
|
|
// 6502
|
|
|
|
//
|
|
|
|
// Created by Tamas Rudnai on 7/14/19.
|
|
|
|
// Copyright © 2019 GameAlloy. All rights reserved.
|
|
|
|
//
|
|
|
|
|
|
|
|
#ifndef __6502_INSTR_BRANCH_H__
|
|
|
|
#define __6502_INSTR_BRANCH_H__
|
|
|
|
|
2019-09-10 07:00:00 +00:00
|
|
|
static inline void BRA( int8_t reladdr ) {
|
2019-07-30 08:05:21 +00:00
|
|
|
m6502.pc += reladdr;
|
2019-09-11 07:11:45 +00:00
|
|
|
dbgPrintf("BRA %04X ", m6502.pc);
|
2019-07-30 08:05:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
BCC Branch on Carry Clear
|
|
|
|
|
|
|
|
branch on C = 0 N Z C I D V
|
2019-09-10 07:00:00 +00:00
|
|
|
- - - - - -
|
2019-07-30 08:05:21 +00:00
|
|
|
|
|
|
|
addressing assembler opc bytes cyles
|
|
|
|
--------------------------------------------
|
|
|
|
relative BCC oper 90 2 2**
|
|
|
|
**/
|
|
|
|
static inline void BCC( int8_t reladdr ) {
|
|
|
|
dbgPrintf("BCC ");
|
2019-09-11 07:11:45 +00:00
|
|
|
if ( m6502.flags.C == 0 ) {
|
2019-09-10 07:00:00 +00:00
|
|
|
BRA( reladdr );
|
2019-09-11 07:11:45 +00:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
dbgPrintf("-no-");
|
|
|
|
}
|
2019-07-30 08:05:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
BCS Branch on Carry Set
|
|
|
|
|
|
|
|
branch on C = 1 N Z C I D V
|
2019-09-10 07:00:00 +00:00
|
|
|
- - - - - -
|
2019-07-30 08:05:21 +00:00
|
|
|
|
|
|
|
addressing assembler opc bytes cyles
|
|
|
|
--------------------------------------------
|
|
|
|
relative BCS oper B0 2 2**
|
|
|
|
**/
|
|
|
|
static inline void BCS( int8_t reladdr ) {
|
|
|
|
dbgPrintf("BCS ");
|
2019-09-11 07:11:45 +00:00
|
|
|
if ( m6502.flags.C == 1 ) {
|
2019-09-10 07:00:00 +00:00
|
|
|
BRA( reladdr );
|
2019-09-11 07:11:45 +00:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
dbgPrintf("-no-");
|
|
|
|
}
|
2019-07-30 08:05:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
BNE Branch on Result not Zero
|
|
|
|
|
|
|
|
branch on Z = 0 N Z C I D V
|
2019-09-10 07:00:00 +00:00
|
|
|
- - - - - -
|
2019-07-30 08:05:21 +00:00
|
|
|
|
|
|
|
addressing assembler opc bytes cyles
|
|
|
|
--------------------------------------------
|
|
|
|
relative BNE oper D0 2 2**
|
|
|
|
**/
|
|
|
|
static inline void BNE( int8_t reladdr ) {
|
|
|
|
dbgPrintf("BNE ");
|
2019-09-11 07:11:45 +00:00
|
|
|
if ( m6502.flags.Z == 0 ) {
|
2019-09-10 07:00:00 +00:00
|
|
|
BRA( reladdr );
|
2019-09-11 07:11:45 +00:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
dbgPrintf("-no-");
|
|
|
|
}
|
2019-07-30 08:05:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
BEQ Branch on Result Zero
|
|
|
|
|
|
|
|
branch on Z = 1 N Z C I D V
|
2019-09-10 07:00:00 +00:00
|
|
|
- - - - - -
|
2019-07-30 08:05:21 +00:00
|
|
|
|
|
|
|
addressing assembler opc bytes cyles
|
|
|
|
--------------------------------------------
|
|
|
|
relative BEQ oper F0 2 2**
|
|
|
|
**/
|
|
|
|
static inline void BEQ( int8_t reladdr ) {
|
|
|
|
dbgPrintf("BEQ ");
|
2019-09-11 07:11:45 +00:00
|
|
|
if ( m6502.flags.Z == 1 ) {
|
2019-09-10 07:00:00 +00:00
|
|
|
BRA( reladdr );
|
2019-09-11 07:11:45 +00:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
dbgPrintf("-no-");
|
|
|
|
}
|
2019-07-30 08:05:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
BPL Branch on Result Plus
|
|
|
|
|
|
|
|
branch on N = 0 N Z C I D V
|
2019-09-10 07:00:00 +00:00
|
|
|
- - - - - -
|
2019-07-30 08:05:21 +00:00
|
|
|
|
|
|
|
addressing assembler opc bytes cyles
|
|
|
|
--------------------------------------------
|
|
|
|
relative BPL oper 10 2 2**
|
|
|
|
**/
|
|
|
|
static inline void BPL( int8_t reladdr ) {
|
|
|
|
dbgPrintf("BPL ");
|
2019-09-11 07:11:45 +00:00
|
|
|
if ( m6502.flags.N == 0 ) {
|
2019-09-10 07:00:00 +00:00
|
|
|
BRA( reladdr );
|
2019-09-11 07:11:45 +00:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
dbgPrintf("-no-");
|
|
|
|
}
|
2019-07-30 08:05:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
BMI Branch on Result Minus
|
|
|
|
|
|
|
|
branch on N = 1 N Z C I D V
|
2019-09-10 07:00:00 +00:00
|
|
|
- - - - - -
|
2019-07-30 08:05:21 +00:00
|
|
|
|
|
|
|
addressing assembler opc bytes cyles
|
|
|
|
--------------------------------------------
|
|
|
|
relative BMI oper 30 2 2**
|
|
|
|
**/
|
|
|
|
static inline void BMI( int8_t reladdr ) {
|
|
|
|
dbgPrintf("BMI ");
|
2019-09-11 07:11:45 +00:00
|
|
|
if ( m6502.flags.N == 1 ) {
|
2019-09-10 07:00:00 +00:00
|
|
|
BRA( reladdr );
|
2019-09-11 07:11:45 +00:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
dbgPrintf("-no-");
|
|
|
|
}
|
2019-07-30 08:05:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
BVC Branch on Overflow Clear
|
|
|
|
|
|
|
|
branch on V = 0 N Z C I D V
|
2019-09-10 07:00:00 +00:00
|
|
|
- - - - - -
|
2019-07-30 08:05:21 +00:00
|
|
|
|
|
|
|
addressing assembler opc bytes cyles
|
|
|
|
--------------------------------------------
|
|
|
|
relative BVC oper 50 2 2**
|
|
|
|
**/
|
|
|
|
static inline void BVC( int8_t reladdr ) {
|
|
|
|
dbgPrintf("BVC ");
|
2019-09-11 07:11:45 +00:00
|
|
|
if ( m6502.flags.V == 0 ) {
|
2019-09-10 07:00:00 +00:00
|
|
|
BRA( reladdr );
|
2019-09-11 07:11:45 +00:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
dbgPrintf("-no-");
|
|
|
|
}
|
2019-07-30 08:05:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
BVS Branch on Overflow Set
|
|
|
|
|
|
|
|
branch on V = 1 N Z C I D V
|
2019-09-10 07:00:00 +00:00
|
|
|
- - - - - -
|
2019-07-30 08:05:21 +00:00
|
|
|
|
|
|
|
addressing assembler opc bytes cyles
|
|
|
|
--------------------------------------------
|
|
|
|
relative BVC oper 70 2 2**
|
|
|
|
**/
|
|
|
|
static inline void BVS( int8_t reladdr ) {
|
|
|
|
dbgPrintf("BVS ");
|
2019-09-11 07:11:45 +00:00
|
|
|
if ( m6502.flags.V == 1 ) {
|
2019-09-10 07:00:00 +00:00
|
|
|
BRA( reladdr );
|
2019-09-11 07:11:45 +00:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
dbgPrintf("-no-");
|
|
|
|
}
|
2019-07-30 08:05:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif // __6502_INSTR_BRANCH_H__
|