Skip to content

Commit 6e46998

Browse files
AngeloGioacchino Del RegnoChun-Kuang Hu
authored andcommitted
drm/mediatek: gamma: Use bitfield macros
Make the code more robust and improve readability by using bitfield macros instead of open coding bit operations. Reviewed-by: Jason-JH.Lin <[email protected]> Reviewed-by: Alexandre Mergnat <[email protected]> Signed-off-by: AngeloGioacchino Del Regno <[email protected]> Reviewed-by: CK Hu <[email protected]> Link: https://patchwork.kernel.org/project/dri-devel/patch/[email protected]/ Signed-off-by: Chun-Kuang Hu <[email protected]>
1 parent 0d4caaa commit 6e46998

File tree

1 file changed

+19
-9
lines changed

1 file changed

+19
-9
lines changed

drivers/gpu/drm/mediatek/mtk_disp_gamma.c

Lines changed: 19 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -3,6 +3,7 @@
33
* Copyright (c) 2021 MediaTek Inc.
44
*/
55

6+
#include <linux/bitfield.h>
67
#include <linux/clk.h>
78
#include <linux/component.h>
89
#include <linux/module.h>
@@ -21,8 +22,14 @@
2122
#define GAMMA_LUT_EN BIT(1)
2223
#define GAMMA_DITHERING BIT(2)
2324
#define DISP_GAMMA_SIZE 0x0030
25+
#define DISP_GAMMA_SIZE_HSIZE GENMASK(28, 16)
26+
#define DISP_GAMMA_SIZE_VSIZE GENMASK(12, 0)
2427
#define DISP_GAMMA_LUT 0x0700
2528

29+
#define DISP_GAMMA_LUT_10BIT_R GENMASK(29, 20)
30+
#define DISP_GAMMA_LUT_10BIT_G GENMASK(19, 10)
31+
#define DISP_GAMMA_LUT_10BIT_B GENMASK(9, 0)
32+
2633
struct mtk_disp_gamma_data {
2734
bool has_dither;
2835
bool lut_diff;
@@ -97,9 +104,9 @@ void mtk_gamma_set_common(struct device *dev, void __iomem *regs, struct drm_crt
97104
hwlut.blue = drm_color_lut_extract(lut[i].blue, 10);
98105

99106
if (!lut_diff || (i % 2 == 0)) {
100-
word = (hwlut.red << 20) +
101-
(hwlut.green << 10) +
102-
hwlut.red;
107+
word = FIELD_PREP(DISP_GAMMA_LUT_10BIT_R, hwlut.red);
108+
word |= FIELD_PREP(DISP_GAMMA_LUT_10BIT_G, hwlut.green);
109+
word |= FIELD_PREP(DISP_GAMMA_LUT_10BIT_B, hwlut.blue);
103110
} else {
104111
diff.red = lut[i].red - lut[i - 1].red;
105112
diff.red = drm_color_lut_extract(diff.red, 10);
@@ -110,17 +117,17 @@ void mtk_gamma_set_common(struct device *dev, void __iomem *regs, struct drm_crt
110117
diff.blue = lut[i].blue - lut[i - 1].blue;
111118
diff.blue = drm_color_lut_extract(diff.blue, 10);
112119

113-
word = (diff.blue << 20) +
114-
(diff.green << 10) +
115-
diff.red;
120+
word = FIELD_PREP(DISP_GAMMA_LUT_10BIT_R, diff.red);
121+
word |= FIELD_PREP(DISP_GAMMA_LUT_10BIT_G, diff.green);
122+
word |= FIELD_PREP(DISP_GAMMA_LUT_10BIT_B, diff.blue);
116123
}
117124
writel(word, lut_base + i * 4);
118125
}
119126

120127
cfg_val = readl(regs + DISP_GAMMA_CFG);
121128

122129
/* Enable the gamma table */
123-
cfg_val |= GAMMA_LUT_EN;
130+
cfg_val |= FIELD_PREP(GAMMA_LUT_EN, 1);
124131

125132
writel(cfg_val, regs + DISP_GAMMA_CFG);
126133
}
@@ -137,9 +144,12 @@ void mtk_gamma_config(struct device *dev, unsigned int w,
137144
unsigned int bpc, struct cmdq_pkt *cmdq_pkt)
138145
{
139146
struct mtk_disp_gamma *gamma = dev_get_drvdata(dev);
147+
u32 sz;
148+
149+
sz = FIELD_PREP(DISP_GAMMA_SIZE_HSIZE, w);
150+
sz |= FIELD_PREP(DISP_GAMMA_SIZE_VSIZE, h);
140151

141-
mtk_ddp_write(cmdq_pkt, h << 16 | w, &gamma->cmdq_reg, gamma->regs,
142-
DISP_GAMMA_SIZE);
152+
mtk_ddp_write(cmdq_pkt, sz, &gamma->cmdq_reg, gamma->regs, DISP_GAMMA_SIZE);
143153
if (gamma->data && gamma->data->has_dither)
144154
mtk_dither_set_common(gamma->regs, &gamma->cmdq_reg, bpc,
145155
DISP_GAMMA_CFG, GAMMA_DITHERING, cmdq_pkt);

0 commit comments

Comments
 (0)