Received: by 2002:a25:23cc:0:0:0:0:0 with SMTP id j195csp1693752ybj; Wed, 6 May 2020 03:37:07 -0700 (PDT) X-Google-Smtp-Source: APiQypIWZ/XtPOMcSoI49kAj0qVEFdpU0grTiN3I6ziueOR9Qci7N/s/CtZD80NBsuDVv/zfX0k8 X-Received: by 2002:a05:6402:356:: with SMTP id r22mr6660256edw.3.1588761427340; Wed, 06 May 2020 03:37:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1588761427; cv=none; d=google.com; s=arc-20160816; b=QOV8bl8vPXZM7l0/C7IwwIneJedDfd3ORTKWRLJ8pDPM+ri4butaquZW9OEYbwmiBb Vma0qaaC8fkeaNk9HIPUUfifx0igLXqPrxF+6u8L/FaxB/MEy8voez3/KeYhnRhq1Uxt 2XKE2qTv3sVl/O3/Shfdvs8vd828RYkrT3XXkydkiXNbLsU/NEzqTgBRZcxw++B6+aca WasTZY0kdZ9jLr9lhf1mas9UYkhS3cp5slPbAHfYOIxK5+0dV47L3uPPg6MDwoXGXDCL JM2RzlFka5cTmlXl4GxvcUVKUlOx1ODeoV8WxPqJDgIOmnIRAlGU3roesFV1KHWcjVbl qWxg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:to:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:from; bh=dE1I6wo8eteCJJkf4gWSP9mTi+/jOFoYw+ZzLfpZd54=; b=YNlhOL6dvOtqWjWKYUfqusopwNSk1pERswECPjUAlaY5vgcg64vgw9guvPPYWCz1Zx SQ0HSAEjS3yV3SMXOk9SrbVrTRaO2bBaRXnvsOszI29gP5RkP34jaDlJVYeFzHQNCw8y YBDMAIC367MKS6oJ+1cjMKtDp1Ja9y7b6n67cL6/ncM/8R+l0ZdC3yuIrGQrxGZaovde Vl+mFH79+tB8FDeyGl2BWkyxkbJR3mqgQTyCtk/09vVDu5a01XZDRonQLQumGnja9IhK Fz9ZRa9e9xAiDUbQrhh+mqa3Rl5QD0OE1TB/yxOun6AoaArSy8AeVC3R0taTcue4G8D2 7QQw== ARC-Authentication-Results: i=1; mx.google.com; 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 m16si778579edq.329.2020.05.06.03.36.44; Wed, 06 May 2020 03:37:07 -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; 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 S1729207AbgEFKfK (ORCPT + 99 others); Wed, 6 May 2020 06:35:10 -0400 Received: from mail.secom.com.pl ([213.216.87.26]:54526 "EHLO mail.secom.com.pl" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728943AbgEFKfJ (ORCPT ); Wed, 6 May 2020 06:35:09 -0400 Received: from debian-2019.secom.com.pl ([192.168.192.41]) by mail.secom.com.pl; Wed, 06 May 2020 12:34:46 +0200 From: =?UTF-8?q?Rafa=C5=82=20Hibner?= Cc: =?UTF-8?q?Rafa=C5=82=20Hibner?= , Appana Durga Kedareswara rao , Radhey Shyam Pandey , Harini Katakam , Vinod Koul , Dan Williams , Michal Simek , dmaengine@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: [PATCH V2] dma: zynqmp_dma: Move list_del inside zynqmp_dma_free_descriptor. Date: Wed, 6 May 2020 12:28:45 +0200 Message-Id: <20200506102844.2259-1-rafal.hibner@secom.com.pl> X-Mailer: git-send-email 2.20.1 In-Reply-To: References: MIME-Version: 1.0 Content-Transfer-Encoding: 8bit To: unlisted-recipients:; (no To-header on input) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org List elements are not formally removed from list during zynqmp_dma_reset. Signed-off-by: Rafal Hibner --- > Looking at this, i think it would make sense to do list_splice_init() before we > send the list to be freed. Moving list_del inside zynqmp_dma_free_descriptor fixes the problem just as well and avoids INIT_LIST_HEAD(list). I still don't see how list_splice_init would help here. Regards, Rafal --- drivers/dma/xilinx/zynqmp_dma.c | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/drivers/dma/xilinx/zynqmp_dma.c b/drivers/dma/xilinx/zynqmp_dma.c index 931e41a72..df0403335 100644 --- a/drivers/dma/xilinx/zynqmp_dma.c +++ b/drivers/dma/xilinx/zynqmp_dma.c @@ -434,6 +434,7 @@ static void zynqmp_dma_free_descriptor(struct zynqmp_dma_chan *chan, struct zynqmp_dma_desc_sw *child, *next; chan->desc_free_cnt++; + list_del(&sdesc->node); list_add_tail(&sdesc->node, &chan->free_list); list_for_each_entry_safe(child, next, &sdesc->tx_list, node) { chan->desc_free_cnt++; @@ -604,8 +605,6 @@ static void zynqmp_dma_chan_desc_cleanup(struct zynqmp_dma_chan *chan) dma_async_tx_callback callback; void *callback_param; - list_del(&desc->node); - callback = desc->async_tx.callback; callback_param = desc->async_tx.callback_param; if (callback) { -- 2.20.1