Removed state mutex to fix deadlock
This commit is contained in:
		
							parent
							
								
									9dfcaab35a
								
							
						
					
					
						commit
						27fa1ac090
					
				
							
								
								
									
										
											BIN
										
									
								
								doc/ABX00027-full-pinout.pdf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								doc/ABX00027-full-pinout.pdf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								doc/Atmel-42181-SAM-D21_Datasheet.pdf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								doc/Atmel-42181-SAM-D21_Datasheet.pdf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								doc/Behringer-X-AIR-XR16-User-Manual-EN.pdf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								doc/Behringer-X-AIR-XR16-User-Manual-EN.pdf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								doc/NANO33IoTV2.0_sch.pdf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								doc/NANO33IoTV2.0_sch.pdf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								doc/X AIR Remote Control Protocol.pdf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								doc/X AIR Remote Control Protocol.pdf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										1289
									
								
								doc/parameters.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1289
									
								
								doc/parameters.txt
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										5
									
								
								overwrite.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										5
									
								
								overwrite.py
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,5 @@ | |||||||
|  | import shutil | ||||||
|  | 
 | ||||||
|  | config_src = "./overwrite/FreeRTOSConfig.h" | ||||||
|  | config_dst = "./.pio/libdeps/nano_33_iot/FreeRTOS_SAMD21/src/FreeRTOSConfig.h" | ||||||
|  | shutil.copy(config_src, config_dst) | ||||||
							
								
								
									
										176
									
								
								overwrite/FreeRTOSConfig.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										176
									
								
								overwrite/FreeRTOSConfig.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,176 @@ | |||||||
|  | /* This has been copied then modified from
 | ||||||
|  |  * FreeRTOS/Demo/CORTEX_M0+_Atmel_SAMD20_XPlained/RTOSDemo/src/config/FreeRTOSConfig.h | ||||||
|  |  */ | ||||||
|  | /*
 | ||||||
|  |  * FreeRTOS Kernel V10.2.1 | ||||||
|  |  * Copyright (C) 2019 Amazon.com, Inc. or its affiliates.  All Rights Reserved. | ||||||
|  |  * | ||||||
|  |  * Permission is hereby granted, free of charge, to any person obtaining a copy of | ||||||
|  |  * this software and associated documentation files (the "Software"), to deal in | ||||||
|  |  * the Software without restriction, including without limitation the rights to | ||||||
|  |  * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of | ||||||
|  |  * the Software, and to permit persons to whom the Software is furnished to do so, | ||||||
|  |  * subject to the following conditions: | ||||||
|  |  * | ||||||
|  |  * The above copyright notice and this permission notice shall be included in all | ||||||
|  |  * copies or substantial portions of the Software. | ||||||
|  |  * | ||||||
|  |  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||||
|  |  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS | ||||||
|  |  * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR | ||||||
|  |  * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER | ||||||
|  |  * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN | ||||||
|  |  * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. | ||||||
|  |  * | ||||||
|  |  * http://www.FreeRTOS.org
 | ||||||
|  |  * http://aws.amazon.com/freertos
 | ||||||
|  |  * | ||||||
|  |  * 1 tab == 4 spaces! | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | #ifndef FREERTOS_CONFIG_H | ||||||
|  | #define FREERTOS_CONFIG_H | ||||||
|  | 
 | ||||||
|  | /*-----------------------------------------------------------
 | ||||||
|  |  * Application specific definitions. | ||||||
|  |  * | ||||||
|  |  * These definitions should be adjusted for your particular hardware and | ||||||
|  |  * application requirements. | ||||||
|  |  * | ||||||
|  |  * THESE PARAMETERS ARE DESCRIBED WITHIN THE 'CONFIGURATION' SECTION OF THE | ||||||
|  |  * FreeRTOS API DOCUMENTATION AVAILABLE ON THE FreeRTOS.org WEB SITE. | ||||||
|  |  * | ||||||
|  |  * See http://www.freertos.org/a00110.html
 | ||||||
|  |  *----------------------------------------------------------*/ | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | #define configUSE_PREEMPTION			1 | ||||||
|  | #define configUSE_IDLE_HOOK				1 | ||||||
|  | #define configUSE_TICK_HOOK				0 | ||||||
|  | #define configCPU_CLOCK_HZ				( ( unsigned long ) F_CPU  ) | ||||||
|  | #define configTICK_RATE_HZ				( ( TickType_t ) 1000 ) | ||||||
|  | #define configMAX_PRIORITIES			( 9 ) | ||||||
|  | #define configMINIMAL_STACK_SIZE		( ( unsigned short ) 150 ) | ||||||
|  | #define configTOTAL_HEAP_SIZE			( ( size_t ) ( 14 * 1024 ) ) | ||||||
|  | #define configMAX_TASK_NAME_LEN			( 16 ) //includes string null terminator
 | ||||||
