From patchwork Thu Nov 15 18:13:20 2018 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Srinivas Kandagatla X-Patchwork-Id: 151233 Delivered-To: patch@linaro.org Received: by 2002:a2e:299d:0:0:0:0:0 with SMTP id p29-v6csp7327789ljp; Thu, 15 Nov 2018 10:15:34 -0800 (PST) X-Google-Smtp-Source: AJdET5ce3DA8T7lLueGFFWSSnjEaaMeDoayYqusCTlU/GpJlco8DuYs2kTwhD6S9K2IJ6RVqn+oX X-Received: by 2002:a62:ab0d:: with SMTP id p13mr7009282pff.211.1542305734589; Thu, 15 Nov 2018 10:15:34 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1542305734; cv=none; d=google.com; s=arc-20160816; b=b9VEnZPlmB1BMC/N8lSWh6Hce3DG8nRqd8W1E4n5IsH5tzYulnK8Xywht7j3LhBYK7 /hLoWlX5dkPZSyvfifKzAcwAgGaZaWoTZfmsbvOZJ67BdWXobk6pwTNhAomtDzxnyrR0 FdxZCrHaPW56tPfKVPGUvNOZRhQC8uROVOt2iXgm4bC1eDRQPqMPlFiZRnp8WbCOm8r0 Jr7/yGqiwt0JIrHj7WVm7CUAWF7bOQ1h5TYZARrlzPeINz1xKUKXf49sSpuGfkO9/bYH SoJ8y563e1J5QdG5bUudt8741ubNxpsOAxOb7jT66TCPPcfClbWQz3xatOfGjSN0Ak1d sW8g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=q3gLC+nmyp2mq9QJP7D6LeLPOksVBsoxF3h1ogX1tDA=; b=Y6xi6wBbVsfEewxJRRlCLihWznc14Um3+ImiffSq0Xo6N7UySQVFmOSPJQRJuCZ2lX GRHiD3dEOMJjerGSXrPJT3n5gU/ojLDAUBkM4P2HeDr8Wx6d4dQKuF0n4jn146pS0c6V qkvnAgREca1UG/zgYfvwj88Daiy3yEF5B3rDPVH/Xm+IOYXNsCMsFmqGPcVMesDfTd0A LU4hqK8ZWZPpsnRtsReHh7njnZvqAM5A0ak/jUIJI+VhBA4LTkQrfmY+NatNr+EZtx60 l6OdGuxKymSHl/1spzegcvp/89fpG41yednhX2bgb8hXnhaFccVn2oMD5O+aJPFFOTMj xkIw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b=PD2Miuqt; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id b59-v6si33104783plb.206.2018.11.15.10.15.34; Thu, 15 Nov 2018 10:15:34 -0800 (PST) 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; dkim=pass header.i=@linaro.org header.s=google header.b=PD2Miuqt; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2388854AbeKPEYY (ORCPT + 32 others); Thu, 15 Nov 2018 23:24:24 -0500 Received: from mail-wr1-f66.google.com ([209.85.221.66]:37121 "EHLO mail-wr1-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2388454AbeKPEYX (ORCPT ); Thu, 15 Nov 2018 23:24:23 -0500 Received: by mail-wr1-f66.google.com with SMTP id j10so8020267wru.4 for ; Thu, 15 Nov 2018 10:15:30 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=q3gLC+nmyp2mq9QJP7D6LeLPOksVBsoxF3h1ogX1tDA=; b=PD2MiuqtbVX1pUtDQ5uG7knacHELfzxsm2rl4tC/L3ngPzrHoSpuX51Kj5XLtACe+8 TJyJoirK/chyhTCMDRGoAhgTM1HtEze10ObZ9eS24yWH3hRdYffonVmRxdc5UjMzb18n uEU3XUq52bRvcCBp+erqp9e6Ut6bP9aGmhXNI= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=q3gLC+nmyp2mq9QJP7D6LeLPOksVBsoxF3h1ogX1tDA=; b=sdg5FnRJRXioWRUAV1WYUm+wtrr6pbr5OtrZ037W9m9PU0JF+rdrolBn/V/3ObwZ4e rTF0ueG5+uksbd2Wc6n5VVbB7vxwKeGTnKFFKiFkTA8PbwjtzSZxXqAPlw9yyDeeMHA+ t3DvXo3UIGNygPimBXPMOnWQtI9NEFR3f5PrH1/J4nLs6M+zRoWp5+12vNcmMgvklkId Oe7m8J1K31BLDSPEosSydA+Cs5QawBZmF4qOC1exEJtbXcEVGk4WFMTbE29B8N0SukFr OXTAgv9MhbNEjD5TfqKF+u/l4tiKFnephA/5ezDMt76se6UdttiYtwkC/OBJ2Rx/AR5Z gL2Q== X-Gm-Message-State: AGRZ1gJpGwG8sGCX05XJnTv6g9gi1uUeco303fkCGW/vxPb57N6Xi8/f pUIqGpe8T3jNbELkMq+aJMqAYg== X-Received: by 2002:adf:a78a:: with SMTP id j10-v6mr6975400wrc.286.1542305729876; Thu, 15 Nov 2018 10:15:29 -0800 (PST) Received: from localhost.localdomain (cpc90716-aztw32-2-0-cust92.18-1.cable.virginm.net. [86.26.100.93]) by smtp.gmail.com with ESMTPSA id r76-v6sm20934737wmb.21.2018.11.15.10.15.28 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Thu, 15 Nov 2018 10:15:29 -0800 (PST) From: Srinivas Kandagatla To: broonie@kernel.org, vkoul@kernel.org Cc: alsa-devel@alsa-project.org, robh+dt@kernel.org, linux-kernel@vger.kernel.org, bgoswami@codeaurora.org, rohitkr@codeaurora.org, lgirdwood@gmail.com, tiwai@suse.com, devicetree@vger.kernel.org, srini@kernel.org, Srinivas Kandagatla Subject: [PATCH v3 1/5] ALSA: soc-compress: add support to snd_compr_set_runtime_buffer() Date: Thu, 15 Nov 2018 18:13:20 +0000 Message-Id: <20181115181324.26784-2-srinivas.kandagatla@linaro.org> X-Mailer: git-send-email 2.19.1 In-Reply-To: <20181115181324.26784-1-srinivas.kandagatla@linaro.org> References: <20181115181324.26784-1-srinivas.kandagatla@linaro.org> MIME-Version: 1.0 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Existing compress offload code allocates data buffers using simple kmalloc, however there are situations where these buffers have to be mapped in smmu. So provide a way to set the runtime buffer by the driver itself, simillar to what we do with pcm. This patch adds support to set runtime dma buffer on compressed stream. Signed-off-by: Srinivas Kandagatla --- include/sound/compress_driver.h | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) -- 2.19.1 diff --git a/include/sound/compress_driver.h b/include/sound/compress_driver.h index ea8c93bbb0e0..0cdc3999ecfa 100644 --- a/include/sound/compress_driver.h +++ b/include/sound/compress_driver.h @@ -23,6 +23,7 @@ struct snd_compr_ops; * struct snd_compr_runtime: runtime stream description * @state: stream state * @ops: pointer to DSP callbacks + * @dma_buffer_p: runtime dma buffer pointer * @buffer: pointer to kernel buffer, valid only when not in mmap mode or * DSP doesn't implement copy * @buffer_size: size of the above buffer @@ -37,6 +38,7 @@ struct snd_compr_ops; struct snd_compr_runtime { snd_pcm_state_t state; struct snd_compr_ops *ops; + struct snd_dma_buffer *dma_buffer_p; void *buffer; u64 buffer_size; u32 fragment_size; @@ -175,6 +177,23 @@ static inline void snd_compr_drain_notify(struct snd_compr_stream *stream) wake_up(&stream->runtime->sleep); } +/** + * snd_compr_set_runtime_buffer - Set the Compress runtime buffer + * @substream: compress substream to set + * @bufp: the buffer information, NULL to clear + * + * Copy the buffer information to runtime buffer when @bufp is non-NULL. + * Otherwise it clears the current buffer information. + */ +static inline void snd_compr_set_runtime_buffer( + struct snd_compr_stream *substream, + struct snd_dma_buffer *bufp) +{ + struct snd_compr_runtime *runtime = substream->runtime; + + runtime->dma_buffer_p = bufp; +} + int snd_compr_stop_error(struct snd_compr_stream *stream, snd_pcm_state_t state);