Received: by 2002:a05:7412:da14:b0:e2:908c:2ebd with SMTP id fe20csp588214rdb; Fri, 6 Oct 2023 12:11:45 -0700 (PDT) X-Google-Smtp-Source: AGHT+IFLlmfiA7bWLqXfVq9PEmSMEgW332BdSHM9iMGc5d8yRq929CfjS+ZzZDsigqptWTeLgjil X-Received: by 2002:a17:90a:ad09:b0:268:2500:b17e with SMTP id r9-20020a17090aad0900b002682500b17emr9297110pjq.23.1696619505410; Fri, 06 Oct 2023 12:11:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1696619505; cv=none; d=google.com; s=arc-20160816; b=ZOE6c4ZWheDjH0sxvTcfsVSjS7UtZov2gCwJmwnAQyiyOSMxOommdR9/hWa2c3W5lG +jXwqdpSB572nUBH8g7AnNwFjr/7O+htrhLGVZ2lt9bn9Ns3/4Md2NvSnfqlqRbgusBm pQGna1tYKkKyfFYrk766woT7gjUJ5NzMz2w60mupvC4usA8vIk8bKt043ecPfZifJvP+ Oc/ck7PYYk30uFTjwnZaihpL0sMUuCM+k9px3LC0CWqlfPI7yHGEN+Pop44SI0d0ssbO pOPvZWIKg+U5bHzx2vkfTniQv5IFK7B42nu93AjrYUcsHv9NGOvEGTfr1kJqo4UcjeVm nLCQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :references:cc:to:content-language:subject:user-agent:mime-version :date:message-id:dkim-signature; bh=Bob5WG29fJunptqizCVxDZ9oSLTwj7639q2KXx0Xx1Y=; fh=zVnE8nzBiWjz6k8ByGXbhrRZONZVucV+BveYc4wwjYA=; b=iOxVDNVioT1qY1M/IAFwrlL6LrLlm37ouXuWyau+gmLtqtJnMgu0Z9qEWjvbSp0jLR GrSGU3BGHAvoUwbV0FaeJD7o5qb1SiGxRfuaaXrXB1oGTw3Yn+5pWLu9VO3vId6CDHNj 23t8GyhYPUnh8lpVY+QbKEa635kTGfYrx+EInFbMMd0TbzCd8q/nXWXSjvaykjp8Rkbw Vk+sdpoIHK9YbJ1DUDxzR4S6VVzjyqZGB2aFtIQquniNp8JM+9kz/YB6HjqGy8JZGzGJ v2m6+T41Cok0VTUbGlMz1uzQSD8G9EwFCDjtkQxN0Q+WkED3Aa6k+tfmn9VcJqx01mdz DnGQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=LorROfMe; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:1 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 morse.vger.email (morse.vger.email. [2620:137:e000::3:1]) by mx.google.com with ESMTPS id d4-20020a170902ef0400b001c76b4c349esi4134996plx.218.2023.10.06.12.11.45 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Fri, 06 Oct 2023 12:11:45 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:1 as permitted sender) client-ip=2620:137:e000::3:1; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=LorROfMe; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::3:1 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: from out1.vger.email (depot.vger.email [IPv6:2620:137:e000::3:0]) by morse.vger.email (Postfix) with ESMTP id 1675F80AFBB0; Fri, 6 Oct 2023 12:11:43 -0700 (PDT) X-Virus-Status: Clean X-Virus-Scanned: clamav-milter 0.103.10 at morse.vger.email Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233384AbjJFTLg (ORCPT + 99 others); Fri, 6 Oct 2023 15:11:36 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39200 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233284AbjJFTLf (ORCPT ); Fri, 6 Oct 2023 15:11:35 -0400 Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id EA04695; Fri, 6 Oct 2023 12:11:33 -0700 (PDT) Received: by smtp.kernel.org (Postfix) with ESMTPSA id EA781C433C7; Fri, 6 Oct 2023 19:11:29 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1696619493; bh=Lj4fRkQCzIZ7u/HC0Jn56DkeYzZ+0j/V7yUN5egW+T8=; h=Date:Subject:To:Cc:References:From:In-Reply-To:From; b=LorROfMehaUyQjuc79SoBmYewe4Ejvwe8RZmEI8S1CxZpcKZ+mYQFx2OovsVINsO/ W7OUqlEf8dIPRZAzpS9AxBZymH+yI/3u3GUOEAzBE9H5U1jP5jj6eXDibcldF0U33G khN63W7+Dz9qmKqaPdiGOQ6OEvTzs6xv4h0FJkg1TlLluy6QsZjp93T7sq0yTHVkk2 BykeLxJWmgK2+G8pGHz1MNvkIuGZMzVlyESd7a09IgWrDOis3RDzvjnqs6iZcV1UgH SC32WBmme2qMxIhP+ALT4gZEdImPeN1UVo6vl5U3vwXNx/SpFSjpDUB25IS98AJa4Z ZSJH86WNV4Lxw== Message-ID: <1eaa8d5b-af6b-71bb-df7a-d438b483f5bb@kernel.org> Date: Sat, 7 Oct 2023 04:11:22 +0900 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.15.1 Subject: Re: [PATCH v7 09/26] PM / devfreq: rockchip-dfi: Clean up DDR type register defines Content-Language: en-US To: Sascha Hauer , linux-rockchip@lists.infradead.org Cc: linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-pm@vger.kernel.org, Heiko Stuebner , Kyungmin Park , MyungJoo Ham , Will Deacon , Mark Rutland , kernel@pengutronix.de, Michael Riesch , Robin Murphy , Vincent Legoll , Rob Herring , Krzysztof Kozlowski , Conor Dooley , devicetree@vger.kernel.org, Sebastian Reichel References: <20230704093242.583575-1-s.hauer@pengutronix.de> <20230704093242.583575-10-s.hauer@pengutronix.de> From: Chanwoo Choi In-Reply-To: <20230704093242.583575-10-s.hauer@pengutronix.de> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-0.4 required=5.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,MAILING_LIST_MULTI,NICE_REPLY_A, RCVD_IN_SBL_CSS,SPF_HELO_NONE,SPF_PASS autolearn=unavailable autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on morse.vger.email Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-Greylist: Sender passed SPF test, not delayed by milter-greylist-4.6.4 (morse.vger.email [0.0.0.0]); Fri, 06 Oct 2023 12:11:43 -0700 (PDT) On 23. 7. 4. 18:32, Sascha Hauer wrote: > Use the HIWORD_UPDATE() define known from other rockchip drivers to > make the defines look less odd to the readers who've seen other > rockchip drivers. > > The HIWORD registers have their functional bits in the lower 16 bits > whereas the upper 16 bits contain a mask. Only the functional bits that > have the corresponding mask bit set are modified during a write. Although > the register writes look different, the end result should be the same, > at least there's no functional change intended with this patch. > > Reviewed-by: Sebastian Reichel > Signed-off-by: Sascha Hauer > --- > drivers/devfreq/event/rockchip-dfi.c | 33 ++++++++++++++++++---------- > 1 file changed, 21 insertions(+), 12 deletions(-) > > diff --git a/drivers/devfreq/event/rockchip-dfi.c b/drivers/devfreq/event/rockchip-dfi.c > index 6bccb6fbcfc0c..6b3ef97b3be09 100644 > --- a/drivers/devfreq/event/rockchip-dfi.c > +++ b/drivers/devfreq/event/rockchip-dfi.c > @@ -26,15 +26,19 @@ > > #define DMC_MAX_CHANNELS 2 > > +#define HIWORD_UPDATE(val, mask) ((val) | (mask) << 16) > + > /* DDRMON_CTRL */ > #define DDRMON_CTRL 0x04 > -#define CLR_DDRMON_CTRL (0x1f0000 << 0) > -#define LPDDR4_EN (0x10001 << 4) > -#define HARDWARE_EN (0x10001 << 3) > -#define LPDDR3_EN (0x10001 << 2) > -#define SOFTWARE_EN (0x10001 << 1) > -#define SOFTWARE_DIS (0x10000 << 1) > -#define TIME_CNT_EN (0x10001 << 0) > +#define DDRMON_CTRL_DDR4 BIT(5) > +#define DDRMON_CTRL_LPDDR4 BIT(4) > +#define DDRMON_CTRL_HARDWARE_EN BIT(3) > +#define DDRMON_CTRL_LPDDR23 BIT(2) > +#define DDRMON_CTRL_SOFTWARE_EN BIT(1) > +#define DDRMON_CTRL_TIMER_CNT_EN BIT(0) > +#define DDRMON_CTRL_DDR_TYPE_MASK (DDRMON_CTRL_DDR4 | \ > + DDRMON_CTRL_LPDDR4 | \ > + DDRMON_CTRL_LPDDR23) > > #define DDRMON_CH0_COUNT_NUM 0x28 > #define DDRMON_CH0_DFI_ACCESS_NUM 0x2c > @@ -73,16 +77,20 @@ static void rockchip_dfi_start_hardware_counter(struct devfreq_event_dev *edev) > void __iomem *dfi_regs = dfi->regs; > > /* clear DDRMON_CTRL setting */ > - writel_relaxed(CLR_DDRMON_CTRL, dfi_regs + DDRMON_CTRL); > + writel_relaxed(HIWORD_UPDATE(0, DDRMON_CTRL_TIMER_CNT_EN | DDRMON_CTRL_SOFTWARE_EN | > + DDRMON_CTRL_HARDWARE_EN), dfi_regs + DDRMON_CTRL); You mentioned that there are no behavior changes even if the different value is written. But, it looks strange. Could you please explain more detailed about it? CLR_DDRMON_CTRL is 0x1f0000 vs. HIWORD_UPDATE(0, DDRMON_CTRL_TIMER_CNT_EN | DDRMON_CTRL_SOFTWARE_EN | DDRMON_CTRL_HARDWARE_EN) = (0 | (BIT(0)|BIT(1)|BIT(3))<<16) = 0xb0000 > > /* set ddr type to dfi */ > if (dfi->ddr_type == ROCKCHIP_DDRTYPE_LPDDR3) > - writel_relaxed(LPDDR3_EN, dfi_regs + DDRMON_CTRL); > + writel_relaxed(HIWORD_UPDATE(DDRMON_CTRL_LPDDR23, DDRMON_CTRL_DDR_TYPE_MASK), > + dfi_regs + DDRMON_CTRL); LPDDR3_EN (0x10001 << 2) = 0x40004 vs. HIWORD_UPDATE(DDRMON_CTRL_LPDDR23, DDRMON_CTRL_DDR_TYPE_MASK) = (BIT(2) | (BIT(5)|BIT(4)|BIT(2))<<16) = 0x340004 > else if (dfi->ddr_type == ROCKCHIP_DDRTYPE_LPDDR4) > - writel_relaxed(LPDDR4_EN, dfi_regs + DDRMON_CTRL); > + writel_relaxed(HIWORD_UPDATE(DDRMON_CTRL_LPDDR4, DDRMON_CTRL_DDR_TYPE_MASK), > + dfi_regs + DDRMON_CTRL); > > /* enable count, use software mode */ > - writel_relaxed(SOFTWARE_EN, dfi_regs + DDRMON_CTRL); > + writel_relaxed(HIWORD_UPDATE(DDRMON_CTRL_SOFTWARE_EN, DDRMON_CTRL_SOFTWARE_EN), > + dfi_regs + DDRMON_CTRL); > } > > static void rockchip_dfi_stop_hardware_counter(struct devfreq_event_dev *edev) > @@ -90,7 +98,8 @@ static void rockchip_dfi_stop_hardware_counter(struct devfreq_event_dev *edev) > struct rockchip_dfi *dfi = devfreq_event_get_drvdata(edev); > void __iomem *dfi_regs = dfi->regs; > > - writel_relaxed(SOFTWARE_DIS, dfi_regs + DDRMON_CTRL); > + writel_relaxed(HIWORD_UPDATE(0, DDRMON_CTRL_SOFTWARE_EN), > + dfi_regs + DDRMON_CTRL); > } > > static void rockchip_dfi_read_counters(struct devfreq_event_dev *edev, struct dmc_count *count) -- Best Regards, Samsung Electronics Chanwoo Choi