Try and only use the PCM buffer low latency mode in sound settings when we really need to.

git-svn-id: svn://svn.rockbox.org/rockbox/trunk@16496 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
Dan Everton 2008-03-03 11:06:04 +00:00
parent 48a79ade6f
commit 0466319a75
5 changed files with 117 additions and 35 deletions

View file

@ -10,6 +10,7 @@ filetypes.c
language.c language.c
main.c main.c
menu.c menu.c
menus/menu_common.c
menus/display_menu.c menus/display_menu.c
menus/theme_menu.c menus/theme_menu.c
#if CONFIG_CODEC == SWCODEC #if CONFIG_CODEC == SWCODEC

View file

@ -46,6 +46,7 @@
#include "keyboard.h" #include "keyboard.h"
#include "gui/scrollbar.h" #include "gui/scrollbar.h"
#include "eq_menu.h" #include "eq_menu.h"
#include "menu_common.h"
/* /*
* Utility functions * Utility functions
@ -615,8 +616,7 @@ MENUITEM_FUNCTION(eq_save, 0, ID2P(LANG_EQUALIZER_SAVE),
MENUITEM_FUNCTION(eq_browse, 0, ID2P(LANG_EQUALIZER_BROWSE), MENUITEM_FUNCTION(eq_browse, 0, ID2P(LANG_EQUALIZER_BROWSE),
(int(*)(void))eq_browse_presets, NULL, NULL, Icon_NOICON); (int(*)(void))eq_browse_presets, NULL, NULL, Icon_NOICON);
int soundmenu_callback(int action,const struct menu_item_ex *this_item); MAKE_MENU(equalizer_menu, ID2P(LANG_EQUALIZER), lowlatency_callback, Icon_EQ,
MAKE_MENU(equalizer_menu, ID2P(LANG_EQUALIZER), soundmenu_callback, Icon_EQ,
&eq_enable, &eq_graphical, &eq_precut, &gain_menu, &eq_enable, &eq_graphical, &eq_precut, &gain_menu,
&advanced_eq_menu_, &eq_save, &eq_browse); &advanced_eq_menu_, &eq_save, &eq_browse);

47
apps/menus/menu_common.c Normal file
View file

@ -0,0 +1,47 @@
/***************************************************************************
* __________ __ ___.
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
* \/ \/ \/ \/ \/
* $Id$
*
* Copyright (C) 2008 Dan Everton
*
* All files in this archive are subject to the GNU General Public License.
* See the file COPYING in the source tree root for full license agreement.
*
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
* KIND, either express or implied.
*
****************************************************************************/
#include <stddef.h>
#include <limits.h>
#include "config.h"
#include "action.h"
#include "menu.h"
#include "menu_common.h"
#if CONFIG_CODEC == SWCODEC
#include "pcmbuf.h"
#endif
#if CONFIG_CODEC == SWCODEC
/* Use this callback if your menu adjusts DSP settings. */
int lowlatency_callback(int action, const struct menu_item_ex *this_item)
{
(void)this_item;
switch (action)
{
case ACTION_ENTER_MENUITEM: /* on entering an item */
pcmbuf_set_low_latency(true);
break;
case ACTION_EXIT_MENUITEM: /* on exit */
pcmbuf_set_low_latency(false);
break;
}
return action;
}
#endif

30
apps/menus/menu_common.h Normal file
View file

@ -0,0 +1,30 @@
/***************************************************************************
* __________ __ ___.
* Open \______ \ ____ ____ | | _\_ |__ _______ ___
* Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
* Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
* Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
* \/ \/ \/ \/ \/
* $Id$
*
* Copyright (C) 2008 Dan Everton
*
* All files in this archive are subject to the GNU General Public License.
* See the file COPYING in the source tree root for full license agreement.
*
* This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
* KIND, either express or implied.
*
****************************************************************************/
#ifndef _MENU_COMMON_H
#define _MENU_COMMON_H
#include "menu.h"
#include "config.h"
#if CONFIG_CODEC == SWCODEC
int lowlatency_callback(int action, const struct menu_item_ex *this_item);
#endif
#endif /* _MENU_COMMON_H */

View file

