luckfox-pico-sdk/sysdrv/source/uboot/u-boot/drivers/video/drm/rockchip_crtc.h
luckfox-eng29 8f34c2760d project:build.sh: Added fastboot support; custom modifications to U-Boot and kernel implemented using patches.
project:cfg:BoardConfig_IPC: Added fastboot BoardConfig file and firmware post-scripts, distinguishing between
the BoardConfigs for Luckfox Pico Pro and Luckfox Pico Max. project:app: Added fastboot_client and rk_smart_door
for quick boot applications; updated rkipc app to adapt to the latest media library. media:samples: Added more
usage examples. media:rockit: Fixed bugs; removed support for retrieving data frames from VPSS. media:isp:
Updated rkaiq library and related tools to support connection to RKISP_Tuner. sysdrv:Makefile: Added support for
compiling drv_ko on Luckfox Pico Ultra W using Ubuntu; added support for custom root filesystem.
sysdrv:tools:board: Updated Buildroot optional mirror sources, updated some software versions, and stored device
tree files and configuration files that undergo multiple modifications for U-Boot and kernel separately.
sysdrv:source:mcu: Used RISC-V MCU SDK with RT-Thread system, mainly for initializing camera AE during quick
boot. sysdrv:source:uboot: Added support for fastboot; added high baud rate DDR bin for serial firmware upgrades.
sysdrv:source:kernel: Upgraded to version 5.10.160; increased NPU frequency for RV1106G3; added support for
fastboot.

Signed-off-by: luckfox-eng29 <eng29@luckfox.com>
2024-10-14 09:47:04 +08:00

82 lines
2.5 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;
u8 dclk_div;
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 rk3576_vop;
extern const struct vop2_data rk3576_vop_lit;
extern const struct vop2_data rk3588_vop;
#endif