2018-02-14 13:03:15 -05:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
|
|
|
|
#include "6502_emulate.h"
|
|
|
|
|
|
|
|
/* 128kB of RAM */
|
|
|
|
#define RAMSIZE 128*1024
|
|
|
|
unsigned char ram[RAMSIZE];
|
|
|
|
|
|
|
|
/* Registers */
|
|
|
|
unsigned char a,y,x;
|
2018-02-14 13:10:01 -05:00
|
|
|
unsigned short sp;
|
|
|
|
|
|
|
|
/* Flags */
|
|
|
|
unsigned int n,z,c,v;
|
|
|
|
|
|
|
|
int init_6502(void) {
|
|
|
|
|
|
|
|
a=0;
|
|
|
|
y=0;
|
|
|
|
x=0;
|
|
|
|
|
|
|
|
sp=0x1ff;
|
|
|
|
|
|
|
|
n=0; z=0; c=0; v=0;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
}
|
2018-02-14 13:03:15 -05:00
|
|
|
|
|
|
|
unsigned short y_indirect(unsigned char base, unsigned char y) {
|
|
|
|
|
|
|
|
unsigned short addr;
|
|
|
|
|
|
|
|
addr=(((short)(ram[base+1]))<<8) | (short)ram[base];
|
|
|
|
|
|
|
|
//if (debug) printf("Address=%x\n",addr+y);
|
|
|
|
|
|
|
|
return addr+y;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2018-02-14 13:10:01 -05:00
|
|
|
void adc(int value) {
|
|
|
|
|
|
|
|
int temp_a;
|
|
|
|
int temp_value;
|
|
|
|
int result;
|
|
|
|
|
|
|
|
temp_a=a&0xff;
|
|
|
|
temp_value=value&0xff;
|
|
|
|
|
|
|
|
result=(temp_a+temp_value+c);
|
|
|
|
|
|
|
|
c=(result&0x100)>>8;
|
|
|
|
n=(result&0x80)>>7;
|
|
|
|
|
|
|
|
v=!!((a^result)&(value^result)&0x80);
|
|
|
|
|
|
|
|
a=result&0xff;
|
|
|
|
z=(a==0);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
void sbc(int value) {
|
|
|
|
int temp_a;
|
|
|
|
int result;
|
|
|
|
int temp_value;
|
|
|
|
|
|
|
|
temp_a=a&0xff;
|
2018-02-14 14:09:54 -05:00
|
|
|
temp_value=(~value)&0xff;
|
|
|
|
|
|
|
|
result=temp_a+temp_value+c;
|
2018-02-14 13:10:01 -05:00
|
|
|
|
2018-02-14 14:09:54 -05:00
|
|
|
// printf("SBC: %x - %x (%x) = %x\n",a,value,c,result);
|
2018-02-14 13:10:01 -05:00
|
|
|
|
|
|
|
c=(result&0x100)>>8;
|
|
|
|
n=(result&0x80)>>7;
|
|
|
|
|
|
|
|
v=!!((a^result)&((255-value)^result)&0x80);
|
|
|
|
|
|
|
|
a=result&0xff;
|
|
|
|
z=(a==0);
|
2018-02-14 14:09:54 -05:00
|
|
|
|
|
|
|
|
2018-02-14 13:10:01 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
void cmp(int value) {
|
|
|
|
|
|
|
|
int temp_a;
|
|
|
|
int temp_value;
|
2018-02-14 15:30:57 -05:00
|
|
|
int result;
|
2018-02-14 13:10:01 -05:00
|
|
|
|
|
|
|
temp_a=a&0xff;
|
2018-02-14 15:30:57 -05:00
|
|
|
temp_value=(~value)&0xff;
|
|
|
|
|
|
|
|
result=temp_a+temp_value+1;
|
|
|
|
|
|
|
|
c=(result&0x100)>>8;
|
|
|
|
|
|
|
|
result&=0xff;
|
|
|
|
|
|
|
|
n=(result&0x80)>>7;
|
|
|
|
z=(result==0);
|
2018-02-14 13:10:01 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
void pha(void) {
|
|
|
|
|
|
|
|
sp--;
|
|
|
|
ram[sp]=a;
|
|
|
|
}
|
|
|
|
|
|
|
|
void pla(void) {
|
|
|
|
|
|
|
|
a=ram[sp];
|
|
|
|
sp++;
|
|
|
|
}
|
2018-02-14 15:30:57 -05:00
|
|
|
|
|
|
|
void lsr(void) {
|
|
|
|
int temp_a;
|
|
|
|
|
|
|
|
temp_a=a;
|
|
|
|
temp_a&=0xff;
|
|
|
|
|
2018-07-01 23:06:08 -04:00
|
|
|
c=temp_a&0x1;
|
|
|
|
temp_a=temp_a>>1;
|
2018-02-14 15:30:57 -05:00
|
|
|
a=(temp_a&0xff);
|
2018-07-01 23:06:08 -04:00
|
|
|
z=(a==0);
|
|
|
|
n=!!(a&0x80);
|
2018-02-14 15:30:57 -05:00
|
|
|
// printf("LSR A=%x\n",a);
|
|
|
|
}
|
2018-02-23 00:16:43 -05:00
|
|
|
|
2018-07-01 23:06:08 -04:00
|
|
|
void asl(void) {
|
|
|
|
int temp_a;
|
|
|
|
|
|
|
|
temp_a=a;
|
|
|
|
temp_a&=0xff;
|
|
|
|
|
|
|
|
c=!!(temp_a&0x80);
|
|
|
|
|
|
|
|
temp_a=temp_a<<1;
|
|
|
|
a=(temp_a&0xff);
|
|
|
|
z=(a==0);
|
|
|
|
n=!!(a&0x80);
|
|
|
|
// printf("ASL A=%x\n",a);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void ror(void) {
|
|
|
|
int temp_a;
|
|
|
|
int old_c;
|
|
|
|
|
|
|
|
old_c=c;
|
|
|
|
temp_a=a;
|
|
|
|
temp_a&=0xff;
|
|
|
|
|
|
|
|
c=temp_a&0x1;
|
|
|
|
temp_a=temp_a>>1;
|
|
|
|
a=(temp_a&0xff);
|
|
|
|
a|=old_c<<7;
|
|
|
|
|
|
|
|
z=(a==0);
|
|
|
|
n=!!(a&0x80);
|
|
|
|
// printf("ROR A=%x\n",a);
|
|
|
|
}
|
|
|
|
|
|
|
|
void rol(void) {
|
|
|
|
int temp_a;
|
|
|
|
int old_c;
|
|
|
|
|
|
|
|
old_c=c;
|
|
|
|
temp_a=a;
|
|
|
|
temp_a&=0xff;
|
|
|
|
|
|
|
|
c=!!(temp_a&0x80);
|
|
|
|
|
|
|
|
temp_a=temp_a<<1;
|
|
|
|
a=(temp_a&0xff);
|
|
|
|
a|=old_c;
|
|
|
|
|
|
|
|
z=(a==0);
|
|
|
|
n=!!(a&0x80);
|
|
|
|
// printf("ROL A=%x\n",a);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void ror_mem(int addr) {
|
|
|
|
int temp_a;
|
|
|
|
int old_c;
|
|
|
|
|
|
|
|
old_c=c;
|
|
|
|
temp_a=ram[addr];
|
|
|
|
temp_a&=0xff;
|
|
|
|
|
|
|
|
c=temp_a&0x1;
|
|
|
|
temp_a=temp_a>>1;
|
|
|
|
ram[addr]=(temp_a&0xff);
|
|
|
|
ram[addr]|=old_c<<7;
|
|
|
|
|
|
|
|
z=(ram[addr]==0);
|
|
|
|
n=!!(ram[addr]&0x80);
|
|
|
|
// printf("ROR %x=%x\n",addr,ram[addr]);
|
|
|
|
}
|
|
|
|
|
|
|
|
void rol_mem(int addr) {
|
|
|
|
int temp_a;
|
|
|
|
int old_c;
|
|
|
|
|
|
|
|
old_c=c;
|
|
|
|
temp_a=ram[addr];
|
|
|
|
temp_a&=0xff;
|
|
|
|
|
|
|
|
c=!!(temp_a&0x80);
|
|
|
|
|
|
|
|
temp_a=temp_a<<1;
|
|
|
|
ram[addr]=(temp_a&0xff);
|
|
|
|
ram[addr]|=old_c;
|
|
|
|
|
|
|
|
z=(ram[addr]==0);
|
|
|
|
n=!!(ram[addr]&0x80);
|
|
|
|
// printf("ROL %x=%x\n",addr,ram[addr]);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2018-02-23 00:16:43 -05:00
|
|
|
unsigned char high(int value) {
|
|
|
|
return (value>>8)&0xff;
|
|
|
|
}
|
|
|
|
|
|
|
|
unsigned char low(int value) {
|
|
|
|
return (value&0xff);
|
|
|
|
}
|
|
|
|
|