Received: by 2002:a6b:fb09:0:0:0:0:0 with SMTP id h9csp1120843iog; Sat, 25 Jun 2022 01:14:23 -0700 (PDT) X-Google-Smtp-Source: AGRyM1uIkLms6AHIFA5Vd4a/zaHoOjeBPNwrOAn9nVK7rqBNUj2mp3HbC3xJ+21b698S0UyPeYT9 X-Received: by 2002:a17:906:74c2:b0:722:a7e9:6f82 with SMTP id z2-20020a17090674c200b00722a7e96f82mr2818398ejl.3.1656144863472; Sat, 25 Jun 2022 01:14:23 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1656144863; cv=none; d=google.com; s=arc-20160816; b=QoYxjR+EGFrAarxa6l0lAT979es9QKOE8RlA+tnFSS2p8YHg758qNUs3zJXKEJxxv+ X4mXHR1zIDphA0JxV3zgXipRCx17exmATmqu7IXoesFlh+gFsZ2ok/YZ6vcQWyQbNu6Z SO13MGKdeRbn0HxnZtsQalEGh86L1hNSjWiExCtQiD8DLu/AETjcn0dMcci3ly/31Xdf 5DMGEW6khr4j6Jam0fZrv2pETEsooBkI04P4rGaDhN1JZgxoZoVKc/cK5pctf2+iHYir s0aEEX5hyaBhF1COzHChH4u+fZh2PHA7C6HeNF3aSCYQJKwXSyMkuULrzY3dX+pSBj0g +W9Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=bu9ThZiqHgbg1r1C+T+lfjGMCukryEOihKF3vIB0r3o=; b=ZU2gu2dZlsxLPb1SSgqbroKIVRdzZy8YzvJr3MVasxMwQso98M+EeIONkAYiIjOZus oUqAvdsaCiVY3H6DoytJf7yI4XdlIoIEfvqjSOFGTOOdWRkrKAt4NSttPnSBp0PiEpIN WBno23MUga9Z9wTMuyUZLg4MqRL09Zgp5n/fDwfFJQeOjBkRAEgJd6NZh7cTV/XrCTrL HssHeUks36QxMSuSFKtdBQjMXyskAol/vsNK0iaIFbyM/VlyCKzlC74PBGIwqwdTn+A+ sWYdAjbcPCyFSQAi4GoEzyU53yDk3bB5tyztfloB1haabWHY1HdAT67g2b2H1Ng4jNXU MHaQ== 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; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id b11-20020a1709063f8b00b006e7efa5c4fbsi4964434ejj.173.2022.06.25.01.13.57; Sat, 25 Jun 2022 01:14:23 -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; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232195AbiFYHpA (ORCPT + 99 others); Sat, 25 Jun 2022 03:45:00 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54624 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229787AbiFYHo4 (ORCPT ); Sat, 25 Jun 2022 03:44:56 -0400 Received: from szxga02-in.huawei.com (szxga02-in.huawei.com [45.249.212.188]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id C67344707F; Sat, 25 Jun 2022 00:44:52 -0700 (PDT) Received: from dggemv711-chm.china.huawei.com (unknown [172.30.72.53]) by szxga02-in.huawei.com (SkyGuard) with ESMTP id 4LVQsc1lMPzShDW; Sat, 25 Jun 2022 15:41:24 +0800 (CST) Received: from kwepemm600007.china.huawei.com (7.193.23.208) by dggemv711-chm.china.huawei.com (10.1.198.66) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.24; Sat, 25 Jun 2022 15:44:50 +0800 Received: from localhost.localdomain (10.67.165.2) by kwepemm600007.china.huawei.com (7.193.23.208) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.24; Sat, 25 Jun 2022 15:44:50 +0800 From: Jie Hai To: , CC: , Subject: [PATCH 3/8] dmaengine: hisilicon: Add multi-thread support for a DMA channel Date: Sat, 25 Jun 2022 15:44:17 +0800 Message-ID: <20220625074422.3479591-4-haijie1@huawei.com> X-Mailer: git-send-email 2.30.0 In-Reply-To: <20220625074422.3479591-1-haijie1@huawei.com> References: <20220625074422.3479591-1-haijie1@huawei.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.67.165.2] X-ClientProxiedBy: dggems701-chm.china.huawei.com (10.3.19.178) To kwepemm600007.china.huawei.com (7.193.23.208) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham 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 When we get a DMA channel and try to use it in multiple threads it will cause oops and hanging the system. % echo 100 > /sys/module/dmatest/parameters/threads_per_chan % echo 100 > /sys/module/dmatest/parameters/iterations % echo 1 > /sys/module/dmatest/parameters/run [383493.327077] Unable to handle kernel paging request at virtual address dead000000000108 [383493.335103] Mem abort info: [383493.335103] ESR = 0x96000044 [383493.335105] EC = 0x25: DABT (current EL), IL = 32 bits [383493.335107] SET = 0, FnV = 0 [383493.335108] EA = 0, S1PTW = 0 [383493.335109] FSC = 0x04: level 0 translation fault [383493.335110] Data abort info: [383493.335111] ISV = 0, ISS = 0x00000044 [383493.364739] CM = 0, WnR = 1 [383493.367793] [dead000000000108] address between user and kernel address ranges [383493.375021] Internal error: Oops: 96000044 [#1] PREEMPT SMP [383493.437574] CPU: 63 PID: 27895 Comm: dma0chan0-copy2 Kdump: loaded Tainted: GO 5.17.0-rc4+ #2 [383493.457851] pstate: 204000c9 (nzCv daIF +PAN -UAO -TCO -DIT -SSBS BTYPE=--) [383493.465331] pc : vchan_tx_submit+0x64/0xa0 [383493.469957] lr : vchan_tx_submit+0x34/0xa0 This happens because of data race. Each thread rewrite channels's descriptor as soon as device_issue_pending is called. It leads to the situation that the driver thinks that it uses the right descriptor in interrupt handler while channels's descriptor has been changed by other thread. With current fixes channels's descriptor changes it's value only when it has been used. A new descriptor is acquired from vc->desc_issued queue that is already filled with descriptors that are ready to be sent. Threads have no direct access to DMA channel descriptor. Now it is just possible to queue a descriptor for further processing. Fixes: e9f08b65250d ("dmaengine: hisilicon: Add Kunpeng DMA engine support") Signed-off-by: Jie Hai --- drivers/dma/hisi_dma.c | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/drivers/dma/hisi_dma.c b/drivers/dma/hisi_dma.c index 0a0f8a4d168a..0385419be8d5 100644 --- a/drivers/dma/hisi_dma.c +++ b/drivers/dma/hisi_dma.c @@ -271,7 +271,6 @@ static void hisi_dma_start_transfer(struct hisi_dma_chan *chan) vd = vchan_next_desc(&chan->vc); if (!vd) { - dev_err(&hdma_dev->pdev->dev, "no issued task!\n"); chan->desc = NULL; return; } @@ -303,7 +302,7 @@ static void hisi_dma_issue_pending(struct dma_chan *c) spin_lock_irqsave(&chan->vc.lock, flags); - if (vchan_issue_pending(&chan->vc)) + if (vchan_issue_pending(&chan->vc) && !chan->desc) hisi_dma_start_transfer(chan); spin_unlock_irqrestore(&chan->vc.lock, flags); @@ -442,11 +441,10 @@ static irqreturn_t hisi_dma_irq(int irq, void *data) chan->qp_num, chan->cq_head); if (FIELD_GET(STATUS_MASK, cqe->w0) == STATUS_SUCC) { vchan_cookie_complete(&desc->vd); + hisi_dma_start_transfer(chan); } else { dev_err(&hdma_dev->pdev->dev, "task error!\n"); } - - chan->desc = NULL; } spin_unlock(&chan->vc.lock); -- 2.33.0