valuemutex.c 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. #include "valuemutex.h"
  2. #include <string.h>
  3. bool init_mutex(ValueMutex* valuemutex, void* value, size_t size) {
  4. // mutex without name,
  5. // no attributes (unfortunatly robust mutex is not supported by FreeRTOS),
  6. // with dynamic memory allocation
  7. valuemutex->mutex = furi_mutex_alloc(FuriMutexTypeNormal);
  8. if(valuemutex->mutex == NULL) return false;
  9. valuemutex->value = value;
  10. valuemutex->size = size;
  11. return true;
  12. }
  13. bool delete_mutex(ValueMutex* valuemutex) {
  14. if(furi_mutex_acquire(valuemutex->mutex, FuriWaitForever) == FuriStatusOk) {
  15. furi_mutex_free(valuemutex->mutex);
  16. return true;
  17. } else {
  18. return false;
  19. }
  20. }
  21. void* acquire_mutex(ValueMutex* valuemutex, uint32_t timeout) {
  22. if(furi_mutex_acquire(valuemutex->mutex, timeout) == FuriStatusOk) {
  23. return valuemutex->value;
  24. } else {
  25. return NULL;
  26. }
  27. }
  28. bool release_mutex(ValueMutex* valuemutex, const void* value) {
  29. if(value != valuemutex->value) return false;
  30. if(furi_mutex_release(valuemutex->mutex) != FuriStatusOk) return false;
  31. return true;
  32. }
  33. bool read_mutex(ValueMutex* valuemutex, void* data, size_t len, uint32_t timeout) {
  34. void* value = acquire_mutex(valuemutex, timeout);
  35. if(value == NULL || len > valuemutex->size) return false;
  36. memcpy(data, value, len > 0 ? len : valuemutex->size);
  37. if(!release_mutex(valuemutex, value)) return false;
  38. return true;
  39. }
  40. bool write_mutex(ValueMutex* valuemutex, void* data, size_t len, uint32_t timeout) {
  41. void* value = acquire_mutex(valuemutex, timeout);
  42. if(value == NULL || len > valuemutex->size) return false;
  43. memcpy(value, data, len > 0 ? len : valuemutex->size);
  44. if(!release_mutex(valuemutex, value)) return false;
  45. return true;
  46. }