Received: by 2002:a05:6a10:2785:0:0:0:0 with SMTP id ia5csp2431151pxb; Mon, 11 Jan 2021 09:25:33 -0800 (PST) X-Google-Smtp-Source: ABdhPJxaqVnLOH3NrdNOu1Un+i1Fbj0UPTj/hBcCh//e+RpYQnDlj0LUbovMng2WUHlcGy9wx7oa X-Received: by 2002:a17:906:7f11:: with SMTP id d17mr358728ejr.534.1610385933149; Mon, 11 Jan 2021 09:25:33 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1610385933; cv=none; d=google.com; s=arc-20160816; b=k+cJhhSc6oGqjR0fSdj87nrGcdSLjkB4uvI7sv6QIRZtzzXFIgN/3fH+j2SR1tjX0k OA+IRuUg+bz+aQ5H3q0g98fhG7S4R6XBKx5cMEUw90pUlfjgzS9dclVYjyMt9YYtN+uq Iw1tScGvBDJ4IkunGBEV6CKq7bgeJik+7lhCfx/9BotFPqRVc8+Ji+awLSL7VcfBUajK sErw3/elpuBCPtZfQNEPeAjRdnulkLGFSAPU49vMWCWOHf/qZEPz+KppGTvxoCzF9l0J 18UiBBlsJuuxcVKEl3reyKbNIQei2Uk1OXXyxF5wfBw9y1KV3y+f9Ywy6x4Db41DYdRu Eqhg== 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=nlQQ/vuvM+YFD1P2kwNcnM5GCWtwQx+O3Y0S8Yn3P+c=; b=TZkjvc3tuWlycgDw9F7NVzBv/YtRWpK48QJ9IFwIszJTXZm52ALSyy2NaOMEA0qnvT tHZPcMrd4Lu+j85FISfQOXb+t2AHaQi56A2PR4GDhVEcEre9fiDxJ5NPaVIpuH2iWRd6 sdKehKUIsHYjDvPKcL23+0R2ArpKkksJnQ85q1rUB1of6E3WJPIKIEl0dqwhK00GMvll prVUUre1QoL1PT903uPJtAXU+IVnkutJd9VQJbZXeTNJ5Vu+IyeQ8OwjLkmrgUR1LfmN AWx4QNNhPjg/17Ul7wKF/HoKGnnQd7LTsJXXhRqHeEfV3WupiCNCTc6SiEd3W0fiGjcW 4hqQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b="UKRoI/e2"; 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 mf27si40668ejb.129.2021.01.11.09.25.08; Mon, 11 Jan 2021 09:25:33 -0800 (PST) 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="UKRoI/e2"; 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 S2389470AbhAKRWq (ORCPT + 99 others); Mon, 11 Jan 2021 12:22:46 -0500 Received: from mail.kernel.org ([198.145.29.99]:55678 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389172AbhAKRWp (ORCPT ); Mon, 11 Jan 2021 12:22:45 -0500 Received: by mail.kernel.org (Postfix) with ESMTPSA id 16AFF22AAD; Mon, 11 Jan 2021 17:22:03 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1610385725; bh=ucPgUzXVIgWKKN/+F8TNx30krDlRgEwvSla3l6JVkSU=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=UKRoI/e2JspwtRrHn2mzv0r4hzgem7xRf7oblunSNksCu9iLEM30gwWBM+EfL4EZ8 8QztRIpnPMiMF9LJj7czvYTXwakOf15ku18gA1aMtTx10xl/7NyhyHX7cRrYAPqylg IjOmojire0zwNCkbqEQNluEw6AZ3nstYOJ2Wf1KXerz2eQeIG0WknAxcDsCFL2np5k 0ogyxZPPzrYbUUPh9lT62na9TIeswAO3VWqXZfOZ/5gR+QV7JlqV3PquwjfMBkm9U0 L/7l9dHWiZjydDjUuwz7eWNWIz4Gjk5pzYcwhu4Vdk6X9gnQs4KBeNa1q/osAxTXmA XvX/jN8RUx9FQ== Date: Mon, 11 Jan 2021 22:52:00 +0530 From: Vinod Koul To: Bjorn Andersson Cc: Mark Brown , Wolfram Sang , linux-arm-msm@vger.kernel.org, Andy Gross , Matthias Kaehlcke , Douglas Anderson , Sumit Semwal , Amit Pundir , linux-spi@vger.kernel.org, linux-i2c@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 3/7] soc: qcom: geni: Add support for gpi dma Message-ID: <20210111172200.GZ2771@vkoul-mobl> References: <20210111151651.1616813-1-vkoul@kernel.org> <20210111151651.1616813-4-vkoul@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 11-01-21, 09:40, Bjorn Andersson wrote: > On Mon 11 Jan 09:16 CST 2021, Vinod Koul wrote: > > > GPI DMA is one of the DMA modes supported on geni, this adds support to > > enable that mode > > > > Signed-off-by: Vinod Koul > > --- > > drivers/soc/qcom/qcom-geni-se.c | 39 ++++++++++++++++++++++++++++++++- > > include/linux/qcom-geni-se.h | 4 ++++ > > 2 files changed, 42 insertions(+), 1 deletion(-) > > > > diff --git a/drivers/soc/qcom/qcom-geni-se.c b/drivers/soc/qcom/qcom-geni-se.c > > index a3868228ea05..db44dc32e049 100644 > > --- a/drivers/soc/qcom/qcom-geni-se.c > > +++ b/drivers/soc/qcom/qcom-geni-se.c > > @@ -310,6 +310,39 @@ static void geni_se_select_dma_mode(struct geni_se *se) > > writel_relaxed(val, se->base + SE_GENI_DMA_MODE_EN); > > } > > > > +static int geni_se_select_gpi_mode(struct geni_se *se) > > This doesn't return any information and the return value isn't looked > at, please make it void. Sure.. > > +{ > > + unsigned int geni_dma_mode = 0; > > + unsigned int gpi_event_en = 0; > > + unsigned int common_geni_m_irq_en = 0; > > + unsigned int common_geni_s_irq_en = 0; > > These could certainly be given a shorter name. Certainly.. > None of them needs to be initialized, first access in all cases are > assignments. Will update > > + > > + common_geni_m_irq_en = readl_relaxed(se->base + SE_GENI_M_IRQ_EN); > > + common_geni_s_irq_en = readl_relaxed(se->base + SE_GENI_S_IRQ_EN); > > + common_geni_m_irq_en &= > > + ~(M_CMD_DONE_EN | M_TX_FIFO_WATERMARK_EN | > > + M_RX_FIFO_WATERMARK_EN | M_RX_FIFO_LAST_EN); > > + common_geni_s_irq_en &= ~S_CMD_DONE_EN; > > + geni_dma_mode = readl_relaxed(se->base + SE_GENI_DMA_MODE_EN); > > + gpi_event_en = readl_relaxed(se->base + SE_GSI_EVENT_EN); > > + > > + geni_dma_mode |= GENI_DMA_MODE_EN; > > + gpi_event_en |= (DMA_RX_EVENT_EN | DMA_TX_EVENT_EN | > > + GENI_M_EVENT_EN | GENI_S_EVENT_EN); > > Please reorder these so that you do > readl(m) > mask out bits of m > > readl(s) > mask out bits of s > > ... okay will update > > + > > + writel_relaxed(0, se->base + SE_IRQ_EN); > > + writel_relaxed(common_geni_s_irq_en, se->base + SE_GENI_S_IRQ_EN); > > + writel_relaxed(common_geni_m_irq_en, se->base + SE_GENI_M_IRQ_EN); > > + writel_relaxed(0xFFFFFFFF, se->base + SE_GENI_M_IRQ_CLEAR); > > Lowercase hex digits please. Yeah missed > > + writel_relaxed(0xFFFFFFFF, se->base + SE_GENI_S_IRQ_CLEAR); > > + writel_relaxed(0xFFFFFFFF, se->base + SE_DMA_TX_IRQ_CLR); > > + writel_relaxed(0xFFFFFFFF, se->base + SE_DMA_RX_IRQ_CLR); > > + writel_relaxed(geni_dma_mode, se->base + SE_GENI_DMA_MODE_EN); > > + writel_relaxed(gpi_event_en, se->base + SE_GSI_EVENT_EN); > > Why is this driver using _relaxed accessors exclusively? Why are you > using _relaxed versions? > > And wouldn't it be suitable to have a wmb() before the "dma mode enable" > and "event enable" at least? (I.e. use writel() instead) Yeah we invoke this to select the mode before programming DMA, so yes a wmb() would make sense. Thanks for quick look -- ~Vinod