|  | #define configUSE_TRACE_FACILITY		1 | ||||||
|  | #define configUSE_16_BIT_TICKS			0 | ||||||
|  | #define configIDLE_SHOULD_YIELD			1 | ||||||
|  | #define configUSE_MUTEXES				1 | ||||||
|  | #define configQUEUE_REGISTRY_SIZE		8 | ||||||
|  | #define configCHECK_FOR_STACK_OVERFLOW	2 | ||||||
|  | #define configUSE_RECURSIVE_MUTEXES		1 | ||||||
|  | #define configUSE_MALLOC_FAILED_HOOK	1 | ||||||
|  | #define configUSE_APPLICATION_TASK_TAG	0 | ||||||
|  | #define configUSE_COUNTING_SEMAPHORES	1 | ||||||
|  | #define configUSE_QUEUE_SETS			1 | ||||||
|  | #define configSUPPORT_STATIC_ALLOCATION 0 | ||||||
|  | #define configSUPPORT_DYNAMIC_ALLOCATION 1 | ||||||
|  | 
 | ||||||
|  | /* Run time stats related definitions. */ | ||||||
|  | #define configGENERATE_RUN_TIME_STATS	1 | ||||||
|  | 
 | ||||||
|  | /* Arduino framework integration */ | ||||||
|  | #define portCONFIGURE_TIMER_FOR_RUN_TIME_STATS() 	vMainConfigureTimerForRunTimeStats() // see runTimeStats_hooks.h
 | ||||||
|  | #define portGET_RUN_TIME_COUNTER_VALUE() 			ulMainGetRunTimeCounterValue() // see runTimeStats_hooks.h
 | ||||||
|  | 
 | ||||||
|  | /* This demo makes use of one or more example stats formatting functions.  These
 | ||||||
|  | format the raw data provided by the uxTaskGetSystemState() function in to human | ||||||
|  | readable ASCII form.  See the notes in the implementation of vTaskList() within | ||||||
|  | FreeRTOS/Source/tasks.c for limitations. */ | ||||||
|  | #define configUSE_STATS_FORMATTING_FUNCTIONS	1 | ||||||
|  | 
 | ||||||
|  | #define configUSE_MUTEXES        				1 | ||||||
|  | #define INCLUDE_uxTaskGetStackHighWaterMark 	1 | ||||||
|  | #define INCLUDE_xTaskGetIdleTaskHandle 			1 | ||||||
|  | #define configUSE_MALLOC_FAILED_HOOK			1 | ||||||
|  | 
 | ||||||
|  | /* Co-routine definitions. */ | ||||||
|  | #define configUSE_CO_ROUTINES 		     0 | ||||||
|  | #define configMAX_CO_ROUTINE_PRIORITIES ( 2 ) | ||||||
|  | 
 | ||||||
|  | /* Software timer definitions. */ | ||||||
|  | #define configUSE_TIMERS				1 | ||||||
|  | #define configTIMER_TASK_PRIORITY		( 2 ) | ||||||
|  | #define configTIMER_QUEUE_LENGTH		10 | ||||||
|  | #define configTIMER_TASK_STACK_DEPTH	( configMINIMAL_STACK_SIZE ) | ||||||
|  | 
 | ||||||
|  | /* Set the following definitions to 1 to include the API function, or zero
 | ||||||
|  | to exclude the API function. */ | ||||||
|  | #define INCLUDE_xTaskGetCurrentTaskHandle   1 | ||||||
|  | #define INCLUDE_vTaskPrioritySet			1 | ||||||
|  | #define INCLUDE_uxTaskPriorityGet			1 | ||||||
|  | #define INCLUDE_vTaskDelete					1 | ||||||
|  | #define INCLUDE_vTaskCleanUpResources		1 | ||||||
|  | #define INCLUDE_vTaskSuspend				1 | ||||||
|  | #define INCLUDE_vTaskDelayUntil				1 | ||||||
|  | #define INCLUDE_vTaskDelay					1 | ||||||
|  | #define INCLUDE_eTaskGetState				1 | ||||||
|  | 
 | ||||||
