Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

drm/rockchip: lvds: switch to FIELD_PREP_WM16 macro

The era of hand-rolled HIWORD_UPDATE macros is over, at least for those
drivers that use constant masks.

Remove rockchip_lvds.h's own HIWORD_UPDATE macro, and replace all
instances of it with hw_bitfield.h's FIELD_PREP_WM16 macro, which gives
us more error checking.

For the slightly-less-trivial case of the 2-bit width instance, the
results were checked during development to match all possible input
values (0 to 3, inclusive).

Signed-off-by: Nicolas Frattaroli <nicolas.frattaroli@collabora.com>
Reviewed-by: Heiko Stuebner <heiko@sntech.de>
Signed-off-by: Yury Norov (NVIDIA) <yury.norov@gmail.com>

authored by

Nicolas Frattaroli and committed by
Yury Norov
dcdcfd83 7d5f75a9

+11 -10
+11 -10
drivers/gpu/drm/rockchip/rockchip_lvds.h
··· 9 9 #ifndef _ROCKCHIP_LVDS_ 10 10 #define _ROCKCHIP_LVDS_ 11 11 12 + #include <linux/bits.h> 13 + #include <linux/hw_bitfield.h> 14 + 12 15 #define RK3288_LVDS_CH0_REG0 0x00 13 16 #define RK3288_LVDS_CH0_REG0_LVDS_EN BIT(7) 14 17 #define RK3288_LVDS_CH0_REG0_TTL_EN BIT(6) ··· 109 106 #define LVDS_VESA_18 2 110 107 #define LVDS_JEIDA_18 3 111 108 112 - #define HIWORD_UPDATE(v, h, l) ((GENMASK(h, l) << 16) | ((v) << (l))) 113 - 114 109 #define PX30_LVDS_GRF_PD_VO_CON0 0x434 115 - #define PX30_LVDS_TIE_CLKS(val) HIWORD_UPDATE(val, 8, 8) 116 - #define PX30_LVDS_INVERT_CLKS(val) HIWORD_UPDATE(val, 9, 9) 117 - #define PX30_LVDS_INVERT_DCLK(val) HIWORD_UPDATE(val, 5, 5) 110 + #define PX30_LVDS_TIE_CLKS(val) FIELD_PREP_WM16(BIT(8), (val)) 111 + #define PX30_LVDS_INVERT_CLKS(val) FIELD_PREP_WM16(BIT(9), (val)) 112 + #define PX30_LVDS_INVERT_DCLK(val) FIELD_PREP_WM16(BIT(5), (val)) 118 113 119 114 #define PX30_LVDS_GRF_PD_VO_CON1 0x438 120 - #define PX30_LVDS_FORMAT(val) HIWORD_UPDATE(val, 14, 13) 121 - #define PX30_LVDS_MODE_EN(val) HIWORD_UPDATE(val, 12, 12) 122 - #define PX30_LVDS_MSBSEL(val) HIWORD_UPDATE(val, 11, 11) 123 - #define PX30_LVDS_P2S_EN(val) HIWORD_UPDATE(val, 6, 6) 124 - #define PX30_LVDS_VOP_SEL(val) HIWORD_UPDATE(val, 1, 1) 115 + #define PX30_LVDS_FORMAT(val) FIELD_PREP_WM16(GENMASK(14, 13), (val)) 116 + #define PX30_LVDS_MODE_EN(val) FIELD_PREP_WM16(BIT(12), (val)) 117 + #define PX30_LVDS_MSBSEL(val) FIELD_PREP_WM16(BIT(11), (val)) 118 + #define PX30_LVDS_P2S_EN(val) FIELD_PREP_WM16(BIT(6), (val)) 119 + #define PX30_LVDS_VOP_SEL(val) FIELD_PREP_WM16(BIT(1), (val)) 125 120 126 121 #endif /* _ROCKCHIP_LVDS_ */