7 #ifndef _PICO_MULTICORE_H
8 #define _PICO_MULTICORE_H
10 #include "pico/types.h"
12 #include "hardware/structs/sio.h"
28 #ifndef PICO_CORE1_STACK_SIZE
29 #ifdef PICO_STACK_SIZE
30 #define PICO_CORE1_STACK_SIZE PICO_STACK_SIZE
32 #define PICO_CORE1_STACK_SIZE 0x800
116 return !!(sio_hw->fifo_st & SIO_FIFO_ST_VLD_BITS);
127 return !!(sio_hw->fifo_st & SIO_FIFO_ST_RDY_BITS);
188 (void) sio_hw->fifo_rd;
203 sio_hw->fifo_st = 0xff;
222 return sio_hw->fifo_st;
bool multicore_fifo_push_timeout_us(uint32_t data, uint64_t timeout_us)
Push data on to the write FIFO (data to the other core) with timeout.
Definition: multicore.c:41
void multicore_fifo_push_blocking(uint32_t data)
Push data on to the write FIFO (data to the other core).
Definition: multicore.c:37
bool multicore_fifo_pop_timeout_us(uint64_t timeout_us, uint32_t *out)
Pop data from the read FIFO (data from the other core) with timeout.
Definition: multicore.c:69
static void multicore_fifo_drain(void)
Discard any data in the read FIFO.
Definition: multicore.h:186
static bool multicore_fifo_wready(void)
Check the write FIFO to see if it has space for more data.
Definition: multicore.h:126
static uint32_t multicore_fifo_get_status(void)
Get FIFO statuses.
Definition: multicore.h:221
uint32_t multicore_fifo_pop_blocking(void)
Pop data from the read FIFO (data from the other core).
Definition: multicore.c:65
static void multicore_fifo_clear_irq(void)
Clear FIFO interrupt.
Definition: multicore.h:201
static bool multicore_fifo_rvalid(void)
Check the read FIFO to see if there is data available (sent by the other core)
Definition: multicore.h:115
bool multicore_lockout_victim_is_initialized(uint core_num)
Determine if multicore_victim_init() has been called on the specified core.
Definition: multicore.c:284
void multicore_lockout_victim_init(void)
Initialize the current core such that it can be a "victim" of lockout (i.e. forced to pause in a know...
Definition: multicore.c:207
void multicore_lockout_start_blocking(void)
Request the other core to pause in a known state and wait for it to do so.
Definition: multicore.c:258
bool multicore_lockout_start_timeout_us(uint64_t timeout_us)
Request the other core to pause in a known state and wait up to a time limit for it to do so.
Definition: multicore.c:254
void multicore_lockout_end_blocking(void)
Release the other core from a locked out state amd wait for it to acknowledge.
Definition: multicore.c:280
bool multicore_lockout_end_timeout_us(uint64_t timeout_us)
Release the other core from a locked out state amd wait up to a time limit for it to acknowledge.
Definition: multicore.c:276
void multicore_launch_core1(void(*entry)(void))
Run code on core 1.
Definition: multicore.c:132
void multicore_launch_core1_with_stack(void(*entry)(void), uint32_t *stack_bottom, size_t stack_size_bytes)
Launch code on core 1 with stack.
Definition: multicore.c:117
void multicore_launch_core1_raw(void(*entry)(void), uint32_t *sp, uint32_t vector_table)
Launch code on core 1 with no stack protection.
Definition: multicore.c:140
void multicore_reset_core1(void)
Reset core 1.
Definition: multicore.c:100