From 040306a71663d98f1ca568b61010ee125d1e6501 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Udo=20Schl=C3=A4pfer?= Date: Fri, 30 Jan 2015 22:47:30 +0100 Subject: iBasso DX50/DX90: User selectable freq scaling governor. Depends on http://gerrit.rockbox.org/r/#/c/1043/. This patch adds a new setting in Settings -> General -> System: Freq Scaling Governor Usable in Quickscreen and Shortcuts. Possible settings are: - Conservative: Slow frequency switching. - Ondemand or Interactive: Fast frequency switching. - Powersave: Allways lowest frequency. - Performance: Allways highest frequency. German translation provided. This may be genric for Android kernel based devices but is only enabled for iBasso Devices. Other maintainers may choose do adopt this. Change-Id: I10296f5be9586ad3a409105db0cd03682a30e9c1 --- apps/lang/deutsch.lang | 21 +++++++++++++++++++++ apps/lang/english.lang | 20 ++++++++++++++++++++ apps/menus/settings_menu.c | 12 ++++++++++++ apps/settings.c | 9 +++++++++ apps/settings.h | 4 ++++ apps/settings_list.c | 20 ++++++++++++++++++++ 6 files changed, 86 insertions(+) (limited to 'apps') diff --git a/apps/lang/deutsch.lang b/apps/lang/deutsch.lang index 55377c2..6d9c025 100644 --- a/apps/lang/deutsch.lang +++ b/apps/lang/deutsch.lang @@ -33,6 +33,7 @@ # - Kaspar Rothenfußer # - Johannes Linke # - Kai Posadowsky +# - Udo Schläpfer id: LANG_SET_BOOL_YES desc: bool true representation @@ -13054,3 +13055,23 @@ *: "Beschränke automatischen Verzeichniswechsel" + + id: LANG_IBASSO_FREQ_SCALING_GOVERNOR + desc: in Settings -> General -> System -> Freq Scaling Governor + user: core + + *: none + ibassodx50: "Freq Scaling Governor" + ibassodx90: "Freq Scaling Governor" + + + *: none + ibassodx50: "Freq Scaling Governor" + ibassodx90: "Freq Scaling Governor" + + + *: none + ibassodx50: "Freq Scaling Governor" + ibassodx90: "Freq Scaling Governor" + + diff --git a/apps/lang/english.lang b/apps/lang/english.lang index ca5e687..081e33d 100644 --- a/apps/lang/english.lang +++ b/apps/lang/english.lang @@ -13373,3 +13373,23 @@ swcodec: "Dry / Wet Mix" + + id: LANG_IBASSO_FREQ_SCALING_GOVERNOR + desc: in Settings -> General -> System -> Freq Scaling Governor + user: core + + *: none + ibassodx50: "Freq Scaling Governor" + ibassodx90: "Freq Scaling Governor" + + + *: none + ibassodx50: "Freq Scaling Governor" + ibassodx90: "Freq Scaling Governor" + + + *: none + ibassodx50: "Freq Scaling Governor" + ibassodx90: "Freq Scaling Governor" + + diff --git a/apps/menus/settings_menu.c b/apps/menus/settings_menu.c index 130f5be..6fcc3e9 100644 --- a/apps/menus/settings_menu.c +++ b/apps/menus/settings_menu.c @@ -50,6 +50,10 @@ #endif #include "folder_select.h" +#if defined(DX50) || defined(DX90) +#include "governor-ibasso.h" +#endif + /***********************************/ /* TAGCACHE MENU */ #ifdef HAVE_TAGCACHE @@ -325,6 +329,10 @@ MENUITEM_SETTING(touchpad_deadzone, &global_settings.touchpad_deadzone, NULL); MENUITEM_SETTING(shortcuts_replaces_quickscreen, &global_settings.shortcuts_replaces_qs, NULL); #endif +#if defined(DX50) || defined(DX90) +MENUITEM_SETTING(governor, &global_settings.governor, NULL); +#endif + MAKE_MENU(system_menu, ID2P(LANG_SYSTEM), 0, Icon_System_menu, #if (BATTERY_CAPACITY_INC > 0) || (BATTERY_TYPES_COUNT > 1) @@ -377,6 +385,10 @@ MAKE_MENU(system_menu, ID2P(LANG_SYSTEM), #if defined(USB_ENABLE_STORAGE) && defined(HAVE_MULTIDRIVE) &usb_skip_first_drive, #endif + +#if defined(DX50) || defined(DX90) + &governor, +#endif ); /* SYSTEM MENU */ diff --git a/apps/settings.c b/apps/settings.c index f144a4a..be7b7c3 100644 --- a/apps/settings.c +++ b/apps/settings.c @@ -105,6 +105,11 @@ struct system_status global_status; #include "lcd-remote.h" #endif +#if defined(DX50) || defined(DX90) +#include "governor-ibasso.h" +#endif + + long lasttime = 0; /** NVRAM stuff, if the target doesnt have NVRAM it is saved in ROCKBOX_DIR /nvram.bin **/ @@ -1081,6 +1086,10 @@ void settings_apply(bool read_disk) memcpy(&calibration_parameters, &global_settings.ts_calibration_data, sizeof(struct touchscreen_parameter)); #endif +#if defined(DX50) || defined(DX90) + ibasso_set_governor(global_settings.governor); +#endif + /* This should stay last */ #if defined(HAVE_RECORDING) && CONFIG_CODEC == SWCODEC enc_global_settings_apply(); diff --git a/apps/settings.h b/apps/settings.h index 4ea56d2..5d25dc7 100644 --- a/apps/settings.h +++ b/apps/settings.h @@ -850,6 +850,10 @@ struct user_settings int pbe_precut; int afr_enabled; + +#if defined(DX50) || defined(DX90) + int governor; +#endif }; /** global variables **/ diff --git a/apps/settings_list.c b/apps/settings_list.c index abdb512..2c3f360 100644 --- a/apps/settings_list.c +++ b/apps/settings_list.c @@ -62,6 +62,10 @@ #include "onplay.h" #endif +#if defined(DX50) || defined(DX90) +#include "governor-ibasso.h" +#endif + #define NVRAM(bytes) (bytes<