|  | /* Arduino framework integration */ | ||||||
|  | // calibration factor for vNopDelayMS in error_hooks.c
 | ||||||
|  | // used to set accuracy of nopDelayMS function
 | ||||||
|  | // this was experimentally chosen from a samd21 processor at 32khz
 | ||||||
|  | #define configCAL_FACTOR (F_CPU/6000) | ||||||
|  | 
 | ||||||
|  | /* Arduino framework integration */ | ||||||
|  | #if 0 | ||||||
|  | 	// disable interrupts and blink error code
 | ||||||
|  | 	extern void rtosFatalError(void); // see error_hooks.h
 | ||||||
|  | 	#define configASSERT( x ) \ | ||||||
|  | 		if( ( x ) == 0 ) { rtosFatalError(); } | ||||||
|  | #else | ||||||
|  | 	// print a error file and line number out user specified serial port
 | ||||||
|  | 	// disable interrupts and blink error code
 | ||||||
|  | 	extern void rtosFatalErrorSerial(unsigned long ulLine, const char * const pcFileName); // see error_hooks.h
 | ||||||
|  | 	extern const char* removePath(const char* path); // see error_hooks.h
 | ||||||
|  | 	#define configASSERT( x ) \ | ||||||
|  | 		if( ( x ) == 0 ) { rtosFatalErrorSerial( __LINE__, removePath(__FILE__) ); } | ||||||
|  | 
 | ||||||
|  | 	// assert you can use to also print the value that caused the failure
 | ||||||
|  | 	// Useful for debugging, but not FreeRtos standard
 | ||||||
|  | 	#define configPrintASSERT( x, v1, s, v2 ) \ | ||||||
|  | 		if( ( x ) == 0 ) { rtosFatalErrorSerialPrint( __LINE__, removePath(__FILE__), v1, s, v2 ); } | ||||||
|  | #endif | ||||||
|  | 
 | ||||||
|  | /* Arduino framework integration */ | ||||||
|  | // article to help wade through and figure out proper interrupt settings:
 | ||||||
|  | // https://community.arm.com/developer/ip-products/system/b/embedded-blog/posts/cutting-through-the-confusion-with-arm-cortex-m-interrupt-priorities
 | ||||||
|  | 
 | ||||||
|  | /* Cortex-M specific definitions. */ | ||||||
|  | #define configPRIO_BITS		3 // SAMD21 has only 4 priority levels. pg32 of datasheet.
 | ||||||
|  | 
 | ||||||
|  | /* The lowest interrupt priority that can be used in a call to a "set priority"
 | ||||||
|  | function. */ | ||||||
|  | #define configLIBRARY_LOWEST_INTERRUPT_PRIORITY			 0x03 // lowest priority
 | ||||||
|  | 
 | ||||||
|  | /* The highest interrupt priority that can be used by any interrupt service
 | ||||||
|  | routine that makes calls to interrupt safe FreeRTOS API functions.  DO NOT CALL | ||||||
|  | INTERRUPT SAFE FREERTOS API FUNCTIONS FROM ANY INTERRUPT THAT HAS A HIGHER | ||||||
|  | PRIORITY THAN THIS! (higher priorities are lower numeric values. */ | ||||||
|  | // See http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html.
 | ||||||
|  | #define configLIBRARY_MAX_SYSCALL_INTERRUPT_PRIORITY	0x01 // highest priority
 | ||||||
|  | 
 | ||||||
|  | /* Interrupt priorities used by the kernel port layer itself.  These are generic
 | ||||||
|  | to all Cortex-M ports, and do not rely on any particular library functions. */ | ||||||
|  | #define configKERNEL_INTERRUPT_PRIORITY 		( configLIBRARY_LOWEST_INTERRUPT_PRIORITY << (8 - configPRIO_BITS) ) | ||||||
|  | /* !!!! configMAX_SYSCALL_INTERRUPT_PRIORITY must not be set to zero !!!!
 | ||||||
|  | See http://www.FreeRTOS.org/RTOS-Cortex-M3-M4.html. */
 | ||||||
|  | #define configMAX_SYSCALL_INTERRUPT_PRIORITY 	( configLIBRARY_MAX_SYSCALL_INTERRUPT_PRIORITY << (8 - configPRIO_BITS) ) | ||||||
|  | 
 | ||||||
