Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp902573pxf; Thu, 11 Mar 2021 18:55:24 -0800 (PST) X-Google-Smtp-Source: ABdhPJze+Oo5vrG9QTm8cWJnbzmOO6r9T42ZV6SO0/+rfzg3jUJceb6LiRXeNM6xYkOWgzJ3BBVL X-Received: by 2002:a05:6402:2070:: with SMTP id bd16mr11644404edb.133.1615517723926; Thu, 11 Mar 2021 18:55:23 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1615517723; cv=none; d=google.com; s=arc-20160816; b=t4/4wSM7AaRH59NDMtyYSxTVUZ+EWCjpI5zrmxci/ZfG5TNg7Wj37QC9dq+35LF6eb XFP52WhcU0CrqcNTS041TUS/V5X0DLp//T44Yn3xvDL7wbVbTxb0g4v+mpoWajqQDQXI DSHjwGZMQvF7w21e/xHTWyNJMJylFnolJGMVUq1kFySL2QkgK1Ft1yKcKRuRgLtiwh7o rvqUb9DImdndv+fyzq6Jb7LZfdXeyZqi2gtBFiXOKiv7u7k5gh+Tc1+tpira/VUcg/tK l1xM6+hQXe4+9LsqJculv1YNZwsl6bmfeGDW8F+ptVzjtrxJ0vqFLtPtKi5Wq0Yth2ZE LNBw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:to:from; bh=n0h/DCj46FLWAQCAs/91DgeBFBw7loQqYOgDIcItGco=; b=l0JegviwpaCBcq5WViHz3c0WwWt/xiicVMwJ21gkNt7JdQd3MIBkpDbvT53SgY9by+ 7tPvcTFUhZMPkaoOcL5B7Jn7klUVSXAgaiHqkhzT0tO5CCYecaWsRQ32oO9d/y7WqG/P 5LxsA4YXgyFXylaR22tLyvCj0FOnVC0SVjvEj9Nb+RioXNnUb9+QMB+tQuAEP+Ol/IaU g2SeLs3rzNB9+AGV2xmH7DLr+1Th/4kInvOy/J3dRSDGLsSHAq6dCZmU2E7yWQyQmbuo /cLNoPZigmHvjB4UYmrh+NpwGj72z6JakFwBWLx1t/fPDDqi0TljXhat6bu6vMS9OQsj v/zg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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. [23.128.96.18]) by mx.google.com with ESMTP id r25si2926939ejs.195.2021.03.11.18.55.01; Thu, 11 Mar 2021 18:55:23 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 S231629AbhCLCyG (ORCPT + 99 others); Thu, 11 Mar 2021 21:54:06 -0500 Received: from inva020.nxp.com ([92.121.34.13]:52994 "EHLO inva020.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231434AbhCLCyA (ORCPT ); Thu, 11 Mar 2021 21:54:00 -0500 Received: from inva020.nxp.com (localhost [127.0.0.1]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 067671A04F4; Fri, 12 Mar 2021 03:53:59 +0100 (CET) Received: from invc005.ap-rdc01.nxp.com (invc005.ap-rdc01.nxp.com [165.114.16.14]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 4B75D1A04A3; Fri, 12 Mar 2021 03:53:52 +0100 (CET) Received: from localhost.localdomain (shlinux2.ap.freescale.net [10.192.224.44]) by invc005.ap-rdc01.nxp.com (Postfix) with ESMTP id 754AC402A7; Fri, 12 Mar 2021 03:53:43 +0100 (CET) From: Shengjiu Wang To: lgirdwood@gmail.com, broonie@kernel.org, perex@perex.cz, tiwai@suse.com, alsa-devel@alsa-project.org, linux-kernel@vger.kernel.org, timur@kernel.org, nicoleotsuka@gmail.com, Xiubo.Lee@gmail.com, festevam@gmail.com, linuxppc-dev@lists.ozlabs.org, robh+dt@kernel.org, devicetree@vger.kernel.org Subject: [PATCH v5 0/6] Add audio driver base on rpmsg on i.MX platform Date: Fri, 12 Mar 2021 10:38:39 +0800 Message-Id: <1615516725-4975-1-git-send-email-shengjiu.wang@nxp.com> X-Mailer: git-send-email 2.7.4 X-Virus-Scanned: ClamAV using ClamSMTP Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Asymmetric multiprocessor, there is Cortex-A core and Cortex-M core, Linux is running on A core, RTOS is running on M core. The audio hardware device can be controlled by Cortex-M device, So audio playback/capture can be handled by M core. Rpmsg is the interface for sending and receiving msg to and from M core, that we can create a virtual sound on Cortex-A core side. A core will tell the Cortex-M core sound format/rate/channel, where is the data buffer, what is the period size, when to start, when to stop and when suspend or resume happen, each of this behavior there is defined rpmsg command. Especially we designed the low power audio case, that is to allocate a large buffer and fill the data, then Cortex-A core can go to sleep mode, Cortex-M core continue to play the sound, when the buffer is consumed, Cortex-M core will trigger the Cortex-A core to wakeup to fill data. changes in v5: - remove unneeded property in binding doc and driver - update binding doc according to Rob's comments. - Fix link issue reported by kernel test robot changes in v4: - remove the sound card node, merge the property to cpu dai node according to Rob's comments. - sound card device will be registered by cpu dai driver. - Fix do_div issue reported by kernel test robot changes in v3: - add local refcount for clk enablement in hw_params() - update the document according Rob's comments changes in v2: - update codes and comments according to Mark's comments Shengjiu Wang (6): ASoC: soc-component: Add snd_soc_pcm_component_ack ASoC: fsl_rpmsg: Add CPU DAI driver for audio base on rpmsg ASoC: dt-bindings: fsl_rpmsg: Add binding doc for rpmsg audio device ASoC: imx-audio-rpmsg: Add rpmsg_driver for audio channel ASoC: imx-pcm-rpmsg: Add platform driver for audio base on rpmsg ASoC: imx-rpmsg: Add machine driver for audio base on rpmsg .../devicetree/bindings/sound/fsl,rpmsg.yaml | 108 +++ include/sound/soc-component.h | 3 + sound/soc/fsl/Kconfig | 30 + sound/soc/fsl/Makefile | 6 + sound/soc/fsl/fsl_rpmsg.c | 279 ++++++ sound/soc/fsl/fsl_rpmsg.h | 35 + sound/soc/fsl/imx-audio-rpmsg.c | 140 +++ sound/soc/fsl/imx-pcm-rpmsg.c | 918 ++++++++++++++++++ sound/soc/fsl/imx-pcm-rpmsg.h | 512 ++++++++++ sound/soc/fsl/imx-rpmsg.c | 150 +++ sound/soc/soc-component.c | 14 + sound/soc/soc-pcm.c | 2 + 12 files changed, 2197 insertions(+) create mode 100644 Documentation/devicetree/bindings/sound/fsl,rpmsg.yaml create mode 100644 sound/soc/fsl/fsl_rpmsg.c create mode 100644 sound/soc/fsl/fsl_rpmsg.h create mode 100644 sound/soc/fsl/imx-audio-rpmsg.c create mode 100644 sound/soc/fsl/imx-pcm-rpmsg.c create mode 100644 sound/soc/fsl/imx-pcm-rpmsg.h create mode 100644 sound/soc/fsl/imx-rpmsg.c -- 2.27.0