Received: by 2002:a05:6a10:6006:0:0:0:0 with SMTP id w6csp232769pxa; Thu, 27 Aug 2020 00:08:09 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxfbmNiRNpeBuRqwlR7PZTHEwvjPDeCu1lcX8QVZu1CpOKyHgTi9b0+B3obkrdTE02z0Tgo X-Received: by 2002:a17:906:f9cf:: with SMTP id lj15mr20124860ejb.520.1598512088906; Thu, 27 Aug 2020 00:08:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1598512088; cv=none; d=google.com; s=arc-20160816; b=Tka3znxaMUJx8FOxlapgIPICIcZ/90cvPZEsQg0P/UX8f7e1bCjcNzQ6zA5txzkjYR oGUb094hoddiq3D0T1BYK5mHMq58MQLKgTKoHpU85aUAAh4VOD4NgPPRpj8WDG0kXO/i DnjOXV+louU0mgX6b+FqAcl0kS82qPzK/HeLFhBkB69p+uqeWft3FJA8+SpmCUTpy4+D bCgbgwqcjjHsaNiW3NZEp1shV0ZQ1V5FJntten+2xasNHk+llmHTFbRmFErvtDcD5cX7 9qej8aa5gSfBvZ5CbEBBVKCn9SnXYFFNH2+0oUUo9ah/VbuHM5fxAwgLZp088jlTeB2S KuSQ== 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=260MNsf+sBTxKFsAR396C3Ut4B0Gn9sQVV96H1/dwCY=; b=BK6FeWjEgowdTP/UdyWQs4iDdOzdggLnIo7Jz2Hei2wn9vK6sC8aI/En7kyMTXa9TD Lg+QI17Ul1wDR10+Sot1hE3ObCroeYCAoVBEolEH/9zjAl/tqj9zzkrKHm924KveZE+v 2eenMd9XVz4d0UeNua2jrXrChJal3FFtGxqLjpKsSgr3KxoKPr7k6Ej5td3Bl8t00yg8 fR8dFn+vPH33Z5EapyLNJGAej233+su5fWdGKZq/BaLfIB/T5Y+Xh55ZyKfVMpE5yOHW cWjpzvrQ6M9mqh3lGubF7ZohuDzqrCndrT+oIg0co4h7YYB2Hw7+GWcBKDYeDWGNUrlR L2hQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=NLCjbjog; 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; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y5si889683edw.381.2020.08.27.00.07.46; Thu, 27 Aug 2020 00:08:08 -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=@ti.com header.s=ti-com-17Q1 header.b=NLCjbjog; 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; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727877AbgH0HEv (ORCPT + 99 others); Thu, 27 Aug 2020 03:04:51 -0400 Received: from fllv0016.ext.ti.com ([198.47.19.142]:34464 "EHLO fllv0016.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726266AbgH0HEu (ORCPT ); Thu, 27 Aug 2020 03:04:50 -0400 Received: from fllv0035.itg.ti.com ([10.64.41.0]) by fllv0016.ext.ti.com (8.15.2/8.15.2) with ESMTP id 07R74WgK042393; Thu, 27 Aug 2020 02:04:32 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1598511872; bh=260MNsf+sBTxKFsAR396C3Ut4B0Gn9sQVV96H1/dwCY=; h=Subject:To:CC:References:From:Date:In-Reply-To; b=NLCjbjog8okMnENPNR3UYZPVyOn5CS5JvV//y37cuZrWRaCVJKxi/ZCMebULpbl4i rqTnakoUmAbTcKUvYMHPvHN9ImhsxO+H6L9x9kldAsbAwS/IFfHm4Dy90ZOH+l5dFt uiOD57c9Q/wMO3k2qnd58psQYZ4NABqC8BuCRvSM= Received: from DLEE113.ent.ti.com (dlee113.ent.ti.com [157.170.170.24]) by fllv0035.itg.ti.com (8.15.2/8.15.2) with ESMTP id 07R74WQH004470; Thu, 27 Aug 2020 02:04:32 -0500 Received: from DLEE100.ent.ti.com (157.170.170.30) by DLEE113.ent.ti.com (157.170.170.24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1979.3; Thu, 27 Aug 2020 02:04:31 -0500 Received: from fllv0039.itg.ti.com (10.64.41.19) by DLEE100.ent.ti.com (157.170.170.30) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1979.3 via Frontend Transport; Thu, 27 Aug 2020 02:04:31 -0500 Received: from [10.250.235.166] (ileax41-snat.itg.ti.com [10.172.224.153]) by fllv0039.itg.ti.com (8.15.2/8.15.2) with ESMTP id 07R74Riu008885; Thu, 27 Aug 2020 02:04:28 -0500 Subject: Re: [RESEND PATCH v3 5/8] mtd: spi-nor: cadence-quadspi: Handle probe deferral while requesting DMA channel To: Jan Kiszka , Tudor Ambarus , Mark Brown , "Jin, Le (RC-CN DF FA R&D)" CC: Boris Brezillon , Ramuthevar Vadivel Murugan , , , , , , References: <20200601070444.16923-1-vigneshr@ti.com> <20200601070444.16923-6-vigneshr@ti.com> <6c8d9bff-3a67-0e6c-d4d1-36b7ed5007b9@web.de> <8cebd31a-2366-4584-b1d1-faa30c18ed6a@ti.com> <8995f5c5-bd6a-c0e5-1e4f-1744aedd2bcd@siemens.com> <5e215c3c-5603-a796-9dea-13b7c2840ed0@ti.com> From: Vignesh Raghavendra Message-ID: Date: Thu, 27 Aug 2020 12:34:26 +0530 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.10.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: 7bit X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 8/26/20 7:01 PM, Jan Kiszka wrote: > On 26.08.20 14:18, Vignesh Raghavendra wrote: >> On 8/26/20 3:42 PM, Jan Kiszka wrote: >>> On 24.08.20 19:20, Jan Kiszka wrote: >>>> On 24.08.20 14:49, Jan Kiszka wrote: >>>>> On 24.08.20 13:45, Vignesh Raghavendra wrote: >>>>>> [...] >> Also, there seems to be DMA mapping related issue, that was always present in >> older driver as well. Could you see if diff [2] fixes the issue? >> >> [2] Use DMA device for mapping: >> >> ---><8--- >> >> >> diff --git a/drivers/spi/spi-cadence-quadspi.c b/drivers/spi/spi-cadence-quadspi.c >> index b9739ae919340..a546aa4598758 100644 >> --- a/drivers/spi/spi-cadence-quadspi.c >> +++ b/drivers/spi/spi-cadence-quadspi.c >> @@ -901,6 +901,7 @@ static int cqspi_direct_read_execute(struct cqspi_flash_pdata *f_pdata, >> { >> struct cqspi_st *cqspi = f_pdata->cqspi; >> struct device *dev = &cqspi->pdev->dev; >> + struct device *ddev = cqspi->rx_chan->device->dev; >> enum dma_ctrl_flags flags = DMA_CTRL_ACK | DMA_PREP_INTERRUPT; >> dma_addr_t dma_src = (dma_addr_t)cqspi->mmap_phys_base + from; >> int ret = 0; >> @@ -917,8 +918,8 @@ static int cqspi_direct_read_execute(struct cqspi_flash_pdata *f_pdata, >> return 0; >> } >> >> - dma_dst = dma_map_single(dev, buf, len, DMA_FROM_DEVICE); >> - if (dma_mapping_error(dev, dma_dst)) { >> + dma_dst = dma_map_single(ddev, buf, len, DMA_FROM_DEVICE); >> + if (dma_mapping_error(ddev, dma_dst)) { >> dev_err(dev, "dma mapping failed\n"); >> return -ENOMEM; >> } >> @@ -952,7 +953,7 @@ static int cqspi_direct_read_execute(struct cqspi_flash_pdata *f_pdata, >> } >> >> err_unmap: >> - dma_unmap_single(dev, dma_dst, len, DMA_FROM_DEVICE); >> + dma_unmap_single(ddev, dma_dst, len, DMA_FROM_DEVICE); >> >> return ret; >> } >> > > That seems to help! Wasn't able to reproduce the issue with this applied > so far. > OK, great... I will post this patch soon once I finish a bit more testing... Thanks! Regards Vignesh