2022-07-20 10:56:33 +00:00
|
|
|
#include "furi.h"
|
|
|
|
#include <string.h>
|
2023-11-01 07:24:11 +00:00
|
|
|
|
|
|
|
#include <FreeRTOS.h>
|
|
|
|
#include <queue.h>
|
2022-07-20 10:56:33 +00:00
|
|
|
|
|
|
|
void furi_init() {
|
2023-01-29 10:12:24 +00:00
|
|
|
furi_assert(!furi_kernel_is_irq_or_masked());
|
2022-07-20 10:56:33 +00:00
|
|
|
furi_assert(xTaskGetSchedulerState() == taskSCHEDULER_NOT_STARTED);
|
|
|
|
|
|
|
|
furi_log_init();
|
|
|
|
furi_record_init();
|
|
|
|
}
|
|
|
|
|
|
|
|
void furi_run() {
|
2023-01-29 10:12:24 +00:00
|
|
|
furi_assert(!furi_kernel_is_irq_or_masked());
|
2022-07-20 10:56:33 +00:00
|
|
|
furi_assert(xTaskGetSchedulerState() == taskSCHEDULER_NOT_STARTED);
|
|
|
|
|
|
|
|
#if(__ARM_ARCH_7A__ == 0U)
|
2022-11-28 16:51:51 +00:00
|
|
|
/* Service Call interrupt might be configured before kernel start */
|
|
|
|
/* and when its priority is lower or equal to BASEPRI, svc instruction */
|
|
|
|
/* causes a Hard Fault. */
|
2022-07-20 10:56:33 +00:00
|
|
|
NVIC_SetPriority(SVCall_IRQn, 0U);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Start the kernel scheduler */
|
|
|
|
vTaskStartScheduler();
|
|
|
|
}
|