Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp616859ybl; Wed, 29 Jan 2020 06:40:25 -0800 (PST) X-Google-Smtp-Source: APXvYqw7B+KJKAoQFOqunuh7VIWkXZTFI3TFl81AIR3Jzft+RMvetMhjY/M9TWtUAc0M7yBXXUCK X-Received: by 2002:a05:6830:1305:: with SMTP id p5mr3289908otq.124.1580308824838; Wed, 29 Jan 2020 06:40:24 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1580308824; cv=none; d=google.com; s=arc-20160816; b=kWy+3BNqPW6WY0yvDW4+unZfGgODavDv6PDf0tQhXNhf5miCxeKSz08Ql8w3WsOtsJ RWp186Wwew2jClAdUnfcQJgxx1RYvnht9rZwGDSeiao8nBS096/b0M5eOH1EylpzEFSR U9oa6zF4seJss7r+I5KSano+S5Mb/t6NtSBPc+IR5cp0EQ9HcJcwc/UtOcP8BF/rn8up BuRcCxpw+9odYmrs+zzcnDmwUxWigKPRuH0bnrQnuG7eucxfSZA2zKF373X7/bz5i2WW sF1DHBV9deq71utuXUkPMIenvvalEipAO2LBvAnbcZKdfrxVX/U+0EWETwGngf870HL0 rr5Q== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=3K8g2R+qnN1al4PUDNLHepCk8IU3tYNbbOqjAxk66KQ=; b=rKj7JKv2i4/kzrWKai8woqH8ULwPw6CFuBTVclgc16+R+jfJvLFoNXseFWUk5hRbGW oVU87VgzlDvtMUFJWAO1G0waie59G3GPBdODQmqu6XOvTGJzRWnEAhgtGzAGkLfL/c0n eCPUxPxfBPJSvCYs2D19fVh1uEVoFfxUkK/iLiWvQNI5LpvybJA6Pr7ln7KeZrce2Nla LrEK2TZTkk5dHAUD2XStgG/3LUe7kSvytcBy/06k7tx+X1VtbyBC6zD8vkmnbRPCzrGP jqxkCBRyE5BwtUTKAYpXVDZR2RrGyGaIGrtDKakjitaeBJj2EyZBsmgPvu3uDRkSw88z AtFA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=aeb9sR28; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 19si1112239oiq.128.2020.01.29.06.40.12; Wed, 29 Jan 2020 06:40:24 -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=@gmail.com header.s=20161025 header.b=aeb9sR28; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726671AbgA2OjM (ORCPT + 99 others); Wed, 29 Jan 2020 09:39:12 -0500 Received: from mail-lj1-f195.google.com ([209.85.208.195]:44046 "EHLO mail-lj1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726178AbgA2OjL (ORCPT ); Wed, 29 Jan 2020 09:39:11 -0500 Received: by mail-lj1-f195.google.com with SMTP id q8so18668460ljj.11; Wed, 29 Jan 2020 06:39:09 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=3K8g2R+qnN1al4PUDNLHepCk8IU3tYNbbOqjAxk66KQ=; b=aeb9sR283mF7M54b/P79A6sMBEAkyfi10bLIvLUYvCk614WErh7D810kPF7B2gk2HV S4gPFlkcDUXvT91O5HRacHkhXAorOxjYHMvl0VDG1KP8IoRlGcfgSjrW4klCXkOjv9EW WH8mNrsua6vUZtA+JbnVbTUSPnabN1s3Db9LGVfCehw2luiWDIvE8ayFzLRwc+7RE1S2 ylQtSCGWRnF1vQwL77Vh6bg9gscf7zZMZNZqK+uQaemMIB2pkoTuXn5bGlgL4NTc7RWL DrjqRFY6pb82QfXeeRJRv69KloVzPEeSRGXI9QYndFeBJ1/c/EICIppcieugv9sKvewK tzUQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=3K8g2R+qnN1al4PUDNLHepCk8IU3tYNbbOqjAxk66KQ=; b=BBt+VYWayAAsIdHRDEKIaRBApZrFzX6VloatyiWTnJqLZFGNp0Qcef+/9gcvO7+Ozs 1HqMQKmMEHtjlPd+EommIYRRh5CliR1np8ZoPvhRq7HcEJYBF4ap0+aelo49en6M+0rO p8ySmmPGf/zGTfGnECqQbPOpMgwrf5hSCddSK3X8aEa4Ps/fwI1v93j1zIDPnzWU0KJ9 oB/Kvwu1kfcaQWX5X8XKz+VM4LxRn6gtsnEPZKJZSGhh65p/SCLmQMDQxN9dokFLpYGi askjx0rczCSDP0MbYZJp3p6A6IAsf2M8X2tLhXAOuCCSHPk4WQJcvrXrhGLeQ2jwBbaf qOng== X-Gm-Message-State: APjAAAWusBnFUZb8vEHKBXE5vVn/n4rINImYA936GygP0h1gTi0zyQCb 890f2IF8ftrt5f3uKsxZ+xFjJLPp X-Received: by 2002:a2e:9b57:: with SMTP id o23mr17068194ljj.278.1580308748898; Wed, 29 Jan 2020 06:39:08 -0800 (PST) Received: from [192.168.2.145] (79-139-233-37.dynamic.spd-mgts.ru. [79.139.233.37]) by smtp.googlemail.com with ESMTPSA id p15sm1186393lfo.88.2020.01.29.06.39.07 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Wed, 29 Jan 2020 06:39:08 -0800 (PST) Subject: Re: [PATCH v5 05/14] dmaengine: tegra-apb: Prevent race conditions of tasklet vs free list To: Jon Hunter , Laxman Dewangan , Vinod Koul , Dan Williams , Thierry Reding , =?UTF-8?B?TWljaGHFgiBNaXJvc8WCYXc=?= Cc: dmaengine@vger.kernel.org, linux-tegra@vger.kernel.org, linux-kernel@vger.kernel.org References: <20200123230325.3037-1-digetx@gmail.com> <20200123230325.3037-6-digetx@gmail.com> From: Dmitry Osipenko Message-ID: <5f867023-d49a-aff5-8d7f-d682a3b32770@gmail.com> Date: Wed, 29 Jan 2020 17:39:07 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.3.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 29.01.2020 14:01, Jon Hunter пишет: > > On 23/01/2020 23:03, Dmitry Osipenko wrote: >> The interrupt handler puts a half-completed DMA descriptor on a free list >> and then schedules tasklet to process bottom half of the descriptor that >> executes client's callback, this creates possibility to pick up the busy >> descriptor from the free list. Thus let's disallow descriptor's re-use >> until it is fully processed. >> >> Acked-by: Jon Hunter >> Signed-off-by: Dmitry Osipenko >> --- >> drivers/dma/tegra20-apb-dma.c | 2 +- >> 1 file changed, 1 insertion(+), 1 deletion(-) >> >> diff --git a/drivers/dma/tegra20-apb-dma.c b/drivers/dma/tegra20-apb-dma.c >> index 1b8a11804962..aafad50d075e 100644 >> --- a/drivers/dma/tegra20-apb-dma.c >> +++ b/drivers/dma/tegra20-apb-dma.c >> @@ -281,7 +281,7 @@ static struct tegra_dma_desc *tegra_dma_desc_get( >> >> /* Do not allocate if desc are waiting for ack */ >> list_for_each_entry(dma_desc, &tdc->free_dma_desc, node) { >> - if (async_tx_test_ack(&dma_desc->txd)) { >> + if (async_tx_test_ack(&dma_desc->txd) && !dma_desc->cb_count) { >> list_del(&dma_desc->node); >> spin_unlock_irqrestore(&tdc->lock, flags); >> dma_desc->txd.flags = 0; >> > > I think we should mark this for stable as well. I would make this the > 2nd patch in the series as it is related to #1. Okay!