|  | /* Definitions that map the FreeRTOS port interrupt handlers to their CMSIS
 | ||||||
|  | standard names. */ | ||||||
|  | #define vPortSVCHandler SVC_Handler | ||||||
|  | #define xPortPendSVHandler PendSV_Handler | ||||||
|  | //#define xPortSysTickHandler SysTick_Handler
 | ||||||
|  | 
 | ||||||
|  | /* The size of the global output buffer that is available for use when there
 | ||||||
|  | are multiple command interpreters running at once (for example, one on a UART | ||||||
|  | and one on TCP/IP).  This is done to prevent an output buffer being defined by | ||||||
|  | each implementation - which would waste RAM.  In this case, there is only one | ||||||
|  | command interpreter running. */ | ||||||
|  | #define configCOMMAND_INT_MAX_OUTPUT_SIZE 2048 | ||||||
|  | 
 | ||||||
|  | #endif /* FREERTOS_CONFIG_H */ | ||||||
|  | 
 | ||||||
| @ -12,4 +12,6 @@ lib_deps = | |||||||
|     ruiseixasm/Versatile_RotaryEncoder@^1 |     ruiseixasm/Versatile_RotaryEncoder@^1 | ||||||
|     tedtoal/wiring_analog_SAMD_TT@^1 |     tedtoal/wiring_analog_SAMD_TT@^1 | ||||||
| 
 | 
 | ||||||
| extra_scripts = pre:remove_bluetooth.py | extra_scripts = | ||||||
|  |     pre:remove_bluetooth.py | ||||||
|  |     pre:overwrite.py | ||||||
							
								
								
									
										30
									
								
								src/main.cpp
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								src/main.cpp
									
									
									
									
									
								
							| @ -13,7 +13,6 @@ | |||||||
| #include "spinner.h" | #include "spinner.h" | ||||||
| #include "util.h" | #include "util.h" | ||||||
| 
 | 
 | ||||||
| SemaphoreHandle_t state_mutex; |  | ||||||
| State state = State::Connecting; | State state = State::Connecting; | ||||||
| ChainMenu chain_menu = ChainMenu::Master; | ChainMenu chain_menu = ChainMenu::Master; | ||||||
| ChainMode chain_mode = ChainMode::Meter; | ChainMode chain_mode = ChainMode::Meter; | ||||||
| @ -24,6 +23,7 @@ bool level_value_up_to_date = false; | |||||||
| 
 | 
 | ||||||
