Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1731780pxb; Thu, 4 Feb 2021 23:12:14 -0800 (PST) X-Google-Smtp-Source: ABdhPJxojjFayzU4/FtyRJt4QVcaszgckDoXrMJfvSldz4ghlij5Q0lYQhuqc9jKLyricjB+eZQr X-Received: by 2002:a17:907:2058:: with SMTP id pg24mr2721321ejb.441.1612509133823; Thu, 04 Feb 2021 23:12:13 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1612509133; cv=none; d=google.com; s=arc-20160816; b=nRKX2oe0Mt+2Vc7ou5npyjyhwtEWdjCrYFEzUgpwfts421ASVtEpaEz7C4RoueM5gc EjW7b5Ru++pNkzbwi5Z2S/xh43kbgNvzHEsagHnDgThNAOQSRkRe3co0Bx5StI2CY1Ui l5hSLmLyqnr4I9ACLBqesAqvtyBJFHJ78oiEqmWfT+Y/L8B2adxABjERYRaReUawGk4P PSQOWPz2DE28Jt55h8Yr5iyZ5wk221k/SFT0xznNOEJ+NYpB7Ou6vSut8pSDQqzs6Fns V3m8uYCQt3puPDUn+/ywPFsDHLwwHPT7C0SzSrM84lROw0aofemRrF9kmBzlGc6+lqq0 V8ug== 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=kLVOUZ3+YDfeHNlBrvqZVoDxVd+MIYzvylG6tCdMG04=; b=I34d355ZGgRcAUPUAXyXh4TTL2f+AkiNn14PPCgtrmmLprdRUjOrpSqP/a8E3VGzQX V/iZCs2z7KGYgmmDpgE7Y0p08mYqcOVv1PpyE1GBlIJAEIj5LpZYFGNTQIXQ2pkvS75K LdB3lzpmr8EmTFB8l7PXWfjR5p6yZm+VXMiiULbieY8roWbqrwwRuzCed0bw+p7Gg6+0 VdjbshjPwxlyEjk5b1/ygJ4apURYPBDsLHk0VXxmPHwyKe3H/xqvPbEBiuhNjKD02FK+ Gon4COm1HNn0fn/iat2PqK/D/vaRphr1RmlqT3I1IXtwsJo49zLBFEYqZHKlYCiDsPSO QogA== 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 h6si2952754ejt.26.2021.02.04.23.11.49; Thu, 04 Feb 2021 23:12:13 -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 S231394AbhBEHJr (ORCPT + 99 others); Fri, 5 Feb 2021 02:09:47 -0500 Received: from inva021.nxp.com ([92.121.34.21]:59016 "EHLO inva021.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230516AbhBEHJe (ORCPT ); Fri, 5 Feb 2021 02:09:34 -0500 Received: from inva021.nxp.com (localhost [127.0.0.1]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id B5EE6200B26; Fri, 5 Feb 2021 08:08:44 +0100 (CET) Received: from invc005.ap-rdc01.nxp.com (invc005.ap-rdc01.nxp.com [165.114.16.14]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id A6368200B4E; Fri, 5 Feb 2021 08:08:39 +0100 (CET) Received: from localhost.localdomain (shlinux2.ap.freescale.net [10.192.224.44]) by invc005.ap-rdc01.nxp.com (Postfix) with ESMTP id 600C440291; Fri, 5 Feb 2021 08:08:33 +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 0/7] Add audio driver base on rpmsg on i.MX platform Date: Fri, 5 Feb 2021 14:57:23 +0800 Message-Id: <1612508250-10586-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. Shengjiu Wang (7): 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 cpu dai driver 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 ASoC: dt-bindings: imx-rpmsg: Add binding doc for rpmsg machine driver .../devicetree/bindings/sound/fsl,rpmsg.yaml | 80 ++ .../bindings/sound/imx-audio-rpmsg.yaml | 48 + include/sound/soc-component.h | 3 + sound/soc/fsl/Kconfig | 28 + sound/soc/fsl/Makefile | 6 + sound/soc/fsl/fsl_rpmsg.c | 258 +++++ sound/soc/fsl/fsl_rpmsg.h | 38 + sound/soc/fsl/imx-audio-rpmsg.c | 142 +++ sound/soc/fsl/imx-pcm-rpmsg.c | 898 ++++++++++++++++++ sound/soc/fsl/imx-pcm-rpmsg.h | 512 ++++++++++ sound/soc/fsl/imx-rpmsg.c | 148 +++ sound/soc/soc-component.c | 14 + sound/soc/soc-pcm.c | 2 + 13 files changed, 2177 insertions(+) create mode 100644 Documentation/devicetree/bindings/sound/fsl,rpmsg.yaml create mode 100644 Documentation/devicetree/bindings/sound/imx-audio-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