[alsa-devel] [PATCH] topology: Add command line topology tool to build topology binaries

Takashi Iwai tiwai at suse.de
Tue Aug 4 17:02:24 CEST 2015


On Tue, 04 Aug 2015 16:54:27 +0200,
Liam Girdwood wrote:
> 
> Add a command line tool that will parse topology text files and convert to the binary
> topology data as used by the kernel.
> 
> Signed-off-by: Liam Girdwood <liam.r.girdwood at linux.intel.com>
> ---
>  Makefile.am          |   3 ++
>  configure.ac         |   5 ++-
>  topology/Makefile.am |  13 ++++++
>  topology/topology.c  | 117 +++++++++++++++++++++++++++++++++++++++++++++++++++
>  4 files changed, 137 insertions(+), 1 deletion(-)
>  create mode 100644 topology/Makefile.am
>  create mode 100644 topology/topology.c
> 
> diff --git a/Makefile.am b/Makefile.am
> index 5bbe588..613f62d 100644
> --- a/Makefile.am
> +++ b/Makefile.am
> @@ -25,6 +25,9 @@ endif
>  if HAVE_UCM
>  SUBDIRS += alsaucm
>  endif
> +if HAVE_TOPOLOGY
> +SUBDIRS += topology
> +endif
>  
>  EXTRA_DIST= TODO gitcompile
>  AUTOMAKE_OPTIONS=foreign
> diff --git a/configure.ac b/configure.ac
> index f09aa54..4c279a9 100644
> --- a/configure.ac
> +++ b/configure.ac
> @@ -50,6 +50,8 @@ AC_CHECK_HEADERS([alsa/seq.h], [have_seq="yes"], [have_seq="no"],
>    [#include <alsa/asoundlib.h>])
>  AC_CHECK_HEADERS([alsa/use-case.h], [have_ucm="yes"], [have_ucm="no"],
>    [#include <alsa/asoundlib.h>])
> +AC_CHECK_HEADERS([alsa/topology.h], [have_topology="yes"], [have_topology="no"],
> +  [#include <alsa/asoundlib.h>])
>  AC_CHECK_HEADERS([samplerate.h], [have_samplerate="yes"], [have_samplerate="no"],
>    [#include <samplerate.h>])
>  
> @@ -58,6 +60,7 @@ AM_CONDITIONAL(HAVE_MIXER, test "$have_mixer" = "yes")
>  AM_CONDITIONAL(HAVE_RAWMIDI, test "$have_rawmidi" = "yes")
>  AM_CONDITIONAL(HAVE_SEQ, test "$have_seq" = "yes")
>  AM_CONDITIONAL(HAVE_UCM, test "$have_ucm" = "yes")
> +AM_CONDITIONAL(HAVE_TOPOLOGY, test "$have_topology" = "yes")
>  AM_CONDITIONAL(HAVE_SAMPLERATE, test "$have_samplerate" = "yes")
>  
>  dnl Check for librt
> @@ -358,7 +361,7 @@ AC_OUTPUT(Makefile alsactl/Makefile alsactl/init/Makefile \
>  	  m4/Makefile po/Makefile.in \
>  	  alsaconf/alsaconf alsaconf/Makefile \
>  	  alsaconf/po/Makefile \
> -	  alsaucm/Makefile \
> +	  alsaucm/Makefile topology/Makefile \
>  	  aplay/Makefile include/Makefile iecset/Makefile utils/Makefile \
>  	  utils/alsa-utils.spec seq/Makefile seq/aconnect/Makefile \
>  	  seq/aplaymidi/Makefile seq/aseqdump/Makefile seq/aseqnet/Makefile \
> diff --git a/topology/Makefile.am b/topology/Makefile.am
> new file mode 100644
> index 0000000..f59ce01
> --- /dev/null
> +++ b/topology/Makefile.am
> @@ -0,0 +1,13 @@
> +bin_PROGRAMS = \
> +	alsatplg
> +
> +alsatplg_SOURCES = topology.c
> +
> +AM_CPPFLAGS = \
> +         -Wall -I$(top_srcdir)/include
> +
> +alsatplg_LDADD = -lasound
> +
> +# local build
> +AM_CPPFLAGS += -I$(top_srcdir)/../alsa-lib/include
> +alsatplg_LDADD = -L$(top_srcdir)/../alsa-lib/src/.libs

These two lines looks weird, the build shouldn't go beneath its root
directory.  Please drop them.
(Now I found the same in alsaucm, but it should have been overlooked.)


> diff --git a/topology/topology.c b/topology/topology.c
> new file mode 100644
> index 0000000..7049bb7
> --- /dev/null
> +++ b/topology/topology.c
> @@ -0,0 +1,117 @@
> +/*
> +  Copyright(c) 2014-2015 Intel Corporation
> +  Copyright(c) 2010-2011 Texas Instruments Incorporated,
> +  All rights reserved.
> +
> +  This program is free software; you can redistribute it and/or modify
> +  it under the terms of version 2 of the GNU General Public License as
> +  published by the Free Software Foundation.
> +
> +  This program is distributed in the hope that it will be useful, but
> +  WITHOUT ANY WARRANTY; without even the implied warranty of
> +  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
> +  General Public License for more details.
> +
> +  You should have received a copy of the GNU General Public License
> +  along with this program; if not, write to the Free Software
> +  Foundation, Inc., 51 Franklin St - Fifth Floor, Boston, MA 02110-1301 USA.
> +  The full GNU General Public License is included in this distribution
> +  in the file called LICENSE.GPL.
> +*/
> +
> +#include <stdlib.h>
> +#include <stdio.h>
> +#include <stdint.h>
> +#include <fcntl.h>
> +#include <unistd.h>
> +#include <errno.h>
> +#include <string.h>
> +#include <sys/stat.h>
> +#include <dlfcn.h>
> +#include <getopt.h>
> +#include <alsa/asoundlib.h>
> +#include <assert.h>
> +
> +#include "topology.h"

Use <alsa/topology.h>


thanks,

Takashi


More information about the Alsa-devel mailing list