| void setup() { | void setup() { | ||||||
|   Serial.begin(9600); |   Serial.begin(9600); | ||||||
|  |   vSetErrorSerial(&Serial); | ||||||
| 
 | 
 | ||||||
|   setup_input_read(); |   setup_input_read(); | ||||||
|   setup_connect(); |   setup_connect(); | ||||||
| @ -32,8 +32,6 @@ void setup() { | |||||||
|   setup_osc(); |   setup_osc(); | ||||||
|   setup_spinner(); |   setup_spinner(); | ||||||
| 
 | 
 | ||||||
|   state_mutex = xSemaphoreCreateMutex(); |  | ||||||
| 
 |  | ||||||
|   vTaskStartScheduler(); |   vTaskStartScheduler(); | ||||||
|   Serial.println("Start scheduler failed"); |   Serial.println("Start scheduler failed"); | ||||||
| } | } | ||||||
| @ -43,48 +41,37 @@ void loop() { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void connection_established() { | void connection_established() { | ||||||
|   xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY); |  | ||||||
|   state = State::ChainMenu; |   state = State::ChainMenu; | ||||||
|   stop_spinner(); |   stop_spinner(); | ||||||
|   update_meter(); |   update_meter(); | ||||||
|   update_leds(); |   update_leds(); | ||||||
|   xSemaphoreGiveRecursive(state_mutex); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void connection_lost() { | void connection_lost() { | ||||||
|   xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY); |  | ||||||
|   state = State::Connecting; |   state = State::Connecting; | ||||||
|   start_spinner(); |   start_spinner(); | ||||||
|   xSemaphoreGiveRecursive(state_mutex); |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| State get_state() { | State get_state() { | ||||||
|   xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY); |  | ||||||
|   State current_state = state; |   State current_state = state; | ||||||
|   xSemaphoreGiveRecursive(state_mutex); |  | ||||||
|   return current_state; |   return current_state; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void toggle_chain_mode() { | void toggle_chain_mode() { | ||||||
|   xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY); |  | ||||||
|   if(ChainMode::Meter == chain_mode) { |   if(ChainMode::Meter == chain_mode) { | ||||||
|     chain_mode = ChainMode::Level; |     chain_mode = ChainMode::Level; | ||||||
|   } else { |   } else { | ||||||
|     chain_mode = ChainMode::Meter; |     chain_mode = ChainMode::Meter; | ||||||
|   } |   } | ||||||
|   xSemaphoreGiveRecursive(state_mutex); |  | ||||||
|   update_leds(); |   update_leds(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| ChainMode get_chain_mode() { | ChainMode get_chain_mode() { | ||||||
|   xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY); |  | ||||||
|   ChainMode current_chain_mode = chain_mode; |   ChainMode current_chain_mode = chain_mode; | ||||||
|   xSemaphoreGiveRecursive(state_mutex); |  | ||||||
|   return current_chain_mode; |   return current_chain_mode; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void previous_chain_menu_item() { | void previous_chain_menu_item() { | ||||||
|   xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY); |  | ||||||
|   switch (chain_menu) { |   switch (chain_menu) { | ||||||
|     case ChainMenu::Gain: |     case ChainMenu::Gain: | ||||||
|       break; |       break; | ||||||
| @ -99,12 +86,10 @@ void previous_chain_menu_item() { | |||||||
|       update_value(); |       update_value(); | ||||||
|       break; |       break; | ||||||
|   } |   } | ||||||
|   xSemaphoreGiveRecursive(state_mutex); |  | ||||||
|   update_leds(); |   update_leds(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void next_chain_menu_item() { | void next_chain_menu_item() { | ||||||
|   xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY); |  | ||||||
|   switch (chain_menu) { |   switch (chain_menu) { | ||||||
|     case ChainMenu::Gain: |     case ChainMenu::Gain: | ||||||
|       chain_menu = ChainMenu::Fader; |       chain_menu = ChainMenu::Fader; | ||||||
| @ -119,19 +104,15 @@ void next_chain_menu_item() { | |||||||
|     case ChainMenu::Master: |     case ChainMenu::Master: | ||||||
|       break; |       break; | ||||||
|   } |   } | ||||||
|   xSemaphoreGiveRecursive(state_mutex); |  | ||||||
|   update_leds(); |   update_leds(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| ChainMenu get_chain_menu_item() { | ChainMenu get_chain_menu_item() { | ||||||
|   xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY); |  | ||||||
|   ChainMenu current_chain_menu = chain_menu; |   ChainMenu current_chain_menu = chain_menu; | ||||||
|   xSemaphoreGiveRecursive(state_mutex); |  | ||||||
|   return current_chain_menu; |   return current_chain_menu; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void increment_level(float value) { | void increment_level(float value) { | ||||||
|   xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY); |  | ||||||
|   if(level_value_up_to_date) { |   if(level_value_up_to_date) { | ||||||
|     level_value += value; |     level_value += value; | ||||||
|     if(state == State::ChainMenu |     if(state == State::ChainMenu | ||||||
| @ -145,35 +126,26 @@ void increment_level(float value) { | |||||||
|       set_master(level_value); |       set_master(level_value); | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|   xSemaphoreGiveRecursive(state_mutex); |  | ||||||
|   update_leds(); |   update_leds(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void set_level(float value) { | void set_level(float value) { | ||||||
|   xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY); |  | ||||||
|   level_value = value; |   level_value = value; | ||||||
|   level_value_up_to_date = true; |   level_value_up_to_date = true; | ||||||
|   xSemaphoreGiveRecursive(state_mutex); |  | ||||||
|   update_leds(); |   update_leds(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| float get_level() { | float get_level() { | ||||||
|   xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY); |  | ||||||
|   float current_level_value = level_value; |   float current_level_value = level_value; | ||||||
|   xSemaphoreGiveRecursive(state_mutex); |  | ||||||
|   return current_level_value; |   return current_level_value; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void set_meter(float value) { | void set_meter(float value) { | ||||||
|   xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY); |  | ||||||
|   meter_value = value; |   meter_value = value; | ||||||
|   xSemaphoreGiveRecursive(state_mutex); |  | ||||||
|   update_leds(); |   update_leds(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| float get_meter() { | float get_meter() { | ||||||
|   xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY); |  | ||||||
|   float current_meter_value = meter_value; |   float current_meter_value = meter_value; | ||||||
|   xSemaphoreGiveRecursive(state_mutex); |  | ||||||
|   return current_meter_value; |   return current_meter_value; | ||||||
| } | } | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user