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
|
||||
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 "util.h"
|
||||
|
||||
SemaphoreHandle_t state_mutex;
|
||||
State state = State::Connecting;
|
||||
ChainMenu chain_menu = ChainMenu::Master;
|
||||
ChainMode chain_mode = ChainMode::Meter;
|
||||
@ -24,6 +23,7 @@ bool level_value_up_to_date = false;
|
||||
|
||||
void setup() {
|
||||
Serial.begin(9600);
|
||||
vSetErrorSerial(&Serial);
|
||||
|
||||
setup_input_read();
|
||||
setup_connect();
|
||||
@ -32,8 +32,6 @@ void setup() {
|
||||
setup_osc();
|
||||
setup_spinner();
|
||||
|
||||
state_mutex = xSemaphoreCreateMutex();
|
||||
|
||||
vTaskStartScheduler();
|
||||
Serial.println("Start scheduler failed");
|
||||
}
|
||||
@ -43,48 +41,37 @@ void loop() {
|
||||
}
|
||||
|
||||
void connection_established() {
|
||||
xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY);
|
||||
state = State::ChainMenu;
|
||||
stop_spinner();
|
||||
update_meter();
|
||||
update_leds();
|
||||
xSemaphoreGiveRecursive(state_mutex);
|
||||
}
|
||||
|
||||
void connection_lost() {
|
||||
xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY);
|
||||
state = State::Connecting;
|
||||
start_spinner();
|
||||
xSemaphoreGiveRecursive(state_mutex);
|
||||
}
|
||||
|
||||
State get_state() {
|
||||
xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY);
|
||||
State current_state = state;
|
||||
xSemaphoreGiveRecursive(state_mutex);
|
||||
return current_state;
|
||||
}
|
||||
|
||||
void toggle_chain_mode() {
|
||||
xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY);
|
||||
if(ChainMode::Meter == chain_mode) {
|
||||
chain_mode = ChainMode::Level;
|
||||
} else {
|
||||
chain_mode = ChainMode::Meter;
|
||||
}
|
||||
xSemaphoreGiveRecursive(state_mutex);
|
||||
update_leds();
|
||||
}
|
||||
|
||||
ChainMode get_chain_mode() {
|
||||
xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY);
|
||||
ChainMode current_chain_mode = chain_mode;
|
||||
xSemaphoreGiveRecursive(state_mutex);
|
||||
return current_chain_mode;
|
||||
}
|
||||
|
||||
void previous_chain_menu_item() {
|
||||
xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY);
|
||||
switch (chain_menu) {
|
||||
case ChainMenu::Gain:
|
||||
break;
|
||||
@ -99,12 +86,10 @@ void previous_chain_menu_item() {
|
||||
update_value();
|
||||
break;
|
||||
}
|
||||
xSemaphoreGiveRecursive(state_mutex);
|
||||
update_leds();
|
||||
}
|
||||
|
||||
void next_chain_menu_item() {
|
||||
xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY);
|
||||
switch (chain_menu) {
|
||||
case ChainMenu::Gain:
|
||||
chain_menu = ChainMenu::Fader;
|
||||
@ -119,19 +104,15 @@ void next_chain_menu_item() {
|
||||
case ChainMenu::Master:
|
||||
break;
|
||||
}
|
||||
xSemaphoreGiveRecursive(state_mutex);
|
||||
update_leds();
|
||||
}
|
||||
|
||||
ChainMenu get_chain_menu_item() {
|
||||
xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY);
|
||||
ChainMenu current_chain_menu = chain_menu;
|
||||
xSemaphoreGiveRecursive(state_mutex);
|
||||
return current_chain_menu;
|
||||
}
|
||||
|
||||
void increment_level(float value) {
|
||||
xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY);
|
||||
if(level_value_up_to_date) {
|
||||
level_value += value;
|
||||
if(state == State::ChainMenu
|
||||
@ -145,35 +126,26 @@ void increment_level(float value) {
|
||||
set_master(level_value);
|
||||
}
|
||||
}
|
||||
xSemaphoreGiveRecursive(state_mutex);
|
||||
update_leds();
|
||||
}
|
||||
|
||||
void set_level(float value) {
|
||||
xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY);
|
||||
level_value = value;
|
||||
level_value_up_to_date = true;
|
||||
xSemaphoreGiveRecursive(state_mutex);
|
||||
update_leds();
|
||||
}
|
||||
|
||||
float get_level() {
|
||||
xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY);
|
||||
float current_level_value = level_value;
|
||||
xSemaphoreGiveRecursive(state_mutex);
|
||||
return current_level_value;
|
||||
}
|
||||
|
||||
void set_meter(float value) {
|
||||
xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY);
|
||||
meter_value = value;
|
||||
xSemaphoreGiveRecursive(state_mutex);
|
||||
update_leds();
|
||||
}
|
||||
|
||||
float get_meter() {
|
||||
xSemaphoreTakeRecursive(state_mutex, portMAX_DELAY);
|
||||
float current_meter_value = meter_value;
|
||||
xSemaphoreGiveRecursive(state_mutex);
|
||||
return current_meter_value;
|
||||
}
|
||||
Loading…
x
Reference in New Issue
Block a user