mirror of
https://github.com/makarcz/vm6502.git
synced 2025-04-10 21:40:53 +00:00
Version 2.0, full emulation of 6502 op-codes, fully tested and functional. Extended description in ReadMe file. Bin2Hex tool to convert binary images to memory definition format. Microchess, EhBasic added.
57 lines
1.3 KiB
C
57 lines
1.3 KiB
C
|
|
#include <stdlib.h>
|
|
#include <stdio.h>
|
|
#include <string.h>
|
|
|
|
|
|
unsigned char conv2bcd(unsigned short v)
|
|
{
|
|
unsigned char arg8 = 0;
|
|
arg8 = (unsigned char)((v/10) << 4);
|
|
arg8 |= ((unsigned char)(v - (v/10)*10)) & 0x0F;
|
|
return arg8;
|
|
}
|
|
|
|
char *conv24bitbin(unsigned char v)
|
|
{
|
|
static char retbuf[5];
|
|
int i=3;
|
|
|
|
memset(retbuf, '0', 4);
|
|
retbuf[4]=0;
|
|
if (v == 0) return retbuf;
|
|
while (v > 0 && i >= 0) {
|
|
int r = v % 2;
|
|
retbuf[i] = ((r==0) ? '0' : '1');
|
|
v = v/2;
|
|
i--;
|
|
}
|
|
|
|
return retbuf;
|
|
}
|
|
|
|
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
|
|
|
|
int main(int argc, char *argv[])
|
|
{
|
|
unsigned short v = 0;
|
|
|
|
for (v = 0; v < 100; v++) {
|
|
unsigned char cv = conv2bcd(v), hinyb, lonyb;
|
|
hinyb = (cv & 0xF0) >> 4;
|
|
lonyb = cv & 0x0F;
|
|
char buf_hinyb[5], buf_lonyb[5];
|
|
strcpy(buf_hinyb, conv24bitbin(hinyb));
|
|
strcpy(buf_lonyb, conv24bitbin(lonyb));
|
|
printf("%d (dec) \t= %4s(%d) %4s(%d) (BCD, dec:%d)\n", v,
|
|
buf_hinyb,
|
|
hinyb,
|
|
buf_lonyb,
|
|
lonyb,
|
|
cv);
|
|
}
|
|
|
|
return 0;
|
|
}
|
|
|