mirror of
https://github.com/mist64/perfect6502.git
synced 2025-01-14 13:30:02 +00:00
68 lines
1.4 KiB
C
68 lines
1.4 KiB
C
#include <stdio.h>
|
|
#include <strings.h>
|
|
#include "perfect6502.h"
|
|
|
|
extern void init_monitor();
|
|
|
|
typedef unsigned char uint8_t;
|
|
typedef unsigned short uint16_t;
|
|
typedef unsigned int BOOL;
|
|
|
|
#define YES 1
|
|
#define NO 0
|
|
|
|
#define MAX_CYCLES 33000
|
|
BOOL log_rw[MAX_CYCLES];
|
|
uint16_t log_ab[MAX_CYCLES];
|
|
uint8_t log_db[MAX_CYCLES];
|
|
int
|
|
main()
|
|
{
|
|
initAndResetChip();
|
|
printf("%d\n", transistors);
|
|
int stransistors = transistors;
|
|
for (int run = -1; run < stransistors; run ++) {
|
|
#if 0
|
|
/* skip a few runs! */
|
|
if (run == 0)
|
|
run = 180;
|
|
#endif
|
|
|
|
if (run != -1) {
|
|
printf("testing transistor %d: ", run);
|
|
broken_transistor = run;
|
|
}
|
|
|
|
bzero(memory, 65536);
|
|
init_monitor();
|
|
resetChip();
|
|
BOOL fail = NO;
|
|
for (int c = 0; c < MAX_CYCLES; c++) {
|
|
step();
|
|
if (run == -1) {
|
|
log_rw[c] = cycle & 1;
|
|
log_ab[c] = readAddressBus();
|
|
log_db[c] = readDataBus();
|
|
} else {
|
|
if (log_rw[c] != (cycle & 1)) {
|
|
printf("FAIL, RW %d instead of %d @ %d\n", cycle & 1, log_rw[c], c);
|
|
fail = YES;
|
|
break;
|
|
}
|
|
if (log_ab[c] != readAddressBus()) {
|
|
printf("FAIL, AB 0x%04x instead of 0x%04x @ %d\n", readAddressBus(), log_ab[c], c);
|
|
fail = YES;
|
|
break;
|
|
}
|
|
if (log_db[c] != readDataBus()) {
|
|
printf("FAIL, DB 0x%02x instead of 0x%02x @ %d\n", readDataBus(), log_db[c], c);
|
|
fail = YES;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
if (run != -1 && !fail)
|
|
printf("PASS\n");
|
|
}
|
|
}
|