Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp3877214ybz; Mon, 4 May 2020 11:20:29 -0700 (PDT) X-Google-Smtp-Source: APiQypKOoIR1kVYp0GA+nElZnArA8lh1K4qZtqQG4bM/MWDZ6X+4L6wxwwOS+Q7/AnfLntOGapn4 X-Received: by 2002:aa7:c983:: with SMTP id c3mr16209689edt.343.1588616429407; Mon, 04 May 2020 11:20:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588616429; cv=none; d=google.com; s=arc-20160816; b=tU3jBm3nqV0heLHxCGAO0T4s7vlKWEfmO6nSxx4/O1TT+EZr5ZO0Tynd2o2VPen+A6 xbyhPqnr0Yrz4DxX+U13wMO6hBgFvxlyCBnBK1RC0YCbOREp2b6YXa0sysRVL55/IqPT 5xjQOhJkc7u3MgPPK90/g/Ntf0j8Gbg5q7XaVEZ4n4vKUZ8kfa1JWZDf0LvDShDxmJbD mg4kTdaCNKSUgrS+vMjsN09oGwu0tYTzaytxhlSuXGbywH4RXZJL2Rs2s8EjoSrCNBT6 AUsbQjjkCp3pTi1aKpXM23bYPF//fxRtklfAHsjK868rJHCCUqDwsm2LyCokZdx5Z/1I 2UZg== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=dR6hjV5+ffV2oFEpiwVe3kz7gY+KwiusWwj+rcy9Gkg=; b=HjZfl+82GEBz8o1ZTHVnuwJnOS+9CUhxVUb6zCOnXf8cglDPBV2CCu3IgSgBVGfcAg Gq1V4wjXq2wWUPQFXQbtZWwTvdRoSAyEiWl1UOvmWJCg18hWq65X9QEyHkWt/4RaLOv6 1F0y36d9sBKwTkBXU7y2mg7ZPa181+rmgIPxMw4a9zAaENfmMkYY51f+4DitWk+nNaDP SQASSxbe1JX5b+5iOQCb4rOfbaQEtA+YSZ9XGI5Xy2a/HplwkRBSoO8pYCe/FvGW9x7G N+XLywJM7mcqLXhk7rV2c9WMixhlTy+DaIAJ++g9jlpukw7f5+zP8VcZpiRv+Y+Sxx+w D5WA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="bY/R1elW"; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id 40si7900806edr.556.2020.05.04.11.20.06; Mon, 04 May 2020 11:20:29 -0700 (PDT) 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; dkim=pass header.i=@kernel.org header.s=default header.b="bY/R1elW"; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730639AbgEDR7A (ORCPT + 99 others); Mon, 4 May 2020 13:59:00 -0400 Received: from mail.kernel.org ([198.145.29.99]:51856 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729977AbgEDR6y (ORCPT ); Mon, 4 May 2020 13:58:54 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 2E87920707; Mon, 4 May 2020 17:58:53 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1588615133; bh=a+ZdBsfssstmqLx/7kEvHmO0jDwlP3ZCzCwLmaez0Iw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=bY/R1elWA2StKWhYnDVzRd7bDkVzeP5sn1imRcxAtTS2NQLn+rW6vyHm4FXkAPg9X zR8bs/vdOPX2aqJAwN3X7AqlRnMuKAkr/lzChyRwFNCsvxjX90udMVSb2Eb5m0Hm1x OI87iL4+mQ2IOwNJjNHChitJ8M6OkyBgql9Yr7jU= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Dan Williams , Nicolas Ferre , Andy Shevchenko , Vinod Koul Subject: [PATCH 4.4 09/18] dmaengine: dmatest: Fix iteration non-stop logic Date: Mon, 4 May 2020 19:57:07 +0200 Message-Id: <20200504165443.560603458@linuxfoundation.org> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200504165441.533160703@linuxfoundation.org> References: <20200504165441.533160703@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Andy Shevchenko commit b9f960201249f20deea586b4ec814669b4c6b1c0 upstream. Under some circumstances, i.e. when test is still running and about to time out and user runs, for example, grep -H . /sys/module/dmatest/parameters/* the iterations parameter is not respected and test is going on and on until user gives echo 0 > /sys/module/dmatest/parameters/run This is not what expected. The history of this bug is interesting. I though that the commit 2d88ce76eb98 ("dmatest: add a 'wait' parameter") is a culprit, but looking closer to the code I think it simple revealed the broken logic from the day one, i.e. in the commit 0a2ff57d6fba ("dmaengine: dmatest: add a maximum number of test iterations") which adds iterations parameter. So, to the point, the conditional of checking the thread to be stopped being first part of conjunction logic prevents to check iterations. Thus, we have to always check both conditions to be able to stop after given iterations. Since it wasn't visible before second commit appeared, I add a respective Fixes tag. Fixes: 2d88ce76eb98 ("dmatest: add a 'wait' parameter") Cc: Dan Williams Cc: Nicolas Ferre Signed-off-by: Andy Shevchenko Acked-by: Nicolas Ferre Link: https://lore.kernel.org/r/20200424161147.16895-1-andriy.shevchenko@linux.intel.com Signed-off-by: Vinod Koul Signed-off-by: Greg Kroah-Hartman --- drivers/dma/dmatest.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) --- a/drivers/dma/dmatest.c +++ b/drivers/dma/dmatest.c @@ -491,8 +491,8 @@ static int dmatest_func(void *data) flags = DMA_CTRL_ACK | DMA_PREP_INTERRUPT; ktime = ktime_get(); - while (!kthread_should_stop() - && !(params->iterations && total_tests >= params->iterations)) { + while (!(kthread_should_stop() || + (params->iterations && total_tests >= params->iterations))) { struct dma_async_tx_descriptor *tx = NULL; struct dmaengine_unmap_data *um; dma_addr_t srcs[src_cnt];