From patchwork Fri Apr 3 02:19:43 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Gyeongtaek Lee X-Patchwork-Id: 193111 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-6.8 required=3.0 tests=DKIM_SIGNED,DKIM_VALID, HEADER_FROM_DIFFERENT_DOMAINS, INCLUDES_PATCH, MAILING_LIST_MULTI, SIGNED_OFF_BY, SPF_HELO_NONE, SPF_PASS, URIBL_BLOCKED autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 34387C43331 for ; Fri, 3 Apr 2020 03:21:08 +0000 (UTC) Received: from alsa0.perex.cz (alsa0.perex.cz [77.48.224.243]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id B2EAE2077D for ; Fri, 3 Apr 2020 03:21:07 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (1024-bit key) header.d=alsa-project.org header.i=@alsa-project.org header.b="ihk90RBv"; dkim=fail reason="signature verification failed" (1024-bit key) header.d=samsung.com header.i=@samsung.com header.b="ChyuDcpD" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org B2EAE2077D Authentication-Results: mail.kernel.org; dmarc=fail (p=none dis=none) header.from=samsung.com Authentication-Results: mail.kernel.org; spf=pass smtp.mailfrom=alsa-devel-bounces@alsa-project.org Received: from alsa1.perex.cz (alsa1.perex.cz [207.180.221.201]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by alsa0.perex.cz (Postfix) with ESMTPS id 13A101607; Fri, 3 Apr 2020 05:20:16 +0200 (CEST) DKIM-Filter: OpenDKIM Filter v2.11.0 alsa0.perex.cz 13A101607 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=alsa-project.org; s=default; t=1585884066; bh=zA30b/0GrrJiv0mj5a9OPg0WFQZEKV4HBmkkpT8MsI4=; h=From:To:In-Reply-To:Subject:Date:References:Cc:List-Id: List-Unsubscribe:List-Archive:List-Post:List-Help:List-Subscribe: From; b=ihk90RBvDd+gVlHYNOfLxUmKIhSkCamg+EyEURpqto1MDMMmc8PPKuOKd7U4Gz1AO +s3sE160paIZnBcxZ4XT1qeQXTRkLvoo9whD2IC3Pm5IIICyDkhjtBsx+ieN/3D4++ tb+6ggj3ldQK2/QOAv8SlUy6bJGTAP7gOqyl5+SY= Received: from alsa1.perex.cz (localhost.localdomain [127.0.0.1]) by alsa1.perex.cz (Postfix) with ESMTP id 708EBF8015C; Fri, 3 Apr 2020 05:20:15 +0200 (CEST) Received: by alsa1.perex.cz (Postfix, from userid 50401) id A26D8F8015C; Fri, 3 Apr 2020 05:20:12 +0200 (CEST) Received: from mailout4.samsung.com (mailout4.samsung.com [203.254.224.34]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by alsa1.perex.cz (Postfix) with ESMTPS id 95261F800C2 for ; Fri, 3 Apr 2020 05:20:06 +0200 (CEST) DKIM-Filter: OpenDKIM Filter v2.11.0 alsa1.perex.cz 95261F800C2 Authentication-Results: alsa1.perex.cz; dkim=pass (1024-bit key) header.d=samsung.com header.i=@samsung.com header.b="ChyuDcpD" Received: from epcas1p4.samsung.com (unknown [182.195.41.48]) by mailout4.samsung.com (KnoxPortal) with ESMTP id 20200403032002epoutp041a1f34f548b617a8b9657ddd43dfddf9~CMRkVIrmj0942109421epoutp04d for ; Fri, 3 Apr 2020 03:20:02 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 mailout4.samsung.com 20200403032002epoutp041a1f34f548b617a8b9657ddd43dfddf9~CMRkVIrmj0942109421epoutp04d DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=samsung.com; s=mail20170921; t=1585884002; bh=f5TK58gqq7PmPD7XHpVJI8o1g4ENJqR0DWpC6SYILyQ=; h=From:To:Cc:In-Reply-To:Subject:Date:References:From; b=ChyuDcpDkA/yFwuO4jz1cY02CXULmsnb5l94SAHwqyO+05Hd8WPjt3UabNqJMDrHL Vc4bM6kUiY0s5rvfVhOv/dDr0pi6rRNCF5dQtNuXnsIUIw0pzxhEVGT2y9ThdaGpsr MpZhFVA3eunUyd76nqlrFEfCOOj4/U8GR8JOavEQ= Received: from epcpadp1 (unknown [182.195.40.11]) by epcas1p2.samsung.com (KnoxPortal) with ESMTP id 20200403032002epcas1p2c114419dbbbdc5d110a22b810a323582~CMRkHjDdh2241122411epcas1p2p; Fri, 3 Apr 2020 03:20:02 +0000 (GMT) Received: from epsmtrp1.samsung.com (unknown [182.195.40.13]) by epcas2p3.samsung.com (KnoxPortal) with ESMTPA id 20200403021943epcas2p36334748d486a0d4703fb12d88fbc9ee8~CLc6K1ptj2702427024epcas2p3F; Fri, 3 Apr 2020 02:19:43 +0000 (GMT) Received: from epsmgms1p2new.samsung.com (unknown [182.195.42.42]) by epsmtrp1.samsung.com (KnoxPortal) with ESMTP id 20200403021943epsmtrp1daf28e564fc64801a289dc0fbf8daa3a~CLc6J8nlH1699216992epsmtrp1j; Fri, 3 Apr 2020 02:19:43 +0000 (GMT) X-AuditID: b6c32a2a-d51ff7000000103e-d7-5e869d3f80ce Received: from epsmtip1.samsung.com ( [182.195.34.30]) by epsmgms1p2new.samsung.com (Symantec Messaging Gateway) with SMTP id 24.E7.04158.F3D968E5; Fri, 3 Apr 2020 11:19:43 +0900 (KST) Received: from KORDO025540 (unknown [12.36.182.130]) by epsmtip1.samsung.com (KnoxPortal) with ESMTPA id 20200403021943epsmtip108288da1d409607f363570eb8d8e52d5~CLc6B7NGe0088900889epsmtip1T; Fri, 3 Apr 2020 02:19:43 +0000 (GMT) From: "Gyeongtaek Lee" To: "'Mark Brown'" , In-Reply-To: Subject: [PATCH 1/1] ASoC: soc-component: add snd_soc_component_ack() Date: Fri, 3 Apr 2020 11:19:43 +0900 Message-ID: <857068247.21585884002347.JavaMail.epsvc@epcpadp1> MIME-Version: 1.0 X-Mailer: Microsoft Outlook 16.0 Thread-Index: AdYJXZGvKxKC2H0XTAaHFKB54siVTAAAKi8g Content-Language: ko X-Brightmail-Tracker: H4sIAAAAAAAAA+NgFprHIsWRmVeSWpSXmKPExsWy7bCSnK793LY4g94PxhZXLh5ispj68Amb xctDmhYztnWzWLw6vIvR4tuVDiaLoxcXM1ls+L6W0eJI4xQmB06PDZ+b2Dx2zrrL7rFpVSeb x7czE1k8+rasYvRYv+UqSwBbFJdNSmpOZllqkb5dAlfGjA/HmQpuCle8mDmPsYHxjEAXIweH hICJxMx7zF2MXBxCArsZJTa39bJ1MXICxSUkPsw/ww5hC0vcbznCClH0nFFixrlrYAk2AV2J L/fuMIPYIgK+ElcetTCCFDELbGCUmDD5IRNIQkiAR+LVhv2MINs4BXglJvyzBgkLC7hKXJ0y jRHEZhFQkVj24yVYOa+ApcTLpZvZIWxBiZMzn7CA2MwC2hJPbz6FsuUltr+dwwxxnILEz6fL WCFuMJKYfOEOO0SNiMTszjbmCYzCs5CMmoVk1Cwko2YhaVnAyLKKUTK1oDg3PbfYsMAoL7Vc rzgxt7g0L10vOT93EyM41rS0djCeOBF/iFGAg1GJh5fhYGucEGtiWXFl7iFGCQ5mJRFexxlA Id6UxMqq1KL8+KLSnNTiQ4zSHCxK4rzy+ccihQTSE0tSs1NTC1KLYLJMHJxSDYwL19btNuly mLwq5xSfyz2+GY2WZ15cP+l739pob86XfLmrFT82NoSHCmhX7vxxK/hltvgDi3K3TUyTug7e nqYTa2bxy95x3lbF5qSIcsHbrywqzfId+TPXmCxqkHoSbDCVS7DHoSBPMDRML8ueT+vMBvtn +Vdmubwo/31B2H/+eZeHd4xO/VJiKc5INNRiLipOBAAeych+sQIAAA== X-CMS-MailID: 20200403021943epcas2p36334748d486a0d4703fb12d88fbc9ee8 X-Msg-Generator: CA X-Sendblock-Type: AUTO_CONFIDENTIAL X-CPGSPASS: Y X-Hop-Count: 3 X-CMS-RootMailID: 20200403021943epcas2p36334748d486a0d4703fb12d88fbc9ee8 References: Cc: alsa-devel@alsa-project.org, lgirdwood@gmail.com, tiwai@suse.com, hmseo@samsung.com, cpgs@samsung.com, tkjung@samsung.com, pilsun.jang@samsung.com X-BeenThere: alsa-devel@alsa-project.org X-Mailman-Version: 2.1.15 Precedence: list List-Id: "Alsa-devel mailing list for ALSA developers - http://www.alsa-project.org" List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Errors-To: alsa-devel-bounces@alsa-project.org Sender: "Alsa-devel" Current ALSA SoC is directly using component->driver->ops->xxx, thus, it is deep nested, and makes code difficult to read, and is not good for encapsulation. This patch adds new snd_soc_component_ack() and use it. Ack callback is revived because some ASoC driver is using it. Change-Id: I85573cb43f3ca050c47ca9e3af3cfa9ec1fae3d0 Signed-off-by: Gyeongtaek Lee --- include/sound/soc-component.h | 1 + sound/soc/soc-component.c | 18 ++++++++++++++++++ sound/soc/soc-pcm.c | 2 ++ 3 files changed, 21 insertions(+) diff --git a/include/sound/soc-component.h b/include/sound/soc-component.h index 5d80b2eef525..50b079272b47 100644 --- a/include/sound/soc-component.h +++ b/include/sound/soc-component.h @@ -381,6 +381,7 @@ struct page *snd_soc_pcm_component_page(struct snd_pcm_substream *substream, unsigned long offset); int snd_soc_pcm_component_mmap(struct snd_pcm_substream *substream, struct vm_area_struct *vma); +int snd_soc_pcm_component_ack(struct snd_pcm_substream *substream); int snd_soc_pcm_component_new(struct snd_pcm *pcm); void snd_soc_pcm_component_free(struct snd_pcm *pcm); diff --git a/sound/soc/soc-component.c b/sound/soc/soc-component.c index 79ffc2820ba9..b4be91cb9fa0 100644 --- a/sound/soc/soc-component.c +++ b/sound/soc/soc-component.c @@ -526,6 +526,24 @@ int snd_soc_pcm_component_mmap(struct snd_pcm_substream *substream, return -EINVAL; } +int snd_soc_pcm_component_ack(struct snd_pcm_substream *substream) +{ + struct snd_soc_pcm_runtime *rtd = substream->private_data; + struct snd_soc_rtdcom_list *rtdcom; + struct snd_soc_component *component; + + for_each_rtdcom(rtd, rtdcom) { + component = rtdcom->component; + + /* FIXME. it returns 1st ack now */ + if (component->driver->ops && + component->driver->ops->ack) + return component->driver->ops->ack(substream); + } + + return -EINVAL; +} + int snd_soc_pcm_component_new(struct snd_pcm *pcm) { struct snd_soc_pcm_runtime *rtd = pcm->private_data; diff --git a/sound/soc/soc-pcm.c b/sound/soc/soc-pcm.c index b600d3eaaf5c..c8a5a9a9d35f 100644 --- a/sound/soc/soc-pcm.c +++ b/sound/soc/soc-pcm.c @@ -2941,6 +2941,8 @@ int soc_new_pcm(struct snd_soc_pcm_runtime *rtd, int num) if (!ops) continue; + if (ops->ack) + rtd->ops.ack = snd_soc_pcm_component_ack; if (ops->copy_user) rtd->ops.copy_user = snd_soc_pcm_component_copy_user; if (ops->page)