Received: by 2002:a25:868d:0:0:0:0:0 with SMTP id z13csp1489339ybk; Thu, 14 May 2020 10:12:25 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxjTesVkZvv1aCClDnKj9q3/lgeMJYxYjr8jQAeQ1YcIXGGfZMEfBez/tyEW6GEiY/iZ3Mg X-Received: by 2002:a50:d1d3:: with SMTP id i19mr4755391edg.35.1589476342950; Thu, 14 May 2020 10:12:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1589476342; cv=none; d=google.com; s=arc-20160816; b=uek5l5jbvqUl2VVN3OpAZ6m+tot5Iavfclu59bgWPY7U2CcR2bml2O9MgXXdVBTc8O zdvgLhmvKJoK0zCLXu8R/F3L4bj/i27thCfFPfd8Av6qcOFMNzsVsHfcVYAuUjwNpc5Z Ra9KXGE0J7TYgN4obyuMhg4qQVw1/+csf4e2Wogi0j+m4Tzx2z1eKOshFFBlP9cSeJnc qkldCB7Ye2uVSV3E7DP1T6fGXRyfA8AqYnb7GlweQfwxNjGhQ39sA6O+6qJFqG8p9Fkf qj7a/7eodtqu1bkTlwuq39MJG+N3NLCctgpVfLrUp9pIavmd8MHyRAAZgnRDgRzfE245 ivxQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=uUcyf9NwOhWDSsoXsAafDnpXglCvcvKACjl1qcHNAFk=; b=T8jeSE2OY3Q2ifexGm7JIQQx36xC/m1q4xAh7ld6jGpBw6tVhPxc8b8firDw6vBmtr znCuXscMJGKU+SRbreZLWTl46SBIkOLxlM8GhLSDaxyTpNWgKwoJwmgV7u4+TQmrv71+ tCfpaDLmqeti3+COm6Ku2Zm8UCZebSR/f/Ihg+6s90JHrX/qbMXJp6ezR1jWSu62qKQ+ 8vQ6BoNsl2WUR/mduXYgIFWLvfQlt4cgeBh2/vYDyRjAtgbp0c475ePaV7uiRddNlItu j+wLFGizIA1RIFk79fRREbuYYsgWzdcVYd6fpDqBCwM7bkcj1/+E1uXjw86un4hbRZki HIPg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linaro.org header.s=google header.b="m1/voEXy"; 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=linaro.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p9si2243435ejg.108.2020.05.14.10.11.59; Thu, 14 May 2020 10:12:22 -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=@linaro.org header.s=google header.b="m1/voEXy"; 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=linaro.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726202AbgENRI1 (ORCPT + 99 others); Thu, 14 May 2020 13:08:27 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:60408 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726062AbgENRI0 (ORCPT ); Thu, 14 May 2020 13:08:26 -0400 Received: from mail-pf1-x442.google.com (mail-pf1-x442.google.com [IPv6:2607:f8b0:4864:20::442]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id B5BB6C05BD43 for ; Thu, 14 May 2020 10:08:25 -0700 (PDT) Received: by mail-pf1-x442.google.com with SMTP id d184so1582643pfd.4 for ; Thu, 14 May 2020 10:08:25 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linaro.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to; bh=uUcyf9NwOhWDSsoXsAafDnpXglCvcvKACjl1qcHNAFk=; b=m1/voEXyUnijavkOQ2KcCoSjVH54gh9UOXPA7PAvf7E+8JFUn7g+xt6iYEALFHnLnA QF2divI3/3Aldqgbubwmwyp+pXVy9GbeZAOV9LSANKIBjmYqK9sNAYffdkL1GzI0IDqU LKofRS/Sz9SINnKubmGRLNW81UD9AqjrjY3Wm07fSjPTGjjJ77uHHyIQqeY4Itm+sc8e lImgcyfqOZD4/XX1a3LdUnp5EscjmX1ByO20ve6PERtwuIefl5Bmj3qsjLsPdA8U7bZL epydIx60tjNt9FI9WbTRy2EpfwUU92JbmjKT32P2o2JzzW9oAQiY0FS/wUhZYOorfpei Tk2Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=uUcyf9NwOhWDSsoXsAafDnpXglCvcvKACjl1qcHNAFk=; b=rIB9Lt0w7if3xlwUcouZ7/zm+xJn1ENTAawalphnnw4q+JHUemTnWh5LqzBnJM/f/G JHLzfxfn1ADMYxTjlln66aJXeqMM8ffbAndPoIndyuJPVmabv1DMU1oON8iGDIikMbQ3 3YsqyaZ2cQv+wKKot77UHIcTJtjLaiynqAd1YsHH64FCHQrvTzsz8fpQhhnHE/GtBbnW j55AU5TJlCViZ0HQb4KPKcGQ4DYyxUvMQzp+mVIszxQUVhKfIAZP9OmwmtvJ7UbT5/34 bhwb6w3U55S6xvJuALZxzave3Dn7ZzCDiahQXR0OPJzAXaQzBXQ7wTlnwo9rmeQ5zQTq 6RdQ== X-Gm-Message-State: AOAM5324yfu3Bxf90uuUKQcPFKH4jyMZh65DkHMEqLeqQBLUP1jHBnZD jaQTc1SHFyVSsKzHlUJQSSTXZg== X-Received: by 2002:a65:6703:: with SMTP id u3mr4771334pgf.179.1589476105048; Thu, 14 May 2020 10:08:25 -0700 (PDT) Received: from builder.lan (104-188-17-28.lightspeed.sndgca.sbcglobal.net. [104.188.17.28]) by smtp.gmail.com with ESMTPSA id j186sm2754328pfb.220.2020.05.14.10.08.23 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 14 May 2020 10:08:24 -0700 (PDT) Date: Thu, 14 May 2020 10:06:54 -0700 From: Bjorn Andersson To: Baolin Wang Cc: Andy Gross , Ohad Ben-Cohen , Rob Herring , linux-arm-msm@vger.kernel.org, linux-remoteproc@vger.kernel.org, Devicetree List , LKML Subject: Re: [PATCH 3/4] hwspinlock: qcom: Allow mmio usage in addition to syscon Message-ID: <20200514170654.GY2165@builder.lan> References: <20200513005441.1102586-1-bjorn.andersson@linaro.org> <20200513005441.1102586-4-bjorn.andersson@linaro.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue 12 May 20:57 PDT 2020, Baolin Wang wrote: > On Wed, May 13, 2020 at 8:55 AM Bjorn Andersson > wrote: > > > > In all modern Qualcomm platforms the mutex region of the TCSR is forked > > off into its own block, all with a offset of 0 and stride of 4096. So > > add support for directly memory mapping this register space, to avoid > > the need to represent this block using a syscon. > > > > Signed-off-by: Bjorn Andersson > > --- > > drivers/hwspinlock/qcom_hwspinlock.c | 72 +++++++++++++++++++++------- > > 1 file changed, 56 insertions(+), 16 deletions(-) > > > > diff --git a/drivers/hwspinlock/qcom_hwspinlock.c b/drivers/hwspinlock/qcom_hwspinlock.c [..] > > +static struct regmap *qcom_hwspinlock_probe_mmio(struct platform_device *pdev, > > + u32 *offset, u32 *stride) > > +{ > > + struct device *dev = &pdev->dev; > > + struct resource *res; > > + void __iomem *base; > > + > > + /* All modern platform has offset 0 and stride of 4k */ > > + *offset = 0; > > + *stride = 0x1000; > > + > > + res = platform_get_resource(pdev, IORESOURCE_MEM, 0); > > + base = devm_ioremap_resource(&pdev->dev, res); > > I think you can use devm_platform_ioremap_resource(pdev, 0) to > simplify your code, otherwise looks good to me. You're right, I better fix this before someone with Coccinelle get the chance ;) > Reviewed-by: Baolin Wang > Thanks, Bjorn