2019-05-27 08:55:01 +02:00
// SPDX-License-Identifier: GPL-2.0-or-later
2011-11-02 08:36:06 +01:00
/*
* Helper functions for jack - detection kcontrols
*
* Copyright ( c ) 2011 Takashi Iwai < tiwai @ suse . de >
*/
# include <linux/kernel.h>
2011-11-16 14:28:33 +01:00
# include <linux/export.h>
2011-11-02 08:36:06 +01:00
# include <sound/core.h>
# include <sound/control.h>
# define jack_detect_kctl_info snd_ctl_boolean_mono_info
static int jack_detect_kctl_get ( struct snd_kcontrol * kcontrol ,
struct snd_ctl_elem_value * ucontrol )
{
ucontrol - > value . integer . value [ 0 ] = kcontrol - > private_value ;
return 0 ;
}
2017-05-27 20:16:15 +05:30
static const struct snd_kcontrol_new jack_detect_kctl = {
2011-11-02 08:36:06 +01:00
/* name is filled later */
. iface = SNDRV_CTL_ELEM_IFACE_CARD ,
. access = SNDRV_CTL_ELEM_ACCESS_READ ,
. info = jack_detect_kctl_info ,
. get = jack_detect_kctl_get ,
} ;
2015-04-27 21:20:57 +08:00
static int get_available_index ( struct snd_card * card , const char * name )
{
struct snd_ctl_elem_id sid ;
memset ( & sid , 0 , sizeof ( sid ) ) ;
sid . index = 0 ;
sid . iface = SNDRV_CTL_ELEM_IFACE_CARD ;
ALSA: Convert strlcpy to strscpy when return value is unused
strlcpy is deprecated. see: Documentation/process/deprecated.rst
Change the calls that do not use the strlcpy return value to the
preferred strscpy.
Done with cocci script:
@@
expression e1, e2, e3;
@@
- strlcpy(
+ strscpy(
e1, e2, e3);
This cocci script leaves the instances where the return value is
used unchanged.
After this patch, sound/ has 3 uses of strlcpy() that need to be
manually inspected for conversion and changed one day.
$ git grep -w strlcpy sound/
sound/usb/card.c: len = strlcpy(card->longname, s, sizeof(card->longname));
sound/usb/mixer.c: return strlcpy(buf, p->name, buflen);
sound/usb/mixer.c: return strlcpy(buf, p->names[index], buflen);
Miscellenea:
o Remove trailing whitespace in conversion of sound/core/hwdep.c
Link: https://lore.kernel.org/lkml/CAHk-=wgfRnXz0W3D37d01q3JFkr_i_uTL=V6A6G1oUZcprmknw@mail.gmail.com/
Signed-off-by: Joe Perches <joe@perches.com>
Acked-by: Mark Brown <broonie@kernel.org>
Link: https://lore.kernel.org/r/22b393d1790bb268769d0bab7bacf0866dcb0c14.camel@perches.com
Signed-off-by: Takashi Iwai <tiwai@suse.de>
2021-01-04 09:17:34 -08:00
strscpy ( sid . name , name , sizeof ( sid . name ) ) ;
2015-04-27 21:20:57 +08:00
2015-06-26 06:59:57 +02:00
while ( snd_ctl_find_id ( card , & sid ) ) {
2015-04-27 21:20:57 +08:00
sid . index + + ;
2015-06-26 06:59:57 +02:00
/* reset numid; otherwise snd_ctl_find_id() hits this again */
sid . numid = 0 ;
}
2015-04-27 21:20:57 +08:00
return sid . index ;
}
static void jack_kctl_name_gen ( char * name , const char * src_name , int size )
{
size_t count = strlen ( src_name ) ;
bool need_cat = true ;
/* remove redundant " Jack" from src_name */
if ( count > = 5 )
need_cat = strncmp ( & src_name [ count - 5 ] , " Jack " , 5 ) ? true : false ;
snprintf ( name , size , need_cat ? " %s Jack " : " %s " , src_name ) ;
}
2011-11-02 08:36:06 +01:00
struct snd_kcontrol *
2015-04-27 21:20:59 +08:00
snd_kctl_jack_new ( const char * name , struct snd_card * card )
2011-11-02 08:36:06 +01:00
{
struct snd_kcontrol * kctl ;
2015-04-27 21:20:57 +08:00
2015-04-27 21:20:59 +08:00
kctl = snd_ctl_new1 ( & jack_detect_kctl , NULL ) ;
2011-11-02 08:36:06 +01:00
if ( ! kctl )
return NULL ;
2015-04-27 21:20:57 +08:00
jack_kctl_name_gen ( kctl - > id . name , name , sizeof ( kctl - > id . name ) ) ;
2015-05-29 14:06:32 +02:00
kctl - > id . index = get_available_index ( card , kctl - > id . name ) ;
2011-11-02 08:36:06 +01:00
kctl - > private_value = 0 ;
return kctl ;
}
void snd_kctl_jack_report ( struct snd_card * card ,
struct snd_kcontrol * kctl , bool status )
{
if ( kctl - > private_value = = status )
return ;
kctl - > private_value = status ;
snd_ctl_notify ( card , SNDRV_CTL_EVENT_MASK_VALUE , & kctl - > id ) ;
}