@ -32,60 +32,64 @@
#include "pcmbuf.h" #include "pcmbuf.h"
#endif #endif
#include "exported_menus.h" #include "exported_menus.h"
#include "menu_common.h"
/***********************************/ /***********************************/
/* SOUND MENU */ /* SOUND MENU */
#if CONFIG_CODEC == SWCODEC MENUITEM_SETTING(volume, &global_settings.volume, NULL);
/* This callback is also used in the eq menu to toggle low latency mode. MENUITEM_SETTING(bass, &global_settings.bass,
So, remember this if the callback is used for anything other than the togging */ #ifdef HAVE_SW_TONE_CONTROLS
int soundmenu_callback(int action, const struct menu_item_ex *this_item) lowlatency_callback
{
(void)this_item;
switch (action)
{
case ACTION_ENTER_MENUITEM: /* on entering an item */
pcmbuf_set_low_latency(true);
break;
case ACTION_EXIT_MENUITEM: /* on exit */
pcmbuf_set_low_latency(false);
break;
}
return action;
}
#else #else
#define soundmenu_callback NULL NULL
#endif #endif
);
MENUITEM_SETTING(volume, &global_settings.volume, soundmenu_callback);
MENUITEM_SETTING(bass, &global_settings.bass, soundmenu_callback);
#ifdef HAVE_WM8758 #ifdef HAVE_WM8758
MENUITEM_SETTING(bass_cutoff, &global_settings.bass_cutoff, soundmenu_callback); MENUITEM_SETTING(bass_cutoff, &global_settings.bass_cutoff, NULL);
#endif #endif
MENUITEM_SETTING(treble, &global_settings.treble, soundmenu_callback); MENUITEM_SETTING(treble, &global_settings.treble,
#ifdef HAVE_SW_TONE_CONTROLS
lowlatency_callback
#else
NULL
#endif
);
#ifdef HAVE_WM8758 #ifdef HAVE_WM8758
MENUITEM_SETTING(treble_cutoff, &global_settings.treble_cutoff, soundmenu_callback); MENUITEM_SETTING(treble_cutoff, &global_settings.treble_cutoff, NULL);
#endif #endif
MENUITEM_SETTING(balance, &global_settings.balance, soundmenu_callback); MENUITEM_SETTING(balance, &global_settings.balance, NULL);
MENUITEM_SETTING(channel_config, &global_settings.channel_config, soundmenu_callback); MENUITEM_SETTING(channel_config, &global_settings.channel_config,
MENUITEM_SETTING(stereo_width, &global_settings.stereo_width, soundmenu_callback); #if CONFIG_CODEC == SWCODEC
lowlatency_callback
#else
NULL
#endif
);
MENUITEM_SETTING(stereo_width, &global_settings.stereo_width,
#if CONFIG_CODEC == SWCODEC
lowlatency_callback
#else
NULL
#endif
);
#if CONFIG_CODEC == SWCODEC #if CONFIG_CODEC == SWCODEC
/* Crossfeed Submenu */ /* Crossfeed Submenu */
MENUITEM_SETTING(crossfeed, &global_settings.crossfeed, soundmenu_callback); MENUITEM_SETTING(crossfeed, &global_settings.crossfeed, lowlatency_callback);
MENUITEM_SETTING(crossfeed_direct_gain, MENUITEM_SETTING(crossfeed_direct_gain,
&global_settings.crossfeed_direct_gain, soundmenu_callback); &global_settings.crossfeed_direct_gain, lowlatency_callback);
MENUITEM_SETTING(crossfeed_cross_gain, MENUITEM_SETTING(crossfeed_cross_gain,
&global_settings.crossfeed_cross_gain, soundmenu_callback); &global_settings.crossfeed_cross_gain, lowlatency_callback);
MENUITEM_SETTING(crossfeed_hf_attenuation, MENUITEM_SETTING(crossfeed_hf_attenuation,
&global_settings.crossfeed_hf_attenuation, soundmenu_callback); &global_settings.crossfeed_hf_attenuation, lowlatency_callback);
MENUITEM_SETTING(crossfeed_hf_cutoff, MENUITEM_SETTING(crossfeed_hf_cutoff,
&global_settings.crossfeed_hf_cutoff, soundmenu_callback); &global_settings.crossfeed_hf_cutoff, lowlatency_callback);
MAKE_MENU(crossfeed_menu,ID2P(LANG_CROSSFEED), NULL, Icon_NOICON, MAKE_MENU(crossfeed_menu,ID2P(LANG_CROSSFEED), NULL, Icon_NOICON,
&crossfeed, &crossfeed_direct_gain, &crossfeed_cross_gain, &crossfeed, &crossfeed_direct_gain, &crossfeed_cross_gain,
&crossfeed_hf_attenuation, &crossfeed_hf_cutoff); &crossfeed_hf_attenuation, &crossfeed_hf_cutoff);
MENUITEM_SETTING(dithering_enabled, MENUITEM_SETTING(dithering_enabled,
&global_settings.dithering_enabled, soundmenu_callback); &global_settings.dithering_enabled, lowlatency_callback);
#endif #endif
#if (CONFIG_CODEC == MAS3587F) || (CONFIG_CODEC == MAS3539F) #if (CONFIG_CODEC == MAS3587F) || (CONFIG_CODEC == MAS3539F)