[alsa-devel] [PATCH] hda-emu: Make it work with sound-unstable.git
Takashi Iwai
tiwai at suse.de
Tue Jan 15 15:32:03 CET 2013
At Tue, 15 Jan 2013 15:18:41 +0100,
David Henningsson wrote:
>
> To be able to build the new code (so we can run aggregate tests on it)
> the following patch needs to be applied.
>
> Signed-off-by: David Henningsson <david.henningsson at canonical.com>
Ah sorry, I forgot to push my local tree...
Takashi
> ---
> configure.ac | 8 +++++++
> hda-ctlsh.c | 5 ++++
> include/linux/ctype.h | 64 +++++++++++++++++++++++++++++++++++++++++++++++++
> snd-wrapper.c | 32 +++++++++++++++++++++++++
> 4 files changed, 109 insertions(+)
> create mode 100644 include/linux/ctype.h
>
> diff --git a/configure.ac b/configure.ac
> index 3103eb5..80b68a6 100644
> --- a/configure.ac
> +++ b/configure.ac
> @@ -182,6 +182,14 @@ if test "$OLD_HDA_CMD" = "1"; then
> AC_DEFINE(OLD_HDA_CMD)
> fi
>
> +AC_MSG_CHECKING(for user_mutex)
> +if grep -q 'struct mutex user_mutex' hda/hda_codec.h; then
> + AC_DEFINE(HAVE_USER_MUTEX)
> + AC_MSG_RESULT(yes)
> +else
> + AC_MSG_RESULT(no)
> +fi
> +
> AC_MSG_CHECKING(for new pm_notify callback)
> ac_save_CFLAGS="$CFLAGS"
> CFLAGS="$CFLAGS -Iinclude"
> diff --git a/hda-ctlsh.c b/hda-ctlsh.c
> index 5ad95fc..04fc318 100644
> --- a/hda-ctlsh.c
> +++ b/hda-ctlsh.c
> @@ -537,6 +537,11 @@ int snd_hda_get_bool_hint(struct hda_codec *codec, const char *key)
> return -ENOENT;
> }
>
> +int snd_hda_get_int_hint(struct hda_codec *codec, const char *key, int *valp)
> +{
> + return -ENOENT;
> +}
> +
> #ifdef HAVE_USER_PINCFGS
> static void get_drv_pincfgs(void)
> {
> diff --git a/include/linux/ctype.h b/include/linux/ctype.h
> new file mode 100644
> index 0000000..8acfe31
> --- /dev/null
> +++ b/include/linux/ctype.h
> @@ -0,0 +1,64 @@
> +#ifndef _LINUX_CTYPE_H
> +#define _LINUX_CTYPE_H
> +
> +/*
> + * NOTE! This ctype does not handle EOF like the standard C
> + * library is required to.
> + */
> +
> +#define _U 0x01 /* upper */
> +#define _L 0x02 /* lower */
> +#define _D 0x04 /* digit */
> +#define _C 0x08 /* cntrl */
> +#define _P 0x10 /* punct */
> +#define _S 0x20 /* white space (space/lf/tab) */
> +#define _X 0x40 /* hex digit */
> +#define _SP 0x80 /* hard space (0x20) */
> +
> +extern const unsigned char _ctype[];
> +
> +#define __ismask(x) (_ctype[(int)(unsigned char)(x)])
> +
> +#define isalnum(c) ((__ismask(c)&(_U|_L|_D)) != 0)
> +#define isalpha(c) ((__ismask(c)&(_U|_L)) != 0)
> +#define iscntrl(c) ((__ismask(c)&(_C)) != 0)
> +#define isdigit(c) ((__ismask(c)&(_D)) != 0)
> +#define isgraph(c) ((__ismask(c)&(_P|_U|_L|_D)) != 0)
> +#define islower(c) ((__ismask(c)&(_L)) != 0)
> +#define isprint(c) ((__ismask(c)&(_P|_U|_L|_D|_SP)) != 0)
> +#define ispunct(c) ((__ismask(c)&(_P)) != 0)
> +/* Note: isspace() must return false for %NUL-terminator */
> +#define isspace(c) ((__ismask(c)&(_S)) != 0)
> +#define isupper(c) ((__ismask(c)&(_U)) != 0)
> +#define isxdigit(c) ((__ismask(c)&(_D|_X)) != 0)
> +
> +#define isascii(c) (((unsigned char)(c))<=0x7f)
> +#define toascii(c) (((unsigned char)(c))&0x7f)
> +
> +static inline unsigned char __tolower(unsigned char c)
> +{
> + if (isupper(c))
> + c -= 'A'-'a';
> + return c;
> +}
> +
> +static inline unsigned char __toupper(unsigned char c)
> +{
> + if (islower(c))
> + c -= 'a'-'A';
> + return c;
> +}
> +
> +#define tolower(c) __tolower(c)
> +#define toupper(c) __toupper(c)
> +
> +/*
> + * Fast implementation of tolower() for internal usage. Do not use in your
> + * code.
> + */
> +static inline char _tolower(const char c)
> +{
> + return c | 0x20;
> +}
> +
> +#endif
> diff --git a/snd-wrapper.c b/snd-wrapper.c
> index 69cd19c..c2649d9 100644
> --- a/snd-wrapper.c
> +++ b/snd-wrapper.c
> @@ -27,6 +27,35 @@
> #include "hda/hda_codec.h"
> #include "hda-types.h"
> #include "hda-log.h"
> +#include <linux/ctype.h>
> +
> +/* Copied from lib/ctype.c */
> +const unsigned char _ctype[] = {
> +_C,_C,_C,_C,_C,_C,_C,_C, /* 0-7 */
> +_C,_C|_S,_C|_S,_C|_S,_C|_S,_C|_S,_C,_C, /* 8-15 */
> +_C,_C,_C,_C,_C,_C,_C,_C, /* 16-23 */
> +_C,_C,_C,_C,_C,_C,_C,_C, /* 24-31 */
> +_S|_SP,_P,_P,_P,_P,_P,_P,_P, /* 32-39 */
> +_P,_P,_P,_P,_P,_P,_P,_P, /* 40-47 */
> +_D,_D,_D,_D,_D,_D,_D,_D, /* 48-55 */
> +_D,_D,_P,_P,_P,_P,_P,_P, /* 56-63 */
> +_P,_U|_X,_U|_X,_U|_X,_U|_X,_U|_X,_U|_X,_U, /* 64-71 */
> +_U,_U,_U,_U,_U,_U,_U,_U, /* 72-79 */
> +_U,_U,_U,_U,_U,_U,_U,_U, /* 80-87 */
> +_U,_U,_U,_P,_P,_P,_P,_P, /* 88-95 */
> +_P,_L|_X,_L|_X,_L|_X,_L|_X,_L|_X,_L|_X,_L, /* 96-103 */
> +_L,_L,_L,_L,_L,_L,_L,_L, /* 104-111 */
> +_L,_L,_L,_L,_L,_L,_L,_L, /* 112-119 */
> +_L,_L,_L,_P,_P,_P,_P,_C, /* 120-127 */
> +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* 128-143 */
> +0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0, /* 144-159 */
> +_S|_SP,_P,_P,_P,_P,_P,_P,_P,_P,_P,_P,_P,_P,_P,_P,_P, /* 160-175 */
> +_P,_P,_P,_P,_P,_P,_P,_P,_P,_P,_P,_P,_P,_P,_P,_P, /* 176-191 */
> +_U,_U,_U,_U,_U,_U,_U,_U,_U,_U,_U,_U,_U,_U,_U,_U, /* 192-207 */
> +_U,_U,_U,_U,_U,_U,_U,_P,_U,_U,_U,_U,_U,_U,_U,_L, /* 208-223 */
> +_L,_L,_L,_L,_L,_L,_L,_L,_L,_L,_L,_L,_L,_L,_L,_L, /* 224-239 */
> +_L,_L,_L,_L,_L,_L,_L,_P,_L,_L,_L,_L,_L,_L,_L,_L}; /* 240-255 */
> +
>
> int snd_pcm_format_width(int format)
> {
> @@ -46,6 +75,9 @@ int snd_pcm_format_width(int format)
>
> int snd_hda_create_hwdep(struct hda_codec *codec)
> {
> +#ifdef HAVE_USER_MUTEX
> + mutex_init(&codec->user_mutex);
> +#endif
> return 0;
> }
>
> --
> 1.7.9.5
>
More information about the Alsa-devel
mailing list