summaryrefslogtreecommitdiff
path: root/apps
diff options
context:
space:
mode:
authorAidan MacDonald <amachronic@protonmail.com>2021-08-25 20:10:37 +0100
committerAidan MacDonald <amachronic@protonmail.com>2021-08-26 19:34:18 +0000
commit30e96a373210f47da7a25276d49d5f7672f893d5 (patch)
tree6d95a1033d9901dab901f1a536315089a5db700e /apps
parentb2386405b995ecb0b57addf743a128ee3c5b0a35 (diff)
quickscreen: fix EQ enable not working in quickscreen
The EQ enabled setting needs to call into the DSP core when it's changed but this was only hooked into the EQ menu. The quickscreen uses option_select_next_val() so those DSP hooks were not getting called because the setting did not have any callback defined. It seems this bug was introduced by 362f7a3220 removing the blanket call to settings_apply(). Other settings might be affected too. Change-Id: Idcce5809c525fa619e6bdf1be50c98a5df103fec
Diffstat (limited to 'apps')
-rw-r--r--apps/menus/eq_menu.c8
-rw-r--r--apps/menus/eq_menu.h3
-rw-r--r--apps/settings_list.c2
3 files changed, 12 insertions, 1 deletions
diff --git a/apps/menus/eq_menu.c b/apps/menus/eq_menu.c
index 656fe7b282..79389ae561 100644
--- a/apps/menus/eq_menu.c
+++ b/apps/menus/eq_menu.c
@@ -51,6 +51,8 @@
#include "option_select.h"
#include "string-extra.h"
+static void eq_apply(void);
+
/*
* Utility functions
*/
@@ -69,6 +71,12 @@ const char* eq_precut_format(char* buffer, size_t buffer_size, int value, const
return buffer;
}
+void eq_enabled_option_callback(bool enabled)
+{
+ (void)enabled;
+ eq_apply();
+}
+
/*
* Settings functions
*/
diff --git a/apps/menus/eq_menu.h b/apps/menus/eq_menu.h
index 04e8be2ead..f99f83d94f 100644
--- a/apps/menus/eq_menu.h
+++ b/apps/menus/eq_menu.h
@@ -48,4 +48,7 @@ const char* eq_q_format(char* buffer, size_t buffer_size, int value,
const char* eq_precut_format(char* buffer, size_t buffer_size, int value,
const char* unit);
+/* callbacks for settings_list.c */
+void eq_enabled_option_callback(bool enabled);
+
#endif
diff --git a/apps/settings_list.c b/apps/settings_list.c
index 5464416b21..ab99b58a1c 100644
--- a/apps/settings_list.c
+++ b/apps/settings_list.c
@@ -1570,7 +1570,7 @@ const struct settings_list settings[] = {
/* equalizer */
OFFON_SETTING(F_EQSETTING, eq_enabled, LANG_EQUALIZER_ENABLED, false,
- "eq enabled", NULL),
+ "eq enabled", eq_enabled_option_callback),
INT_SETTING_NOWRAP(F_EQSETTING, eq_precut, LANG_EQUALIZER_PRECUT, 0,
"eq precut", UNIT_DB, 0, 240, 1, eq_precut_format,