Received: by 2002:a05:6359:c8b:b0:c7:702f:21d4 with SMTP id go11csp217142rwb; Mon, 26 Sep 2022 11:19:13 -0700 (PDT) X-Google-Smtp-Source: AMsMyM4tI3gJuTEDage0HTAr0c7KBFy3aGjEkEENW+oxZz0PfAFilAqRUcX3fOC/vEPWKVRkotgV X-Received: by 2002:a17:906:fc6:b0:72f:d080:416 with SMTP id c6-20020a1709060fc600b0072fd0800416mr20159014ejk.1.1664216353059; Mon, 26 Sep 2022 11:19:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1664216353; cv=none; d=google.com; s=arc-20160816; b=K+VPjjWtEGK/l2G73qk+lW/1IDlZgvwfd0gAVV9QxRZsg2wpFpac8Xq+Nj+VaE/zW4 2aEOUZiQYIZ4F/e3KDRlf9H8QjbcJHEcA7MIiM3RTBTxX0GgUzHBJz1e3u1gbx/byKdZ kX7Dl4stWrPw0CSmKAEAXG8gpICdctD7g8cDdftl7PN9apuN63H7AaUAmSDqM+8rSV/E XJ/3kQdepzGxw0kLoa9jZEVKzcd5P8OByUvBfLCTbs0Glyn+V1KpL69JCo8zdmXQP1fC K8DA459Vyije2MN8sSGs9CbXaS51GQvRK0Gll0Yl1/1uORiA9Vu01sxJ24Sj3T+yqTbH 56Fg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:subject:cc:to:from; bh=6YLw7PRYIQeuZiPgPR4jQuvgYjjeYbwe9ppaXH/Tzh4=; b=0RWPpjx1/GsRBWx5rbERFe5naA/5BP+XbWvj8JEK9rnn7rngPC5yuPWqBaB1KGyMtj 5wQzxssAvwkDW339qPPfq1qvhFH8uU+yprZTSipztBbOBJ36+lOpvvlSrtSIopJ6/QBW 4R93HsSDID+oeUm0dxPPowQbRfw3TlxGNEZi/LHGwtwVM3L/8Ny3I+sGs+A63uEsezNU aecBIXtpNr4KOTWZCzzN8+KliQIJI5nNpKimg/aVjqOPCMCWMJSr+/BojyrqQzso7nVJ a17wHDxZn+nqJ60Z6E2lG20PXhgJcXKxdTuRByZItAem7jX/pUcqw0xCevPwEDL8XBzb JJHA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id z10-20020a056402274a00b004549b880c67si18957355edd.42.2022.09.26.11.18.46; Mon, 26 Sep 2022 11:19:12 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230335AbiIZRg7 (ORCPT + 99 others); Mon, 26 Sep 2022 13:36:59 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51026 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230519AbiIZRga (ORCPT ); Mon, 26 Sep 2022 13:36:30 -0400 Received: from hi1smtp01.de.adit-jv.com (smtp1.de.adit-jv.com [93.241.18.167]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id EC25D74DCA for ; Mon, 26 Sep 2022 09:58:21 -0700 (PDT) Received: from hi2exch02.adit-jv.com (hi2exch02.adit-jv.com [10.72.92.28]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by hi1smtp01.de.adit-jv.com (Postfix) with ESMTPS id 22BEC5202DB; Mon, 26 Sep 2022 18:58:20 +0200 (CEST) Received: from localhost.localdomain (10.72.94.2) by hi2exch02.adit-jv.com (10.72.92.28) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.1.2507.12; Mon, 26 Sep 2022 18:58:19 +0200 From: Eugeniu Rosca To: Lars-Peter Clausen , Vinod Koul , Mark Brown , Jaroslav Kysela , Takashi Iwai , , CC: Jiada Wang , Dean Jenkins , Andreas Pape , Eugeniu Rosca , Eugeniu Rosca Subject: [PATCH] ALSA: dmaengine: increment buffer pointer atomically Date: Mon, 26 Sep 2022 18:58:13 +0200 Message-ID: <1664211493-11789-1-git-send-email-erosca@de.adit-jv.com> X-Mailer: git-send-email 2.7.4 MIME-Version: 1.0 Content-Type: text/plain X-Originating-IP: [10.72.94.2] X-ClientProxiedBy: hi2exch02.adit-jv.com (10.72.92.28) To hi2exch02.adit-jv.com (10.72.92.28) X-Spam-Status: No, score=-1.5 required=5.0 tests=BAYES_00,KHOP_HELO_FCRDNS, SPF_HELO_NONE,SPF_NONE autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Andreas Pape Setting pointer and afterwards checking for wraparound leads to the possibility of returning the inconsistent pointer position. This patch increments buffer pointer atomically to avoid this issue. Fixes: e7f73a1613567a ("ASoC: Add dmaengine PCM helper functions") Signed-off-by: Andreas Pape Signed-off-by: Eugeniu Rosca --- sound/core/pcm_dmaengine.c | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/sound/core/pcm_dmaengine.c b/sound/core/pcm_dmaengine.c index 5b2ca028f5aa..494ec0c207fa 100644 --- a/sound/core/pcm_dmaengine.c +++ b/sound/core/pcm_dmaengine.c @@ -133,12 +133,14 @@ EXPORT_SYMBOL_GPL(snd_dmaengine_pcm_set_config_from_dai_data); static void dmaengine_pcm_dma_complete(void *arg) { + unsigned int new_pos; struct snd_pcm_substream *substream = arg; struct dmaengine_pcm_runtime_data *prtd = substream_to_prtd(substream); - prtd->pos += snd_pcm_lib_period_bytes(substream); - if (prtd->pos >= snd_pcm_lib_buffer_bytes(substream)) - prtd->pos = 0; + new_pos = prtd->pos + snd_pcm_lib_period_bytes(substream); + if (new_pos >= snd_pcm_lib_buffer_bytes(substream)) + new_pos = 0; + prtd->pos = new_pos; snd_pcm_period_elapsed(substream); } -- 2.37.2