add mutex in furi_create_deprecated (#242)

This commit is contained in:
DrZlo13 2020-11-16 20:22:28 +03:00 committed by GitHub
parent 3d6af91dd1
commit 2ba3722de2
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 30 additions and 3 deletions

View File

@ -1,5 +1,15 @@
#include "flipper_v2.h" #include "flipper_v2.h"
bool init_flipper_api(void) { bool init_flipper_api(void) {
return gpio_api_init(); bool no_errors = true;
if(!furi_init()) {
no_errors = false;
}
if(!gpio_api_init()) {
no_errors = false;
}
return no_errors;
} }

View File

@ -11,6 +11,13 @@
static FuriRecord records[MAX_RECORD_COUNT]; static FuriRecord records[MAX_RECORD_COUNT];
static size_t current_buffer_idx = 0; static size_t current_buffer_idx = 0;
osMutexId_t furi_core_mutex;
bool furi_init(void) {
furi_core_mutex = osMutexNew(NULL);
if(furi_core_mutex == NULL) return false;
return true;
}
// find record pointer by name // find record pointer by name
static FuriRecord* find_record(const char* name) { static FuriRecord* find_record(const char* name) {
@ -32,6 +39,11 @@ bool furi_create_deprecated(const char* name, void* value, size_t size) {
printf("[FURI] creating %s record\n", name); printf("[FURI] creating %s record\n", name);
#endif #endif
// acquire mutex to prevent simultaneous write to record with same index
if(osMutexAcquire(furi_core_mutex, osWaitForever) != osOK) {
return false;
}
FuriRecord* record = find_record(name); FuriRecord* record = find_record(name);
if(record != NULL) { if(record != NULL) {
@ -69,6 +81,8 @@ bool furi_create_deprecated(const char* name, void* value, size_t size) {
current_buffer_idx++; current_buffer_idx++;
osMutexRelease(furi_core_mutex);
return true; return true;
} }

View File

@ -87,6 +87,9 @@ typedef struct {
FlipperAppLibrary libs; FlipperAppLibrary libs;
} FlipperStartupApp; } FlipperStartupApp;
// Init core
bool furi_init(void);
/*! /*!
Simply starts application. Simply starts application.
It call app entrypoint with param passed as argument. It call app entrypoint with param passed as argument.

View File

@ -31,12 +31,12 @@ void furiac_wait_libs(const FlipperAppLibrary* libs) {
if(app_id == INVALID_TASK_ID) { if(app_id == INVALID_TASK_ID) {
#ifdef FURI_DEBUG #ifdef FURI_DEBUG
printf("[FURIAC] Invalid library name %s\n", lib_name); printf("[FURIAC] Invalid library name %s\n", libs->name[i]);
#endif #endif
} else { } else {
while(!task_buffer[app_id].ready) { while(!task_buffer[app_id].ready) {
#ifdef FURI_DEBUG #ifdef FURI_DEBUG
printf("[FURIAC] waiting for library \"%s\"\n", lib_name); printf("[FURIAC] waiting for library \"%s\"\n", libs->name[i]);
#endif #endif
osDelay(50); osDelay(50);
} }