mirror of
https://github.com/hardkernel/linux.git
synced 2026-06-10 21:07:02 +09:00
drm/rockchip: add rk3036_alpha_support
Change-Id: Ife16fb36502e70dfffc80d31d7f33235d63366eb Signed-off-by: Jacob Chen <jacob2.chen@rock-chips.com>
This commit is contained in:
@@ -811,8 +811,11 @@ static void vop_plane_atomic_update(struct drm_plane *plane,
|
||||
SRC_ALPHA_CAL_M0(ALPHA_NO_SATURATION) |
|
||||
SRC_FACTOR_M0(ALPHA_ONE);
|
||||
VOP_WIN_SET(vop, win, src_alpha_ctl, val);
|
||||
VOP_WIN_SET(vop, win, alpha_mode, 1);
|
||||
VOP_WIN_SET(vop, win, alpha_en, 1);
|
||||
} else {
|
||||
VOP_WIN_SET(vop, win, src_alpha_ctl, SRC_ALPHA_EN(0));
|
||||
VOP_WIN_SET(vop, win, alpha_en, 0);
|
||||
}
|
||||
|
||||
VOP_WIN_SET(vop, win, enable, 1);
|
||||
|
||||
@@ -126,6 +126,8 @@ struct vop_win_phy {
|
||||
|
||||
struct vop_reg dst_alpha_ctl;
|
||||
struct vop_reg src_alpha_ctl;
|
||||
struct vop_reg alpha_mode;
|
||||
struct vop_reg alpha_en;
|
||||
};
|
||||
|
||||
struct vop_win_data {
|
||||
|
||||
@@ -436,6 +436,8 @@ static const struct vop_win_phy rk3036_win0_data = {
|
||||
.uv_mst = VOP_REG(RK3036_WIN0_CBR_MST, 0xffffffff, 0),
|
||||
.yrgb_vir = VOP_REG(RK3036_WIN0_VIR, 0xffff, 0),
|
||||
.uv_vir = VOP_REG(RK3036_WIN0_VIR, 0x1fff, 16),
|
||||
.alpha_mode = VOP_REG(RK3036_DSP_CTRL0, 0x1, 18),
|
||||
.alpha_en = VOP_REG(RK3036_ALPHA_CTRL, 0x1, 0)
|
||||
};
|
||||
|
||||
static const struct vop_win_phy rk3036_win1_data = {
|
||||
@@ -449,6 +451,8 @@ static const struct vop_win_phy rk3036_win1_data = {
|
||||
.dsp_st = VOP_REG(RK3036_WIN1_DSP_ST, 0x1fff1fff, 0),
|
||||
.yrgb_mst = VOP_REG(RK3036_WIN1_MST, 0xffffffff, 0),
|
||||
.yrgb_vir = VOP_REG(RK3036_WIN1_VIR, 0xffff, 0),
|
||||
.alpha_mode = VOP_REG(RK3036_DSP_CTRL0, 0x1, 19),
|
||||
.alpha_en = VOP_REG(RK3036_ALPHA_CTRL, 0x1, 1)
|
||||
};
|
||||
|
||||
static const struct vop_win_data rk3036_vop_win_data[] = {
|
||||
|
||||
Reference in New Issue
Block a user