Forward button presses to FPGA in FPGA download mode (2) #43

This no longer has the delay as with the previous commit.
Bits are mapped to the following keys:
 0 - joystick down
 1 - joystick up
 2 - joystick left
 3 - joystick right
 4 - joystick press
 5 - home
 6 - menu
 7 - select
 8 - start
 9 - accept
10 - back
This commit is contained in:
Frans Faase 2022-05-26 19:27:30 +02:00
parent fe9ad7f15d
commit c6b04d5b3e

View file

@ -56,6 +56,10 @@ bool fpga_uart_load(uint8_t* buffer, uint32_t length) {
return fpga_read_stdin(buffer, length, 3000); return fpga_read_stdin(buffer, length, 3000);
} }
void fpga_uart_mess(const char *mess) {
uart_write_bytes(0, mess, strlen(mess));
}
void fpga_download(xQueueHandle buttonQueue, ICE40* ice40, pax_buf_t* pax_buffer, ILI9341* ili9341) { void fpga_download(xQueueHandle buttonQueue, ICE40* ice40, pax_buf_t* pax_buffer, ILI9341* ili9341) {
char message[64]; char message[64];
@ -128,9 +132,12 @@ void fpga_download(xQueueHandle buttonQueue, ICE40* ice40, pax_buf_t* pax_buffer
pax_draw_text(pax_buffer, 0xFFFFFFFF, NULL, 18, 0, 20*3, message); pax_draw_text(pax_buffer, 0xFFFFFFFF, NULL, 18, 0, 20*3, message);
ili9341_write(ili9341, pax_buffer->buf); ili9341_write(ili9341, pax_buffer->buf);
vTaskDelay(1000 / portTICK_PERIOD_MS); vTaskDelay(1000 / portTICK_PERIOD_MS);
snprintf(message, sizeof(message), "CRC failed %08X %08x\n", crc, checkCrc);
fpga_uart_mess(message);
fpga_uninstall_uart(); fpga_uninstall_uart();
return; return;
} }
fpga_uart_mess("CRC correct\n");
ili9341_deinit(ili9341); ili9341_deinit(ili9341);
ili9341_select(ili9341, false); ili9341_select(ili9341, false);
@ -149,17 +156,28 @@ void fpga_download(xQueueHandle buttonQueue, ICE40* ice40, pax_buf_t* pax_buffer
pax_draw_text(pax_buffer, 0xFFFFFFFF, NULL, 18, 0, 20*1, "FPGA signals not done"); pax_draw_text(pax_buffer, 0xFFFFFFFF, NULL, 18, 0, 20*1, "FPGA signals not done");
ili9341_write(ili9341, pax_buffer->buf); ili9341_write(ili9341, pax_buffer->buf);
vTaskDelay(1000 / portTICK_PERIOD_MS); vTaskDelay(1000 / portTICK_PERIOD_MS);
snprintf(message, sizeof(message), "loading bitstream failed with %d\n", res);
fpga_uninstall_uart(); fpga_uninstall_uart();
return; return;
} }
snprintf(message, sizeof(message), "bitstream loaded\n");
// Waiting for next download and sending key strokes to FPGA // Waiting for next download and sending key strokes to FPGA
uint16_t key_state = 0; uint16_t key_state = 0;
while (!fpga_uart_sync(&length, &crc)) { uint16_t idle_count = 0;
while (true) {
if (idle_count >= 200) {
if (fpga_uart_sync(&length, &crc)) {
break;
}
idle_count = 0;
}
rp2040_input_message_t buttonMessage = {0}; rp2040_input_message_t buttonMessage = {0};
if (xQueueReceive(buttonQueue, &buttonMessage, 0) == pdTRUE) { while (xQueueReceive(buttonQueue, &buttonMessage, 0) == pdTRUE) {
uint8_t pin = buttonMessage.input; uint8_t pin = buttonMessage.input;
bool value = buttonMessage.state; bool value = buttonMessage.state;
//snprintf(message, sizeof(message), "button %d %d\n", pin, value);
//fpga_uart_mess(message);
uint16_t key_mask = 0; uint16_t key_mask = 0;
switch(pin) { switch(pin) {
case RP2040_INPUT_JOYSTICK_DOWN: case RP2040_INPUT_JOYSTICK_DOWN:
@ -205,17 +223,34 @@ void fpga_download(xQueueHandle buttonQueue, ICE40* ice40, pax_buf_t* pax_buffer
else { else {
key_state &= ~key_mask; key_state &= ~key_mask;
} }
uint8_t message[5] = { 0xf5 }; //snprintf(message, sizeof(message), "send %04X %04X\n", key_state, key_mask);
message[1] = key_state & 0xff; //fpga_uart_mess(message);
message[2] = key_state >> 8;
message[3] = key_mask & 0xff; uint8_t spi_message[5] = { 0xf4 };
message[4] = key_mask >> 8; spi_message[1] = key_state & 0xff;
res = ice40_send(ice40, message, 5); spi_message[2] = key_state >> 8;
spi_message[3] = key_mask & 0xff;
spi_message[4] = key_mask >> 8;
res = ice40_send(ice40, spi_message, 5);
if (res != ESP_OK) {
ice40_disable(ice40);
ili9341_init(ili9341);
pax_noclip(pax_buffer);
pax_background(pax_buffer, 0xa85a32);
pax_draw_text(pax_buffer, 0xFFFFFFFF, NULL, 18, 0, 20*0, "FPGA download mode");
snprintf(message, sizeof(message), "ice40_send: %d", res);
pax_draw_text(pax_buffer, 0xFFFFFFFF, NULL, 18, 0, 20*1, message);
ili9341_write(ili9341, pax_buffer->buf);
vTaskDelay(1000 / portTICK_PERIOD_MS);
snprintf(message, sizeof(message), "ice40_send failed with %d\n", res);
fpga_uart_mess(message);
fpga_uninstall_uart();
} }
} }
else { idle_count = 0;
vTaskDelay(2 / portTICK_PERIOD_MS);
} }
vTaskDelay(10 / portTICK_PERIOD_MS);
idle_count++;
} }
ice40_disable(ice40); ice40_disable(ice40);
ili9341_init(ili9341); ili9341_init(ili9341);