PM / devfreq: rockchip-dfi: Clean up DDR type register defines
authorSascha Hauer <s.hauer@pengutronix.de>
Wed, 18 Oct 2023 06:16:57 +0000 (08:16 +0200)
committerChanwoo Choi <cw00.choi@samsung.com>
Thu, 19 Oct 2023 11:41:35 +0000 (20:41 +0900)
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.

Link: https://lore.kernel.org/all/20231018061714.3553817-10-s.hauer@pengutronix.de/
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
Reviewed-by: Sebastian Reichel <sebastian.reichel@collabora.com>
Acked-by: Chanwoo Choi <cw00.choi@samsung.com>
Signed-off-by: Chanwoo Choi <cw00.choi@samsung.com>
drivers/devfreq/event/rockchip-dfi.c

index 82d18c60538a50e13837baba8f6c4711e5fee24f..12f90968792357dff3273130a418a49b9b8b18a6 100644 (file)
 
 #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
@@ -74,16 +78,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);
 
        /* 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);
        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)
@@ -91,7 +99,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)