Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp8573239ybi; Tue, 23 Jul 2019 11:01:03 -0700 (PDT) X-Google-Smtp-Source: APXvYqwZ2qB37ZkG6vAURvKbOMg4F8zYy1o0rn8EQZaTg983+Kec01gm7Q0q9Ldt2EDMKSh1p0Yp X-Received: by 2002:a63:5754:: with SMTP id h20mr37392958pgm.195.1563904863129; Tue, 23 Jul 2019 11:01:03 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1563904863; cv=none; d=google.com; s=arc-20160816; b=RtC4aFZUOpqHWTl1PIyUoZwawbiGGdxzzm84x++s9EW8qs2rgSWuKO4poOlhNipS+c 5Hq32H5+iHPQunLdfT4AYRxUUiFvToK27MLVykJFFUBzUmxC4706d2U4Od+bzHHGLxfp dLgAxXAuePcPvP8dnf2yfbEjFEtkuOSADeBLABNDf+/TrlJduKMorapJVnvMtvDmR07m M9z8VK9vU9xW6spvVBTQ57InmXls0ewICiLsKztgFvBEvOfZuG4yDruqcgcKCz3S0R00 DUZJBEi2UmB+HyC/cE24zNvoxWSSUKVmu6jzgjERUFVg/InlVR/r7/ERYcHwKjkDwAFS LbQw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=FqXXQQV+MZH5rohf2esKIW9el+DVT0AFvzzRTGu0+Ec=; b=FGU+teUWup6fnXuwS53E0nCYTScFekHfrvj0SzLRe0hsUhk/K3RBC6+SBfzM6MJuNP hp1t2peYF5UVQ8L6qYmKEN/Cjc6uj8m/BSjRHFrDA0+jCyFOp3c6lgNOxlnem1fkXMtw niORiRppB1jrjOJYhQZjPw3vsAot+9+pjkZMXdZ14pF97CmBuYTNX1b3AEYVQVmNsqTF sDV48vnl0cd3VE0uzsa6bZiPxcZah7jROGS5vIlYTofsl8hPCJ8zSS8drXTrQH58s1zt 25Ytaqth9cg3rFTEoqWoJk4J6/z6/3LrOnPSRVTpdvdUW5SzPtzn+sHpt/2UY1p74cLt oVkA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id h16si12728554plr.94.2019.07.23.11.00.47; Tue, 23 Jul 2019 11:01:03 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388621AbfGWIlR (ORCPT + 99 others); Tue, 23 Jul 2019 04:41:17 -0400 Received: from inva020.nxp.com ([92.121.34.13]:56026 "EHLO inva020.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388522AbfGWIlN (ORCPT ); Tue, 23 Jul 2019 04:41:13 -0400 Received: from inva020.nxp.com (localhost [127.0.0.1]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id DD73E1A026D; Tue, 23 Jul 2019 10:41:10 +0200 (CEST) Received: from inva024.eu-rdc02.nxp.com (inva024.eu-rdc02.nxp.com [134.27.226.22]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id D0B341A0024; Tue, 23 Jul 2019 10:41:10 +0200 (CEST) Received: from fsr-ub1864-103.ea.freescale.net (fsr-ub1864-103.ea.freescale.net [10.171.82.17]) by inva024.eu-rdc02.nxp.com (Postfix) with ESMTP id D7E1F205DD; Tue, 23 Jul 2019 10:41:09 +0200 (CEST) From: Daniel Baluta To: m.felsch@pengutronix.de, shawnguo@kernel.org Cc: mark.rutland@arm.com, aisheng.dong@nxp.com, peng.fan@nxp.com, anson.huang@nxp.com, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, linux-imx@nxp.com, shengjiu.wang@nxp.com, paul.olaru@nxp.com, robh+dt@kernel.org, kernel@pengutronix.de, leonard.crestez@nxp.com, festevam@gmail.com, linux-arm-kernel@lists.infradead.org, sound-open-firmware@alsa-project.org, Daniel Baluta Subject: [PATCH v2 2/5] ASoC: SOF: topology: Add dummy support for i.MX8 DAIs Date: Tue, 23 Jul 2019 11:41:01 +0300 Message-Id: <20190723084104.12639-3-daniel.baluta@nxp.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20190723084104.12639-1-daniel.baluta@nxp.com> References: <20190723084104.12639-1-daniel.baluta@nxp.com> X-Virus-Scanned: ClamAV using ClamSMTP Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add dummy support for SAI/ESAI digital audio interface IPs found on i.MX8 boards. Signed-off-by: Daniel Baluta --- This is also on review with SOF community here: https://github.com/thesofproject/linux/pull/1048 include/sound/sof/dai.h | 2 ++ include/uapi/sound/sof/tokens.h | 8 ++++++++ sound/soc/sof/topology.c | 30 ++++++++++++++++++++++++++++++ 3 files changed, 40 insertions(+) diff --git a/include/sound/sof/dai.h b/include/sound/sof/dai.h index 3d174e20aa53..ec3b5c080537 100644 --- a/include/sound/sof/dai.h +++ b/include/sound/sof/dai.h @@ -50,6 +50,8 @@ enum sof_ipc_dai_type { SOF_DAI_INTEL_DMIC, /**< Intel DMIC */ SOF_DAI_INTEL_HDA, /**< Intel HD/A */ SOF_DAI_INTEL_SOUNDWIRE, /**< Intel SoundWire */ + SOF_DAI_IMX_SAI, /**< i.MX SAI */ + SOF_DAI_IMX_ESAI, /**< i.MX ESAI */ }; /* general purpose DAI configuration */ diff --git a/include/uapi/sound/sof/tokens.h b/include/uapi/sound/sof/tokens.h index dc1b27daaac6..347ce10bfd2d 100644 --- a/include/uapi/sound/sof/tokens.h +++ b/include/uapi/sound/sof/tokens.h @@ -105,4 +105,12 @@ /* for backward compatibility */ #define SOF_TKN_EFFECT_TYPE SOF_TKN_PROCESS_TYPE +/* SAI */ +#define SOF_TKN_IMX_SAI_FIRST_TOKEN 1000 +/* TODO: Add SAI tokens */ + +/* ESAI */ +#define SOF_TKN_IMX_ESAI_FIRST_TOKEN 1100 +/* TODO: Add ESAI tokens */ + #endif diff --git a/sound/soc/sof/topology.c b/sound/soc/sof/topology.c index 432ae343f960..b5399f520366 100644 --- a/sound/soc/sof/topology.c +++ b/sound/soc/sof/topology.c @@ -339,6 +339,8 @@ static const struct sof_dai_types sof_dais[] = { {"SSP", SOF_DAI_INTEL_SSP}, {"HDA", SOF_DAI_INTEL_HDA}, {"DMIC", SOF_DAI_INTEL_DMIC}, + {"SAI", SOF_DAI_IMX_SAI}, + {"ESAI", SOF_DAI_IMX_ESAI}, }; static enum sof_ipc_dai_type find_dai(const char *name) @@ -2457,6 +2459,26 @@ static int sof_link_ssp_load(struct snd_soc_component *scomp, int index, return ret; } +static int sof_link_sai_load(struct snd_soc_component *scomp, int index, + struct snd_soc_dai_link *link, + struct snd_soc_tplg_link_config *cfg, + struct snd_soc_tplg_hw_config *hw_config, + struct sof_ipc_dai_config *config) +{ + /*TODO: Add implementation */ + return 0; +} + +static int sof_link_esai_load(struct snd_soc_component *scomp, int index, + struct snd_soc_dai_link *link, + struct snd_soc_tplg_link_config *cfg, + struct snd_soc_tplg_hw_config *hw_config, + struct sof_ipc_dai_config *config) +{ + /*TODO: Add implementation */ + return 0; +} + static int sof_link_dmic_load(struct snd_soc_component *scomp, int index, struct snd_soc_dai_link *link, struct snd_soc_tplg_link_config *cfg, @@ -2781,6 +2803,14 @@ static int sof_link_load(struct snd_soc_component *scomp, int index, ret = sof_link_hda_load(scomp, index, link, cfg, hw_config, &config); break; + case SOF_DAI_IMX_SAI: + ret = sof_link_sai_load(scomp, index, link, cfg, hw_config, + &config); + break; + case SOF_DAI_IMX_ESAI: + ret = sof_link_esai_load(scomp, index, link, cfg, hw_config, + &config); + break; default: dev_err(sdev->dev, "error: invalid DAI type %d\n", config.type); ret = -EINVAL; -- 2.17.1