PM / devfreq: rockchip-dfi: Handle LPDDR2 correctly
authorSascha Hauer <s.hauer@pengutronix.de>
Wed, 18 Oct 2023 06:16:59 +0000 (08:16 +0200)
committerChanwoo Choi <cw00.choi@samsung.com>
Thu, 19 Oct 2023 11:46:17 +0000 (20:46 +0900)
According to the downstream driver the DDRMON_CTRL_LPDDR23 bit must be
set for both LPDDR2 and LPDDR3. Add the missing LPDDR2 case and while
at it turn the if/else if/else into switch/case which makes it easier
to read.

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

index 571d72d1abd1c05d7b07683d76ab0e495e4427bd..8ce0191552ef1e183c30e126f9a10bebe30b9602 100644 (file)
@@ -83,12 +83,19 @@ static void rockchip_dfi_start_hardware_counter(struct devfreq_event_dev *edev)
                       DDRMON_CTRL_HARDWARE_EN), dfi_regs + DDRMON_CTRL);
 
        /* set ddr type to dfi */
-       if (dfi->ddr_type == ROCKCHIP_DDRTYPE_LPDDR3)
+       switch (dfi->ddr_type) {
+       case ROCKCHIP_DDRTYPE_LPDDR2:
+       case ROCKCHIP_DDRTYPE_LPDDR3:
                writel_relaxed(HIWORD_UPDATE(DDRMON_CTRL_LPDDR23, DDRMON_CTRL_DDR_TYPE_MASK),
                               dfi_regs + DDRMON_CTRL);
-       else if (dfi->ddr_type == ROCKCHIP_DDRTYPE_LPDDR4)
+               break;
+       case ROCKCHIP_DDRTYPE_LPDDR4:
                writel_relaxed(HIWORD_UPDATE(DDRMON_CTRL_LPDDR4, DDRMON_CTRL_DDR_TYPE_MASK),
                               dfi_regs + DDRMON_CTRL);
+               break;
+       default:
+               break;
+       }
 
        /* enable count, use software mode */
        writel_relaxed(HIWORD_UPDATE(DDRMON_CTRL_SOFTWARE_EN, DDRMON_CTRL_SOFTWARE_EN),