107 lines
2.7 KiB
C
107 lines
2.7 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Copyright (c) 2019 MediaTek Inc.
|
|
*/
|
|
|
|
#ifndef __LAYER_STRATEGY_EX__
|
|
#define __LAYER_STRATEGY_EX__
|
|
|
|
#include "layering_rule_base.h"
|
|
|
|
#ifdef CONFIG_MTK_ROUND_CORNER_SUPPORT
|
|
#define MAX_PHY_OVL_CNT (12-2)
|
|
#else
|
|
#define MAX_PHY_OVL_CNT (12)
|
|
#endif
|
|
|
|
/* #define HAS_LARB_HRT */
|
|
#ifndef CONFIG_MTK_ROUND_CORNER_SUPPORT
|
|
#define HRT_AEE_LAYER_MASK 0xFFFFFFDF
|
|
#else
|
|
#define HRT_AEE_LAYER_MASK 0xFFFFFFEF
|
|
#endif
|
|
|
|
enum DISP_DEBUG_LEVEL {
|
|
DISP_DEBUG_LEVEL_CRITICAL = 0,
|
|
DISP_DEBUG_LEVEL_ERR,
|
|
DISP_DEBUG_LEVEL_WARN,
|
|
DISP_DEBUG_LEVEL_DEBUG,
|
|
DISP_DEBUG_LEVEL_INFO,
|
|
};
|
|
|
|
enum HRT_LEVEL {
|
|
HRT_LEVEL_LEVEL0 = 0, /* OPP3 */
|
|
HRT_LEVEL_LEVEL1, /* OPP2 */
|
|
HRT_LEVEL_LEVEL2, /* OPP1 */
|
|
HRT_LEVEL_LEVEL3, /* OPP0 */
|
|
HRT_LEVEL_NUM,
|
|
};
|
|
|
|
enum HRT_TB_TYPE {
|
|
HRT_TB_TYPE_GENERAL = 0,
|
|
HRT_TB_TYPE_RPO_L0,
|
|
HRT_TB_TYPE_RPO_DIM_L0,
|
|
HRT_TB_TYPE_RPO_BOTH,
|
|
HRT_TB_NUM,
|
|
};
|
|
|
|
enum {
|
|
HRT_LEVEL_DEFAULT = HRT_LEVEL_NUM + 1,
|
|
};
|
|
|
|
enum HRT_BOUND_TYPE {
|
|
HRT_BOUND_TYPE_LP4 = 0, /* LP4-2ch */
|
|
HRT_BOUND_TYPE_LP4_PLUS, /* LP4-FHD+(>18:9)*/
|
|
HRT_BOUND_TYPE_LP3, /* LP3-1ch */
|
|
HRT_BOUND_TYPE_LP3_PLUS, /* LP3-FHD+(>18:9)*/
|
|
HRT_BOUND_TYPE_LP4_1CH, /* LP4-1ch */
|
|
HRT_BOUND_TYPE_LP4_HYBRID, /* LP4-2ch special */
|
|
HRT_BOUND_TYPE_LP3_HD,
|
|
HRT_BOUND_TYPE_LP4_HD,
|
|
HRT_BOUND_TYPE_LP3_HD_PLUS, /* LP3-HD+(>18:9)*/
|
|
HRT_BOUND_TYPE_LP4_HD_PLUS, /* LP4-HD+(>18:9)*/
|
|
HRT_BOUND_NUM,
|
|
};
|
|
|
|
enum HRT_PATH_SCENARIO {
|
|
HRT_PATH_GENERAL =
|
|
MAKE_UNIFIED_HRT_PATH_FMT(HRT_PATH_RSZ_NONE,
|
|
HRT_PATH_PIPE_SINGLE, HRT_PATH_DISP_DUAL_EXT, 1),
|
|
HRT_PATH_RPO_L0 =
|
|
MAKE_UNIFIED_HRT_PATH_FMT(HRT_PATH_RSZ_PARTIAL,
|
|
HRT_PATH_PIPE_SINGLE, HRT_PATH_DISP_SINGLE, 2),
|
|
HRT_PATH_RPO_DIM_L0 =
|
|
MAKE_UNIFIED_HRT_PATH_FMT(HRT_PATH_RSZ_PARTIAL,
|
|
HRT_PATH_PIPE_SINGLE, HRT_PATH_DISP_SINGLE, 3),
|
|
HRT_PATH_RPO_BOTH =
|
|
MAKE_UNIFIED_HRT_PATH_FMT(HRT_PATH_RSZ_PARTIAL,
|
|
HRT_PATH_PIPE_SINGLE, HRT_PATH_DISP_SINGLE, 4),
|
|
HRT_PATH_UNKNOWN = MAKE_UNIFIED_HRT_PATH_FMT(0, 0, 0, 5),
|
|
HRT_PATH_NUM = MAKE_UNIFIED_HRT_PATH_FMT(0, 0, 0, 6),
|
|
};
|
|
|
|
enum HRT_OPP_LEVEL {
|
|
HRT_OPP_LEVEL_LEVEL0 = 0, /* OPP0 */
|
|
HRT_OPP_LEVEL_LEVEL1, /* OPP1 */
|
|
HRT_OPP_LEVEL_LEVEL2, /* OPP2 */
|
|
HRT_OPP_LEVEL_NUM,
|
|
HRT_OPP_LEVEL_DEFAULT, /* DEFAULT */
|
|
};
|
|
|
|
enum HRT_DRAMC_TYPE {
|
|
HRT_DRAMC_TYPE_LP4_3733 = 0, /* LP4-3733 */
|
|
HRT_DRAMC_TYPE_LP4_3200, /* LP4-3200 */
|
|
HRT_DRAMC_TYPE_LP3, /* LP3 */
|
|
HRT_DRAMC_TYPE_NUM,
|
|
};
|
|
|
|
void layering_rule_init(void);
|
|
int layering_rule_get_mm_freq_table(enum HRT_OPP_LEVEL opp_level);
|
|
int set_emi_bound_tb(int idx, int num, int *val);
|
|
void copy_hrt_bound_table(int is_larb, int *hrt_table,
|
|
int active_config_id);
|
|
unsigned long long layering_get_frame_bw(int active_cfg_id);
|
|
unsigned int layering_rule_get_hrt_idx(void);
|
|
int layering_get_valid_hrt(int active_config_id);
|
|
#endif
|