make targets "loadable"

This commit is contained in:
Philippe G
2022-01-20 17:30:36 -08:00
parent 964b94fa1e
commit dbdd0739db
10 changed files with 72 additions and 30 deletions

View File

@@ -12,6 +12,8 @@ CONFIG_DISPLAY_CONFIG=""
CONFIG_I2C_CONFIG=""
CONFIG_SPI_CONFIG=""
CONFIG_SET_GPIO=""
CONFIG_TARGET_LOCKED=n
CONFIG_TARGET=""
CONFIG_GPIO_EXP_CONFIG=""
CONFIG_ROTARY_ENCODER=""
CONFIG_LED_GREEN_GPIO=-1

View File

@@ -12,7 +12,8 @@ CONFIG_AMP_LOCKED=y
CONFIG_JACK_LOCKED=y
CONFIG_BAT_LOCKED=y
CONFIG_I2C_LOCKED=y
CONFIG_WELL_KNOWN=y
CONFIG_TARGET_LOCKED=y
CONFIG_TARGET="muse"
CONFIG_DISPLAY_CONFIG=""
CONFIG_I2C_CONFIG=""
CONFIG_SPI_CONFIG="mosi=15,miso=2,clk=14"

View File

@@ -12,7 +12,8 @@ CONFIG_JACK_LOCKED=y
CONFIG_BAT_LOCKED=y
CONFIG_I2C_LOCKED=y
CONFIG_LED_LOCKED=y
CONFIG_WELL_KNOWN=y
CONFIG_TARGET_LOCKED=y
CONFIG_TARGET="squeezeamp"
CONFIG_DISPLAY_CONFIG=""
CONFIG_I2C_CONFIG=""
CONFIG_SPI_CONFIG=""

View File

