mirror of
https://github.com/DavidBuchanan314/6502-emu.git
synced 2025-01-14 00:31:32 +00:00
Only try interpreting control sequences in interactive mode
This commit is contained in:
parent
e9cdef2b48
commit
8905c49b98
@ -175,7 +175,7 @@ int main(int argc, char *argv[])
|
|||||||
}
|
}
|
||||||
|
|
||||||
//init_tables();
|
//init_tables();
|
||||||
init_uart();
|
init_uart(interactive);
|
||||||
|
|
||||||
reset_cpu(a, x, y, sp, sr, pc);
|
reset_cpu(a, x, y, sp, sr, pc);
|
||||||
run_cpu(cycles, verbose, mem_dump, break_pc, fast);
|
run_cpu(cycles, verbose, mem_dump, break_pc, fast);
|
||||||
|
8
6850.c
8
6850.c
@ -9,8 +9,9 @@
|
|||||||
static int n;
|
static int n;
|
||||||
static union UartStatusReg uart_SR;
|
static union UartStatusReg uart_SR;
|
||||||
static uint8_t incoming_char;
|
static uint8_t incoming_char;
|
||||||
|
static int interactive;
|
||||||
|
|
||||||
void init_uart() {
|
void init_uart(int is_interactive) {
|
||||||
memory[DATA_ADDR] = 0;
|
memory[DATA_ADDR] = 0;
|
||||||
|
|
||||||
uart_SR.byte = 0;
|
uart_SR.byte = 0;
|
||||||
@ -19,6 +20,7 @@ void init_uart() {
|
|||||||
uart_SR.bits.RDRF = 0;
|
uart_SR.bits.RDRF = 0;
|
||||||
incoming_char = 0;
|
incoming_char = 0;
|
||||||
|
|
||||||
|
interactive = is_interactive;
|
||||||
}
|
}
|
||||||
|
|
||||||
int stdin_ready() {
|
int stdin_ready() {
|
||||||
@ -40,11 +42,12 @@ void step_uart() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* update input register if empty */
|
/* update input register if empty */
|
||||||
if ((n++ % 10000) == 0) { // polling stdin every cycle is performance intensive. This is a bit of a dirty hack.
|
if ((n++ % 100) == 0) { // polling stdin every cycle is performance intensive. This is a bit of a dirty hack.
|
||||||
if (!uart_SR.bits.RDRF && stdin_ready()) { // the real hardware has no buffer. Remote the RDRF check for more accurate emulation.
|
if (!uart_SR.bits.RDRF && stdin_ready()) { // the real hardware has no buffer. Remote the RDRF check for more accurate emulation.
|
||||||
if (read(0, &incoming_char, 1) != 1) {
|
if (read(0, &incoming_char, 1) != 1) {
|
||||||
printf("Warning: read() returned 0\n");
|
printf("Warning: read() returned 0\n");
|
||||||
}
|
}
|
||||||
|
if (interactive) {
|
||||||
if (incoming_char == 0x18) { // CTRL+X
|
if (incoming_char == 0x18) { // CTRL+X
|
||||||
printf("\r\n");
|
printf("\r\n");
|
||||||
exit(0);
|
exit(0);
|
||||||
@ -52,6 +55,7 @@ void step_uart() {
|
|||||||
if (incoming_char == 0x7F) { // Backspace
|
if (incoming_char == 0x7F) { // Backspace
|
||||||
incoming_char = '\b';
|
incoming_char = '\b';
|
||||||
}
|
}
|
||||||
|
}
|
||||||
uart_SR.bits.RDRF = 1;
|
uart_SR.bits.RDRF = 1;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user