mirror of
https://github.com/V2RetroComputing/analog.git
synced 2024-11-28 19:49:45 +00:00
0835003caa
Progress on PCPI mode bug fixes. PCPI mode is now working again, but the config interface is still broken enough to prevent the use of the config utility while in this mode.. Sending the FORMAT command from the monitor rom returns the card to defaults. Replace n with the slot number the card is installed in: ]CALL -151 *CnF0:46 4F 52 4D 41 54 00 00 Correction of mousetext / inverse / flashing handling on IIe see https://github.com/V2RetroComputing/analog/issues/3 Monochrome mode & color palettes are now implemented. $C0n1: Monochrome mode & palette $80: B&W $90: Inverse $A0: Amber $B0: Inverse Amber $C0: Green $D0: Inverse Green $E0: Commodore 64 Theme $F0: Use IIgs palette $C0n2: Mirror of IIgs TBCOLOR register $C0n3: Mirror of IIgs BORDER register
168 lines
5.8 KiB
C
168 lines
5.8 KiB
C
#include <stdio.h>
|
|
#include <pico/stdlib.h>
|
|
#include <pico/multicore.h>
|
|
#include <hardware/pio.h>
|
|
#include "common/abus.h"
|
|
#include "common/config.h"
|
|
#include "common/modes.h"
|
|
#include "common/buffers.h"
|
|
#include "common/flash.h"
|
|
#include "pico_hal.h"
|
|
|
|
#ifdef RASPBERRYPI_PICO_W
|
|
#include <pico/cyw43_arch.h>
|
|
#endif
|
|
|
|
typedef void (*businterface_t)(uint32_t address, uint32_t value);
|
|
volatile businterface_t businterface = NULL;
|
|
|
|
static void __time_critical_func(core1_loop)() {
|
|
for(;;) {
|
|
uint32_t value = pio_sm_get_blocking(CONFIG_ABUS_PIO, ABUS_MAIN_SM);
|
|
uint32_t address = (value >> 10) & 0xffff;
|
|
|
|
// device read access
|
|
if((value & (1u << CONFIG_PIN_APPLEBUS_RW-CONFIG_PIN_APPLEBUS_DATA_BASE)) != 0) {
|
|
if(CARD_SELECT) {
|
|
pio_sm_put(CONFIG_ABUS_PIO, ABUS_DEVICE_READ_SM, apple_memory[address]);
|
|
//pio_sm_put_blocking(CONFIG_ABUS_PIO, ABUS_DEVICE_READ_SM, apple_memory[address]);
|
|
}
|
|
}
|
|
|
|
busactive = 1;
|
|
|
|
if(CARD_SELECT) {
|
|
if(CARD_DEVSEL) {
|
|
cardslot = (address >> 4) & 0x7;
|
|
} else if(CARD_IOSEL) {
|
|
cardslot = (address >> 8) & 0x7;
|
|
|
|
// Config memory in card slot-rom address space
|
|
if(((value & (1u << CONFIG_PIN_APPLEBUS_RW-CONFIG_PIN_APPLEBUS_DATA_BASE)) == 0) && ((address & 0xF0) == 0xF0)) {
|
|
apple_memory[address] = value;
|
|
}
|
|
}
|
|
} else if(current_machine == MACHINE_AUTO) {
|
|
if((apple_memory[0x0417] == 0xE7) && (apple_memory[0x416] == 0xC9)) { // Apple IIgs
|
|
current_machine = MACHINE_IIGS;
|
|
internal_flags &= ~IFLAGS_IIE_REGS;
|
|
internal_flags |= IFLAGS_IIGS_REGS;
|
|
} else if((apple_memory[0x0417] == 0xE5) && (apple_memory[0x416] == 0xAF)) { // Apple //e Enhanced
|
|
current_machine = MACHINE_IIE;
|
|
internal_flags |= IFLAGS_IIE_REGS;
|
|
internal_flags &= ~IFLAGS_IIGS_REGS;
|
|
} else if((apple_memory[0x0415] == 0xDD) && (apple_memory[0x413] == 0xE5)) { // Apple //e Unenhanced
|
|
current_machine = MACHINE_IIE;
|
|
internal_flags |= IFLAGS_IIE_REGS;
|
|
internal_flags &= ~IFLAGS_IIGS_REGS;
|
|
} else if(apple_memory[0x0410] == 0xD0) { // Apple II/Plus/J-Plus with Autostart
|
|
current_machine = MACHINE_II;
|
|
internal_flags &= ~(IFLAGS_IIE_REGS | IFLAGS_IIGS_REGS);
|
|
} else if((apple_memory[0x07D0] == 0xAA) && (apple_memory[0x07D1] == 0x60)) { // Apple II without Autostart
|
|
current_machine = MACHINE_II;
|
|
internal_flags &= ~(IFLAGS_IIE_REGS | IFLAGS_IIGS_REGS);
|
|
} else if(apple_memory[0x0410] == 0xF2) { // Pravetz!
|
|
current_machine = MACHINE_PRAVETZ;
|
|
internal_flags &= ~(IFLAGS_IIE_REGS | IFLAGS_IIGS_REGS);
|
|
}
|
|
} else switch(reset_state) {
|
|
case 0:
|
|
if(value == ((0xFFFC << 10) | 0x300 | 0x62))
|
|
reset_state++;
|
|
break;
|
|
case 1:
|
|
if(value == ((0xFFFD << 10) | 0x300 | 0xFA))
|
|
reset_state++;
|
|
else
|
|
reset_state=0;
|
|
break;
|
|
case 2:
|
|
if((value & 0x3FFFF00) == ((0xFA62 << 10) | 0x300))
|
|
reset_state++;
|
|
else
|
|
reset_state=0;
|
|
break;
|
|
case 3:
|
|
soft_switches = SOFTSW_TEXT_MODE;
|
|
|
|
default:
|
|
reset_state = 0;
|
|
break;
|
|
}
|
|
|
|
if(businterface != NULL) {
|
|
(*businterface)(address, value);
|
|
}
|
|
}
|
|
}
|
|
|
|
static void core0_loop() {
|
|
for(;;) {
|
|
switch(current_mode) {
|
|
case MODE_DIAG:
|
|
businterface = &diag_businterface;
|
|
diagmain();
|
|
break;
|
|
case MODE_FS:
|
|
businterface = &fs_businterface;
|
|
fsmain();
|
|
break;
|
|
default:
|
|
current_mode = MODE_VGACARD;
|
|
case MODE_VGACARD:
|
|
if(cardslot == 0) cardslot = 3;
|
|
businterface = &vga_businterface;
|
|
vgamain();
|
|
break;
|
|
case MODE_APPLICARD:
|
|
if(cardslot == 0) cardslot = 4;
|
|
businterface = &z80_businterface;
|
|
z80main();
|
|
break;
|
|
case MODE_SERIAL:
|
|
if(cardslot == 0) cardslot = 2;
|
|
businterface = &serial_businterface;
|
|
serialmain();
|
|
break;
|
|
case MODE_PARALLEL:
|
|
if(cardslot == 0) cardslot = 1;
|
|
businterface = ¶llel_businterface;
|
|
parallelmain();
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
int main() {
|
|
// Adjust system clock for better dividing into other clocks
|
|
set_sys_clock_khz(CONFIG_SYSCLOCK*1000, true);
|
|
|
|
abus_init();
|
|
|
|
multicore_launch_core1(core1_loop);
|
|
|
|
memcpy((uint8_t*)apple_memory+0xC1F0, "\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFFV2ANALOG", 16);
|
|
memcpy((uint8_t*)apple_memory+0xC2F0, "\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFFV2ANALOG", 16);
|
|
memcpy((uint8_t*)apple_memory+0xC3F0, "\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFFV2ANALOG", 16);
|
|
memcpy((uint8_t*)apple_memory+0xC4F0, "\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFFV2ANALOG", 16);
|
|
memcpy((uint8_t*)apple_memory+0xC5F0, "\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFFV2ANALOG", 16);
|
|
memcpy((uint8_t*)apple_memory+0xC6F0, "\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFFV2ANALOG", 16);
|
|
memcpy((uint8_t*)apple_memory+0xC7F0, "\xFF\xFF\xFF\xFF\xFF\xFF\xFF\xFFV2ANALOG", 16);
|
|
|
|
// Sensible defaults if there is no config / fs
|
|
default_config();
|
|
|
|
// Try mounting the LittleFS, or format if it isn't there.
|
|
if(pico_mount(0) == LFS_ERR_OK) {
|
|
read_config();
|
|
} else {
|
|
pico_mount(1);
|
|
}
|
|
|
|
current_mode = cfg_mode;
|
|
|
|
core0_loop();
|
|
|
|
return 0;
|
|
}
|