PM / devfreq: rockchip-dfi: Handle LPDDR2 correctly
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>
This commit is contained in:
committed by
Chanwoo Choi
parent
076b0597f5
commit
038ff6f53d
@@ -83,12 +83,19 @@ static void rockchip_dfi_start_hardware_counter(struct devfreq_event_dev *edev)
|
|||||||
DDRMON_CTRL_HARDWARE_EN), dfi_regs + DDRMON_CTRL);
|
DDRMON_CTRL_HARDWARE_EN), dfi_regs + DDRMON_CTRL);
|
||||||
|
|
||||||
/* set ddr type to dfi */
|
/* 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),
|
writel_relaxed(HIWORD_UPDATE(DDRMON_CTRL_LPDDR23, DDRMON_CTRL_DDR_TYPE_MASK),
|
||||||
dfi_regs + DDRMON_CTRL);
|
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),
|
writel_relaxed(HIWORD_UPDATE(DDRMON_CTRL_LPDDR4, DDRMON_CTRL_DDR_TYPE_MASK),
|
||||||
dfi_regs + DDRMON_CTRL);
|
dfi_regs + DDRMON_CTRL);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
/* enable count, use software mode */
|
/* enable count, use software mode */
|
||||||
writel_relaxed(HIWORD_UPDATE(DDRMON_CTRL_SOFTWARE_EN, DDRMON_CTRL_SOFTWARE_EN),
|
writel_relaxed(HIWORD_UPDATE(DDRMON_CTRL_SOFTWARE_EN, DDRMON_CTRL_SOFTWARE_EN),
|
||||||
|
Reference in New Issue
Block a user