Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp4415120pxk; Wed, 30 Sep 2020 02:15:56 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxkXVdoen1UPXA85+IHvrlZvCA5GvmqCI0eksdzIUhXLCNptcydgTmpoWsL21CwUZ71L981 X-Received: by 2002:a17:906:1fc8:: with SMTP id e8mr1779338ejt.280.1601457355911; Wed, 30 Sep 2020 02:15:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601457355; cv=none; d=google.com; s=arc-20160816; b=bRs1WNUfP/V0MvyNN1FaUb+N52xdnECk84q2PVU0eXMW46vf3dTFkyWYOLCHke5Nl7 oLI6gFLB7Y55qFe9/I0V6BsgCDduJw1nyAY9+BhnTK5OAS/+xCZsywS/OwryYyRUOr1h AK6Lsi05QzCK9tVeuPBgT8SUi3qbC8sDBlEFT8VU8I8pTsZ4iCzfOaTYLXr1RkMzTRmv 8zxaT4/+j5KH2xLYyjXkjHw2KJrSeQoDR7WflwtUSbOFH+rUDqjPb7Ns4eMnzRkdH/ir g3kCl5JmdBRnzJ2clyRqHT1b+KZxR05FZSIYTsugPuAEdDiZjWlkO1raxK1Jqd9rsJ21 XZsg== 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 :dkim-signature; bh=uajOkBw+qG5SkQgCuPiRovW8kdqx1dHM4++EH9YD2UM=; b=QJiMhanuwzjcFoQVskp/Ie0AeESWFTS8yRk33W7eiPQMIMsqoIPUnldwfsLjLodAss BfwmzM8//DkBlGQ9Bymxlp0S3PLdLsXRFWH+Zf0cDGIyo8Hr/KdgSaFggUSgUGWMUYkL wYOnTSDYv5hZ5RK7/0z1ZpuuBS3yl04FRK+LpR1eZyltoph1heJrddhqmGXUHXdP+V7R KqMpkV4eHcHlsi5iWnYp3Gs8CaN9eJoOiTtcrpVdII6HZ0HxarHKQDgUFo8ftrO3Buh6 US89tGdFrf/UwUPFTkIEKuuGQCHtpcYLePArekJlRwO/ZHQbFHkamsYgFUSslbK/7yNm NH7w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=aw+HeqcU; 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 g1si902125ejf.109.2020.09.30.02.15.33; Wed, 30 Sep 2020 02:15:55 -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=aw+HeqcU; 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 S1728999AbgI3JO0 (ORCPT + 99 others); Wed, 30 Sep 2020 05:14:26 -0400 Received: from fllv0016.ext.ti.com ([198.47.19.142]:53024 "EHLO fllv0016.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728938AbgI3JOT (ORCPT ); Wed, 30 Sep 2020 05:14:19 -0400 Received: from lelv0266.itg.ti.com ([10.180.67.225]) by fllv0016.ext.ti.com (8.15.2/8.15.2) with ESMTP id 08U9EEFK067322; Wed, 30 Sep 2020 04:14:14 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1601457254; bh=uajOkBw+qG5SkQgCuPiRovW8kdqx1dHM4++EH9YD2UM=; h=From:To:CC:Subject:Date:In-Reply-To:References; b=aw+HeqcU8C9VIFIa+Y6W+4tXwp9mCLuhk9PaHXtlNaZcGWDOSEcC+C6hTsKQH73Ga im1zbCGc6y5oDzOOi4Ic/KxxmKad4wP/hGACsIWFjRsGYYZ/QhYU1bXtpEAI9hF9xo EOre/23/yc9HgeLwBX12aCAC7kCEGTs24geDn4K8= Received: from DFLE105.ent.ti.com (dfle105.ent.ti.com [10.64.6.26]) by lelv0266.itg.ti.com (8.15.2/8.15.2) with ESMTPS id 08U9EEHi049314 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Wed, 30 Sep 2020 04:14:14 -0500 Received: from DFLE100.ent.ti.com (10.64.6.21) by DFLE105.ent.ti.com (10.64.6.26) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1979.3; Wed, 30 Sep 2020 04:14:14 -0500 Received: from fllv0039.itg.ti.com (10.64.41.19) by DFLE100.ent.ti.com (10.64.6.21) 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; Wed, 30 Sep 2020 04:14:14 -0500 Received: from feketebors.ti.com (ileax41-snat.itg.ti.com [10.172.224.153]) by fllv0039.itg.ti.com (8.15.2/8.15.2) with ESMTP id 08U9DuJc116385; Wed, 30 Sep 2020 04:14:11 -0500 From: Peter Ujfalusi To: , , , , CC: , , , , , , Subject: [PATCH 05/18] dmaengine: ti: k3-udma: Wait for peer teardown completion if supported Date: Wed, 30 Sep 2020 12:13:59 +0300 Message-ID: <20200930091412.8020-6-peter.ujfalusi@ti.com> X-Mailer: git-send-email 2.28.0 In-Reply-To: <20200930091412.8020-1-peter.ujfalusi@ti.com> References: <20200930091412.8020-1-peter.ujfalusi@ti.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Set the TDTYPE if it is supported on the platform (j721e) which will cause UDMAP to wait for the remote peer to finish the teardown before returning the teardown completed message. Signed-off-by: Peter Ujfalusi Tested-by: Keerthy Reviewed-by: Grygorii Strashko --- drivers/dma/ti/k3-udma.c | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/drivers/dma/ti/k3-udma.c b/drivers/dma/ti/k3-udma.c index de7bfc02a2de..3f798993a8b1 100644 --- a/drivers/dma/ti/k3-udma.c +++ b/drivers/dma/ti/k3-udma.c @@ -86,6 +86,7 @@ struct udma_rchan { #define UDMA_FLAG_PDMA_ACC32 BIT(0) #define UDMA_FLAG_PDMA_BURST BIT(1) +#define UDMA_FLAG_TDTYPE BIT(2) struct udma_match_data { u32 psil_base; @@ -1591,6 +1592,13 @@ static int udma_tisci_tx_channel_config(struct udma_chan *uc) req_tx.tx_fetch_size = fetch_size >> 2; req_tx.txcq_qnum = tc_ring; req_tx.tx_atype = uc->config.atype; + if (uc->config.ep_type == PSIL_EP_PDMA_XY && + ud->match_data->flags & UDMA_FLAG_TDTYPE) { + /* wait for peer to complete the teardown for PDMAs */ + req_tx.valid_params |= + TI_SCI_MSG_VALUE_RM_UDMAP_CH_TX_TDTYPE_VALID; + req_tx.tx_tdtype = 1; + } ret = tisci_ops->tx_ch_cfg(tisci_rm->tisci, &req_tx); if (ret) @@ -3107,14 +3115,14 @@ static struct udma_match_data am654_mcu_data = { static struct udma_match_data j721e_main_data = { .psil_base = 0x1000, .enable_memcpy_support = true, - .flags = UDMA_FLAG_PDMA_ACC32 | UDMA_FLAG_PDMA_BURST, + .flags = UDMA_FLAG_PDMA_ACC32 | UDMA_FLAG_PDMA_BURST | UDMA_FLAG_TDTYPE, .statictr_z_mask = GENMASK(23, 0), }; static struct udma_match_data j721e_mcu_data = { .psil_base = 0x6000, .enable_memcpy_support = false, /* MEM_TO_MEM is slow via MCU UDMA */ - .flags = UDMA_FLAG_PDMA_ACC32 | UDMA_FLAG_PDMA_BURST, + .flags = UDMA_FLAG_PDMA_ACC32 | UDMA_FLAG_PDMA_BURST | UDMA_FLAG_TDTYPE, .statictr_z_mask = GENMASK(23, 0), }; -- Peter Texas Instruments Finland Oy, Porkkalankatu 22, 00180 Helsinki. Y-tunnus/Business ID: 0615521-4. Kotipaikka/Domicile: Helsinki