android13/u-boot/drivers/video/drm/rockchip_crtc.h

79 lines
2.4 KiB
C

/*
* (C) Copyright 2008-2017 Fuzhou Rockchip Electronics Co., Ltd
*
* SPDX-License-Identifier: GPL-2.0+
*/
#ifndef _ROCKCHIP_CRTC_H_
#define _ROCKCHIP_CRTC_H_
#define VOP2_MAX_VP 4
struct rockchip_vp {
bool enable;
bool xmirror_en;
u8 bg_ovl_dly;
u8 primary_plane_id;
int output_type;
u32 plane_mask;
int cursor_plane;
};
struct rockchip_crtc {
const struct rockchip_crtc_funcs *funcs;
const void *data;
struct drm_display_mode active_mode;
struct rockchip_vp vps[4];
bool hdmi_hpd : 1;
bool active : 1;
bool assign_plane : 1;
bool splice_mode : 1;
u8 splice_crtc_id;
};
struct rockchip_crtc_funcs {
int (*preinit)(struct display_state *state);
int (*init)(struct display_state *state);
void (*deinit)(struct display_state *state);
int (*set_plane)(struct display_state *state);
int (*prepare)(struct display_state *state);
int (*enable)(struct display_state *state);
int (*disable)(struct display_state *state);
void (*unprepare)(struct display_state *state);
int (*fixup_dts)(struct display_state *state, void *blob);
int (*send_mcu_cmd)(struct display_state *state, u32 type, u32 value);
int (*check)(struct display_state *state);
int (*mode_valid)(struct display_state *state);
int (*mode_fixup)(struct display_state *state);
int (*plane_check)(struct display_state *state);
int (*regs_dump)(struct display_state *state);
int (*active_regs_dump)(struct display_state *state);
int (*apply_soft_te)(struct display_state *state);
};
struct vop_data;
struct vop2_data;
extern const struct rockchip_crtc_funcs rockchip_vop_funcs;
extern const struct rockchip_crtc_funcs rockchip_vop2_funcs;
extern const struct vop_data rk3036_vop;
extern const struct vop_data px30_vop_lit;
extern const struct vop_data px30_vop_big;
extern const struct vop_data rk3308_vop;
extern const struct vop_data rk1808_vop;
extern const struct vop_data rk3288_vop_big;
extern const struct vop_data rk3288_vop_lit;
extern const struct vop_data rk3368_vop;
extern const struct vop_data rk3366_vop;
extern const struct vop_data rk3399_vop_big;
extern const struct vop_data rk3399_vop_lit;
extern const struct vop_data rk322x_vop;
extern const struct vop_data rk3328_vop;
extern const struct vop_data rv1106_vop;
extern const struct vop_data rv1108_vop;
extern const struct vop_data rv1126_vop;
extern const struct vop2_data rk3528_vop;
extern const struct vop2_data rk3562_vop;
extern const struct vop2_data rk3568_vop;
extern const struct vop2_data rk3588_vop;
#endif