Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp3183559pxj; Mon, 7 Jun 2021 04:36:33 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzZfOcwiUcmdY4XlmRfx4J9+bE8J0gw8wcKLY7w+GH4lf3H/aM25HaIOg9jZQurz7aP0Hd+ X-Received: by 2002:a17:906:ccd9:: with SMTP id ot25mr17348776ejb.386.1623065793516; Mon, 07 Jun 2021 04:36:33 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1623065793; cv=none; d=google.com; s=arc-20160816; b=vZTVurslxRbOJ5hPcWvMKB9GpOZWsswjRQQQbDZvtBx7GTxdkPEejkTdNNiqxEo5el gz2zjylkY7Z1Ws7XiTdJl4WKGSqgPOFLxukOzTV1ZuyXSFYoLeM9WD1Ua9Ghyg2aFT85 g8tXDxd/4u+zCDDWf04r7CJDuFvM9KCu6IS+8LFNOUMQNbD2+plx5mxAEigRuDe1UyBK BteKwJfV2PUNkshL8YtA/vYB6lK3cy4u7ghQRhyStnWG6/TyXptlxPsvzYETn9/OuSAS Hu/wMlVHTwPDEZBrWSU8OwkzAxfomWZcm5l7vLT6O29aLJyQJ1yUtTfdHoMF4y7fmfor qeaQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=vFubVLJWNAL1H/uNUzNLSZ5vc89kQwNpPb2y+eDT5T8=; b=FVFW10tY+CJIzf+TZQBhfmxs1SvjhpdRjXno1DM55qL5FWIGry5xMhhwMgkkHa2laa BQBugT1ydzvffWckWpDR2pl3CdqBw2QgJtitAg9VpQaD8wnCg+GALCcAPRy8P9u9VW2y UqCbgopP2ztLZmrrEreb40S/nu44KBS0XBnuU+BydeYvniMOH0u+Kxlw+F9yOdD/3PC1 kfjthnCoSyp0mzRpXgVSi3eLHayUVLi+awT6WM/+aTbtr0VwILwF6Bdw/aYUCXdBSGps pDv7qgz/3PpanXpKc9mdBQ8xm5HudeSCg7/xyD8ValWJS2uxn39fOxent0ZaJrun22xt RxGw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=cPgbGmqf; 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=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id hc43si15224014ejc.513.2021.06.07.04.36.10; Mon, 07 Jun 2021 04:36:33 -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=@kernel.org header.s=k20201202 header.b=cPgbGmqf; 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=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230454AbhFGLgw (ORCPT + 99 others); Mon, 7 Jun 2021 07:36:52 -0400 Received: from mail.kernel.org ([198.145.29.99]:49336 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230230AbhFGLgv (ORCPT ); Mon, 7 Jun 2021 07:36:51 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 0ABF5610C7; Mon, 7 Jun 2021 11:34:59 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1623065700; bh=v0YJkBcz+6wfgXabI+7TF72vY2yLxw672rc/FUtSO5Y=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=cPgbGmqf+oGa6/ijvcX0YbECLH3xQ6+fkn3gJEjG1h+mcGRVlaaUfDvr8scLldozp p1gkiCfIap8DrG31wbs97znYWf2nu7TT6b8KFTHYMXCwVuMU+K8uQQeUjTvzNI6VWm 6ZNBnk0Wl9UYIZpqBzqncM9magLVWccGGqWefcHmYSqBnac7bCZ6bdDpNIq/BnNBvZ vB3G+WsxQEYcnxz/EBz6BlwT6ogG5T1RMt2+S8REfAn12w6ZoBBe7KXbhwQWKtl8Zo u5CsgbaTRhaDqx6H/xAbFZjY6f0JS44Meml23n7F3Sjl4YfW1p5aPf+jdV8yTfJC48 p1fKMaNt5yIDw== Date: Mon, 7 Jun 2021 17:04:57 +0530 From: Vinod Koul To: Andy Shevchenko Cc: Serge Semin , dmaengine@vger.kernel.org, linux-kernel@vger.kernel.org, Viresh Kumar Subject: Re: [PATCH v1 1/1] dmaengine: dw: Program xBAR hardware for Elkhart Lake Message-ID: References: <20210602085604.21933-1-andriy.shevchenko@linux.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20210602085604.21933-1-andriy.shevchenko@linux.intel.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 02-06-21, 11:56, Andy Shevchenko wrote: > Intel Elkhart Lake PSE DMA implementation is integrated with crossbar IP > in order to serve more hardware than there are DMA request lines available. > > Due to this, program xBAR hardware to make flexible support of PSE peripheral. > > Signed-off-by: Andy Shevchenko > --- > drivers/dma/dw/idma32.c | 146 ++++++++++++++++++++++++++- > drivers/dma/dw/internal.h | 16 +++ > drivers/dma/dw/pci.c | 6 +- > drivers/dma/dw/platform.c | 6 +- > include/linux/platform_data/dma-dw.h | 3 + > 5 files changed, 168 insertions(+), 9 deletions(-) > > diff --git a/drivers/dma/dw/idma32.c b/drivers/dma/dw/idma32.c > index 3ce44de25d33..5232fcb1a736 100644 > --- a/drivers/dma/dw/idma32.c > +++ b/drivers/dma/dw/idma32.c > @@ -1,15 +1,152 @@ > // SPDX-License-Identifier: GPL-2.0 > -// Copyright (C) 2013,2018 Intel Corporation > +// Copyright (C) 2013,2018,2020 Intel Corporation 2021..? > > #include > #include > #include > +#include > +#include > #include > #include > > #include "internal.h" > > -static void idma32_initialize_chan(struct dw_dma_chan *dwc) > +#define DMA_CTL_CH(x) (0x1000 + (x) * 4) > +#define DMA_SRC_ADDR_FILLIN(x) (0x1100 + (x) * 4) > +#define DMA_DST_ADDR_FILLIN(x) (0x1200 + (x) * 4) > +#define DMA_XBAR_SEL(x) (0x1300 + (x) * 4) > +#define DMA_REGACCESS_CHID_CFG (0x1400) > + > +#define CTL_CH_TRANSFER_MODE_MASK GENMASK(1, 0) > +#define CTL_CH_TRANSFER_MODE_S2S 0 > +#define CTL_CH_TRANSFER_MODE_S2D 1 > +#define CTL_CH_TRANSFER_MODE_D2S 2 > +#define CTL_CH_TRANSFER_MODE_D2D 3 > +#define CTL_CH_RD_RS_MASK GENMASK(4, 3) > +#define CTL_CH_WR_RS_MASK GENMASK(6, 5) > +#define CTL_CH_RD_NON_SNOOP_BIT BIT(8) > +#define CTL_CH_WR_NON_SNOOP_BIT BIT(9) > + > +#define XBAR_SEL_DEVID_MASK GENMASK(15, 0) > +#define XBAR_SEL_RX_TX_BIT BIT(16) > +#define XBAR_SEL_RX_TX_SHIFT 16 > + > +#define REGACCESS_CHID_MASK GENMASK(2, 0) > + > +static unsigned int idma32_get_slave_devid(struct dw_dma_chan *dwc) > +{ > + struct device *slave = dwc->chan.slave; > + > + if (!slave || !dev_is_pci(slave)) > + return 0; > + > + return to_pci_dev(slave)->devfn; so this return devfn.. maybe rename function to get_slave_devfn() ? > +} > + > +static void idma32_initialize_chan_xbar(struct dw_dma_chan *dwc) > +{ > + struct dw_dma *dw = to_dw_dma(dwc->chan.device); > + void __iomem *misc = __dw_regs(dw); > + u32 cfghi = 0, cfglo = 0; > + u8 dst_id, src_id; > + u32 value; > + > + /* DMA Channel ID Configuration register must be programmed first */ > + value = readl(misc + DMA_REGACCESS_CHID_CFG); > + > + value &= ~REGACCESS_CHID_MASK; > + value |= dwc->chan.chan_id; > + > + writel(value, misc + DMA_REGACCESS_CHID_CFG); > + > + /* Configure channel attributes */ > + value = readl(misc + DMA_CTL_CH(dwc->chan.chan_id)); > + > + value &= ~(CTL_CH_RD_NON_SNOOP_BIT | CTL_CH_WR_NON_SNOOP_BIT); > + value &= ~(CTL_CH_RD_RS_MASK | CTL_CH_WR_RS_MASK); > + value &= ~CTL_CH_TRANSFER_MODE_MASK; > + > + switch (dwc->direction) { > + case DMA_MEM_TO_MEM: > + value |= CTL_CH_TRANSFER_MODE_D2D; > + break; > + case DMA_MEM_TO_DEV: > + value |= CTL_CH_TRANSFER_MODE_D2S; > + value |= CTL_CH_WR_NON_SNOOP_BIT; > + break; > + case DMA_DEV_TO_MEM: > + value |= CTL_CH_TRANSFER_MODE_S2D; > + value |= CTL_CH_RD_NON_SNOOP_BIT; > + break; > + case DMA_DEV_TO_DEV: > + default: > + value |= CTL_CH_WR_NON_SNOOP_BIT | CTL_CH_RD_NON_SNOOP_BIT; > + value |= CTL_CH_TRANSFER_MODE_S2S; > + break; aha, how did you test this... -- ~Vinod