@@ -1,13 +1,4 @@
# This should be made a pure CMake component but as CMake is even
# more shitty under Windows, backslash in path screws it all
if(CONFIG_MUSE)
message("Compiling for MUSE")
set(src_dirs "muse")
else()
set(src_dirs ".")
endif()
idf_component_register( SRC_DIRS ${src_dirs}
idf_component_register( SRC_DIRS . muse
INCLUDE_DIRS .
PRIV_REQUIRES services
)

View File

@@ -1,3 +0,0 @@
// weak should do the job but it does not...
__attribute__((weak)) void target_init(void) {
}

View File

@@ -10,6 +10,7 @@
//#include <driver/adc.h>
#include "driver/rmt.h"
#include "monitor.h"
#include "targets.h"
/////////////////////////////////////////////////////////////////
//*********************** NeoPixels ***************************
@@ -44,11 +45,15 @@ static const char TAG[] = "muse";
static void (*battery_handler_chain)(float value);
static void battery_svc(float value);
static bool init(void);
void target_init(void) {
const struct target_s target_muse = { "muse", init };
static bool init(void) {
battery_handler_chain = battery_handler_svc;
battery_handler_svc = battery_svc;
ESP_LOGI(TAG, "Initializing for Muse");
return true;
}
static void battery_svc(float value) {

View File

@@ -0,0 +1,11 @@
#include "string.h"
#include "targets.h"
const struct target_s *target_set[] = { &target_muse, NULL };
void target_init(char *target) {
for (int i = 0; target_set[i]; i++) if (strcasestr(target_set[i]->model, target)) {
target_set[i]->init();
break;
}
}

View File

@@ -0,0 +1,22 @@
/*
* Squeezelite for esp32
*
* (c) Sebastien 2019
* Philippe G. 2019, philippe_44@outlook.com
*
* This software is released under the MIT License.
* https://opensource.org/licenses/MIT
*
*/
#pragma once
#include "stddef.h"
#include "stdbool.h"
struct target_s {
char *model;
bool (*init)(void);
};
extern const struct target_s target_muse;

View File

@@ -21,6 +21,9 @@ menu "Squeezelite-ESP32"
help
Set logging level info|debug|sdebug
endmenu
config TARGET_LOCKED
bool
default n
config AMP_LOCKED
bool
config JACK_LOCKED
@@ -38,9 +41,6 @@ menu "Squeezelite-ESP32"
config MUTE_GPIO_LEVEL
int
default 0
config WELL_KNOWN
bool
default n
menu "Target"
choice OUTPUT_TYPE
prompt "Main system"
@@ -54,20 +54,20 @@ menu "Squeezelite-ESP32"
select I2C_LOCKED
select LED_LOCKED
select SPKFAULT_LOCKED
select WELL_KNOWN
select TARGET_LOCKED
config MUSE
bool "Muse"
select JACK_LOCKED
select BAT_LOCKED
select I2C_LOCKED
select AMP_LOCKED
select WELL_KNOWN
select TARGET_LOCKED
config BASIC_I2C_BT
bool "Generic I2S & Bluetooth"
config TWATCH2020
bool "T-WATCH2020 by LilyGo"
select I2C_LOCKED
select WELL_KNOWN
select TARGET_LOCKED
endchoice
config RELEASE_API
string "Software update URL"
@@ -131,9 +131,14 @@ menu "Squeezelite-ESP32"
default "[{\"gpio\":32, \"pull\":true, \"debounce\":10, \"normal\":{\"pressed\":\"ACTRLS_VOLDOWN\"}}, {\"gpio\":19, \"pull\":true, \"debounce\":40, \"normal\":{\"pressed\":\"ACTRLS_VOLUP\"}}, {\"gpio\":12, \"pull\":true, \"debounce\":40, \"longpress\":1000, \"normal\":{\"pressed\":\"ACTRLS_TOGGLE\"},\"longpress\":{\"pressed\":\"ACTRLS_POWER\"}}]" if MUSE
default ""
config BAT_CONFIG
string
default "channel=7,scale=20.24,atten=0" if SQUEEZEAMP
default "channel=5,scale=1,atten=3,cells=1" if MUSE
default ""
config TARGET
string
default "muse" if MUSE
default ""
endmenu
menu "Audio settings"
@@ -325,7 +330,7 @@ menu "Squeezelite-ESP32"
endmenu
menu "LED configuration"
visible if !WELL_KNOWN
visible if !TARGET_LOCKED
config LED_GREEN_GPIO
int "Green led GPIO"
default 12 if SQUEEZEAMP
@@ -352,7 +357,7 @@ menu "Squeezelite-ESP32"
endmenu
menu "Audio JACK"
visible if !WELL_KNOWN
visible if !TARGET_LOCKED
config JACK_GPIO
int "Jack insertion GPIO"
default 34 if SQUEEZEAMP || MUSE
@@ -366,7 +371,7 @@ menu "Squeezelite-ESP32"
endmenu
menu "Amplifier"
visible if !WELL_KNOWN
visible if !TARGET_LOCKED
config AMP_GPIO
int "Amplifier GPIO"
default 21 if MUSE
@@ -380,7 +385,7 @@ menu "Squeezelite-ESP32"
endmenu
menu "Speaker Fault"
visible if !WELL_KNOWN
visible if !TARGET_LOCKED
config SPKFAULT_GPIO
int "Speaker fault GPIO"
default 2 if SQUEEZEAMP
@@ -394,7 +399,7 @@ menu "Squeezelite-ESP32"
endmenu
menu "Battery measure"
visible if !WELL_KNOWN
visible if !TARGET_LOCKED
config BAT_CONFIG
string "Battery acquisitiong configuration"
help

View File

@@ -68,7 +68,7 @@ extern const uint8_t server_cert_pem_end[] asm("_binary_github_pem_end");
// as an exception _init function don't need include
extern void services_init(void);
extern void display_init(char *welcome);
extern void target_init(void);
extern void target_init(char *target);
const char * str_or_unknown(const char * str) { return (str?str:unknown_string_placeholder); }
const char * str_or_null(const char * str) { return (str?str:null_string_placeholder); }
bool is_recovery_running;
@@ -421,6 +421,9 @@ void register_default_nvs(){
ESP_LOGD(TAG,"Registering default value for key %s", "rel_api");
config_set_default(NVS_TYPE_STR, "rel_api", CONFIG_RELEASE_API, 0);
ESP_LOGD(TAG,"Registering default value for key %s", "target");
config_set_default(NVS_TYPE_STR, "target", "", 0);
wait_for_commit();
ESP_LOGD(TAG,"Done setting default values in nvs.");
@@ -475,7 +478,11 @@ void app_main()
ESP_LOGI(TAG,"Initializing display");
display_init("SqueezeESP32");
target_init();
char *target = config_alloc_get_default(NVS_TYPE_STR, "target", CONFIG_TARGET, 0);
if (target) {
target_init(target);
free(target);
}
if(is_recovery_running && display){
GDS_ClearExt(display, true);