cic 64dd support

This commit is contained in:
Polprzewodnikowy 2022-05-20 00:31:45 +02:00
parent b055a439a4
commit beb927aef3
7 changed files with 47 additions and 36 deletions

View File

@ -5,7 +5,7 @@ set -e
PACKAGE_FILE_NAME="SC64" PACKAGE_FILE_NAME="SC64"
FILES=( FILES=(
"./fw/ftdi-template.xml" "./fw/ft232h_config.xml"
"./fw/project/lcmxo2/impl1/sc64_impl1.bit" "./fw/project/lcmxo2/impl1/sc64_impl1.bit"
"./fw/project/lcmxo2/impl1/sc64_impl1.jed" "./fw/project/lcmxo2/impl1/sc64_impl1.jed"
"./sw/bootloader/build/bootloader.bin" "./sw/bootloader/build/bootloader.bin"

View File

@ -34,7 +34,6 @@ static const vi_regs_t vi_config[] = {{
VI_CR_PIXEL_ADVANCE_0 | VI_CR_PIXEL_ADVANCE_0 |
VI_CR_ANTIALIAS_1 | VI_CR_ANTIALIAS_1 |
VI_CR_ANTIALIAS_0 | VI_CR_ANTIALIAS_0 |
VI_CR_GAMMA_ON |
VI_CR_TYPE_32 VI_CR_TYPE_32
), ),
.H_WIDTH = SCREEN_WIDTH, .H_WIDTH = SCREEN_WIDTH,
@ -55,7 +54,6 @@ static const vi_regs_t vi_config[] = {{
VI_CR_PIXEL_ADVANCE_0 | VI_CR_PIXEL_ADVANCE_0 |
VI_CR_ANTIALIAS_1 | VI_CR_ANTIALIAS_1 |
VI_CR_ANTIALIAS_0 | VI_CR_ANTIALIAS_0 |
VI_CR_GAMMA_ON |
VI_CR_TYPE_32 VI_CR_TYPE_32
), ),
.H_WIDTH = SCREEN_WIDTH, .H_WIDTH = SCREEN_WIDTH,

View File

@ -1,3 +1,4 @@
#include "error.h"
#include "exception.h" #include "exception.h"
#include "io.h" #include "io.h"
#include "sc64.h" #include "sc64.h"
@ -8,6 +9,11 @@ void init (void) {
si_io_write((io32_t *) (&PIFRAM[0x3C]), pifram | 0x08); si_io_write((io32_t *) (&PIFRAM[0x3C]), pifram | 0x08);
exception_install(); exception_install();
if (!sc64_check_presence()) {
error_display("SC64 hardware not detected");
}
exception_enable_watchdog(); exception_enable_watchdog();
exception_enable_interrupts(); exception_enable_interrupts();

View File

@ -50,7 +50,6 @@ void sc64_get_info (sc64_info_t *info) {
} }
void sc64_init (void) { void sc64_init (void) {
while (!sc64_check_presence());
sc64_change_config(CFG_ID_BOOTLOADER_SWITCH, false); sc64_change_config(CFG_ID_BOOTLOADER_SWITCH, false);
} }

View File

@ -5,9 +5,10 @@ from PIL import Image
if __name__ == "__main__":
if (len(sys.argv) != 3): if (len(sys.argv) != 3):
print(f"Usage: python {sys.argv[0]} input_path output_path") print(f"Usage: python {sys.argv[0]} input_path output_path")
exit(-1) sys.exit(1)
asset_input = sys.argv[1] asset_input = sys.argv[1]
asset_output = sys.argv[2] asset_output = sys.argv[2]
@ -22,8 +23,10 @@ try:
final_asset.write(converted_asset.tobytes()) final_asset.write(converted_asset.tobytes())
except FileNotFoundError: except FileNotFoundError:
print(f"Couldn't open file \"{asset_input}\"") print(f"Couldn't open file \"{asset_input}\"")
sys.exit(2)
except Exception as e: except Exception as e:
print(e) print(e)
sys.exit(3)
finally: finally:
if (source_asset): if (source_asset):
source_asset.close() source_asset.close()

View File

@ -12,6 +12,7 @@ typedef enum {
static volatile bool cic_enabled = false; static volatile bool cic_enabled = false;
static volatile bool cic_detect_enabled;
static volatile uint8_t cic_next_rd; static volatile uint8_t cic_next_rd;
static volatile uint8_t cic_next_wr; static volatile uint8_t cic_next_wr;
@ -54,6 +55,12 @@ static void cic_irq_clk_falling (void) {
static void cic_irq_clk_rising (void) { static void cic_irq_clk_rising (void) {
hw_gpio_set(GPIO_ID_N64_CIC_DQ); hw_gpio_set(GPIO_ID_N64_CIC_DQ);
if (cic_detect_enabled) {
cic_detect_enabled = false;
if (!hw_gpio_get(GPIO_ID_N64_CIC_DQ)) {
cic_enabled = false;
}
}
} }
static uint8_t cic_read (void) { static uint8_t cic_read (void) {
@ -67,6 +74,10 @@ static void cic_write (uint8_t bit) {
task_yield(); task_yield();
} }
static void cic_start_detect (void) {
cic_detect_enabled = cic_dd_mode;
}
static uint8_t cic_read_nibble (void) { static uint8_t cic_read_nibble (void) {
uint8_t data = 0; uint8_t data = 0;
for (int i = 0; i < 4; i++) { for (int i = 0; i < 4; i++) {
@ -97,17 +108,11 @@ static void cic_encode_round (uint8_t index) {
} }
static void cic_write_id (cic_region_t region) { static void cic_write_id (cic_region_t region) {
uint8_t id = 0x01; cic_start_detect();
cic_write(cic_dd_mode ? 1 : 0);
if (cic_dd_mode) { cic_write(region == REGION_PAL ? 1 : 0);
id |= 0x08; cic_write(0);
} cic_write(1);
if (region == REGION_PAL) {
id |= 0x04;
}
cic_write_nibble(id);
} }
static void cic_write_id_failed (void) { static void cic_write_id_failed (void) {