Introduce port_yield()

This allows the web workflow send code to yield briefly when
waiting for more room to send in a socket. Waiting for an "interrupt"
could wait forever because the select task only waits for read and
error. Adding wait on write is tricky because much of the time we
don't care if the sockets are ready to write. Using yield avoids
this trickiness.
This commit is contained in:
Scott Shawcroft 2022-08-11 11:25:34 -07:00
parent 471053c315
commit f1053fb963
No known key found for this signature in database
GPG Key ID: 0DFD512649C052DA
4 changed files with 16 additions and 4 deletions

View File

@ -345,9 +345,6 @@ void reset_port(void) {
reset_all_pins(); reset_all_pins();
// A larger delay so the idle task can run and do any IDF cleanup needed.
vTaskDelay(4);
#if CIRCUITPY_ANALOGIO #if CIRCUITPY_ANALOGIO
analogout_reset(); analogout_reset();
#endif #endif
@ -402,6 +399,9 @@ void reset_port(void) {
#if CIRCUITPY_WATCHDOG #if CIRCUITPY_WATCHDOG
watchdog_reset(); watchdog_reset();
#endif #endif
// Yield so the idle task can run and do any IDF cleanup needed.
port_yield();
} }
void reset_to_bootloader(void) { void reset_to_bootloader(void) {
@ -492,6 +492,10 @@ void port_wake_main_task_from_isr() {
} }
} }
void port_yield() {
vTaskDelay(4);
}
void sleep_timer_cb(void *arg) { void sleep_timer_cb(void *arg) {
port_wake_main_task(); port_wake_main_task();
} }

View File

@ -109,6 +109,11 @@ void port_wake_main_task(void);
// default weak implementation is provided that does nothing. // default weak implementation is provided that does nothing.
void port_wake_main_task_from_isr(void); void port_wake_main_task_from_isr(void);
// Some ports may use real RTOS tasks besides the background task framework of
// CircuitPython. Calling this will yield to other tasks and then return to the
// CircuitPython task when others are done.
void port_yield(void);
// Some ports need special handling just after completing boot.py execution. // Some ports need special handling just after completing boot.py execution.
// This function is called once while boot.py's VM is still valid, and // This function is called once while boot.py's VM is still valid, and
// then a second time after the VM is finalized. // then a second time after the VM is finalized.

View File

@ -31,3 +31,6 @@ MP_WEAK void port_wake_main_task(void) {
MP_WEAK void port_wake_main_task_from_isr(void) { MP_WEAK void port_wake_main_task_from_isr(void) {
} }
MP_WEAK void port_yield(void) {
}

View File

@ -334,7 +334,7 @@ void web_workflow_send_raw(socketpool_socket_obj_t *socket, const uint8_t *buf,
total_sent += sent; total_sent += sent;
if (total_sent < len) { if (total_sent < len) {
// Yield so that network code can run. // Yield so that network code can run.
port_idle_until_interrupt(); port_yield();
} }
} }
} }