 942bbfaefe
			
		
	
	
		942bbfaefe
		
			
		
	
	
	
	
		
			
			* add input debounce code from old fw * exampl of input api * change input API to get/release * revert input API to read * pointer instead of instance * add input API description * add display API * rewrite display names * migrate to valuemanager * add LED API * add closing brakets * add sound api * fix led api * basic api * rename API pages * change pubsub implementation * move FURI AC -> flapp, add valuemutex example, add valuemanager implementation * pubsub usage example * user led example * update example * simplify input * add composed display * add SPI/GPIO and CC1101 bus * change cc1101 api * spi api and devices * spi api and devices * move SPI to page, add GPIO * not block pin open * backlight API and more * add minunit tests * fix logging * ignore unexisting time service on embedded targets * fix warning, issue with printf * Deprecate furi_open and furi_close (#167) Rename existing furi_open and furi_close to deprecated version * add exitcode * migrate to printf * indicate test by leds * add testing description * rename furi.h * wip basic api * add valuemutex, pubsub, split files * add value expanders * value mutex realization and tests * valuemutex test added to makefile * do not build unimplemented files * fix build furmware target f2 * redesigned minunit tests to allow testing in separate files * test file for valuemutex minunit testing * minunit partial test valuemutex * local cmsis_os2 mutex bindings * implement furi open/create, tests * migrate concurrent_access to ValueMutex * add spi header * Lib: add mlib submodule. Co-authored-by: rusdacent <rusdacentx0x08@gmail.com> Co-authored-by: DrZlo13 <who.just.the.doctor@gmail.com>
		
			
				
	
	
		
			52 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			52 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #include "valuemutex.h"
 | |
| #include <string.h>
 | |
| 
 | |
| bool init_mutex(ValueMutex* valuemutex, void* value, size_t size) {
 | |
|     // mutex without name,
 | |
|     // no attributes (unfortunatly robust mutex is not supported by FreeRTOS),
 | |
|     // with dynamic memory allocation
 | |
|     const osMutexAttr_t value_mutext_attr = {
 | |
|         .name = NULL, .attr_bits = 0, .cb_mem = NULL, .cb_size = 0U};
 | |
| 
 | |
|     valuemutex->mutex = osMutexNew(&value_mutext_attr);
 | |
|     if(valuemutex->mutex == NULL) return false;
 | |
| 
 | |
|     valuemutex->value = value;
 | |
|     valuemutex->size = size;
 | |
| 
 | |
|     return true;
 | |
| }
 | |
| 
 | |
| void* acquire_mutex(ValueMutex* valuemutex, uint32_t timeout) {
 | |
|     if(osMutexAcquire(valuemutex->mutex, timeout) == osOK) {
 | |
|         return valuemutex->value;
 | |
|     } else {
 | |
|         return NULL;
 | |
|     }
 | |
| }
 | |
| 
 | |
| bool release_mutex(ValueMutex* valuemutex, void* value) {
 | |
|     if(value != valuemutex->value) return false;
 | |
| 
 | |
|     if(osMutexRelease(valuemutex->mutex) != osOK) return false;
 | |
| 
 | |
|     return true;
 | |
| }
 | |
| 
 | |
| bool read_mutex(ValueMutex* valuemutex, void* data, size_t len, uint32_t timeout) {
 | |
|     void* value = acquire_mutex(valuemutex, timeout);
 | |
|     if(value == NULL || len > valuemutex->size) return false;
 | |
|     memcpy(data, value, len > 0 ? len : valuemutex->size);
 | |
|     if(!release_mutex(valuemutex, value)) return false;
 | |
| 
 | |
|     return true;
 | |
| }
 | |
| 
 | |
| bool write_mutex(ValueMutex* valuemutex, void* data, size_t len, uint32_t timeout) {
 | |
|     void* value = acquire_mutex(valuemutex, timeout);
 | |
|     if(value == NULL || len > valuemutex->size) return false;
 | |
|     memcpy(value, data, len > 0 ? len : valuemutex->size);
 | |
|     if(!release_mutex(valuemutex, value)) return false;
 | |
| 
 | |
|     return true;
 | |
| } |