hc
2024-12-19 9370bb92b2d16684ee45cf24e879c93c509162da
kernel/drivers/gpu/drm/amd/display/dc/dml/display_mode_lib.h
....@@ -25,22 +25,68 @@
2525 #ifndef __DISPLAY_MODE_LIB_H__
2626 #define __DISPLAY_MODE_LIB_H__
2727
28
-
29
-#include "dml_common_defs.h"
30
-#include "dml1_display_rq_dlg_calc.h"
28
+#include "dm_services.h"
29
+#include "dc_features.h"
30
+#include "display_mode_structs.h"
31
+#include "display_mode_enums.h"
32
+#include "display_mode_vba.h"
3133
3234 enum dml_project {
3335 DML_PROJECT_UNDEFINED,
34
- DML_PROJECT_RAVEN1
36
+ DML_PROJECT_RAVEN1,
37
+ DML_PROJECT_NAVI10,
38
+ DML_PROJECT_NAVI10v2,
39
+ DML_PROJECT_DCN21,
40
+#ifdef CONFIG_DRM_AMD_DC_DCN3_0
41
+ DML_PROJECT_DCN30,
42
+#endif
43
+};
44
+
45
+struct display_mode_lib;
46
+
47
+struct dml_funcs {
48
+ void (*rq_dlg_get_dlg_reg)(
49
+ struct display_mode_lib *mode_lib,
50
+ display_dlg_regs_st *dlg_regs,
51
+ display_ttu_regs_st *ttu_regs,
52
+ const display_e2e_pipe_params_st *e2e_pipe_param,
53
+ const unsigned int num_pipes,
54
+ const unsigned int pipe_idx,
55
+ const bool cstate_en,
56
+ const bool pstate_en,
57
+ const bool vm_en,
58
+ const bool ignore_viewport_pos,
59
+ const bool immediate_flip_support);
60
+ void (*rq_dlg_get_rq_reg)(
61
+ struct display_mode_lib *mode_lib,
62
+ display_rq_regs_st *rq_regs,
63
+ const display_pipe_params_st *pipe_param);
64
+ void (*recalculate)(struct display_mode_lib *mode_lib);
65
+ void (*validate)(struct display_mode_lib *mode_lib);
3566 };
3667
3768 struct display_mode_lib {
3869 struct _vcs_dpi_ip_params_st ip;
3970 struct _vcs_dpi_soc_bounding_box_st soc;
4071 enum dml_project project;
72
+ struct vba_vars_st vba;
4173 struct dal_logger *logger;
74
+ struct dml_funcs funcs;
4275 };
4376
44
-void dml_init_instance(struct display_mode_lib *lib, enum dml_project project);
77
+void dml_init_instance(struct display_mode_lib *lib,
78
+ const struct _vcs_dpi_soc_bounding_box_st *soc_bb,
79
+ const struct _vcs_dpi_ip_params_st *ip_params,
80
+ enum dml_project project);
4581
82
+const char *dml_get_status_message(enum dm_validation_status status);
83
+
84
+#if defined(CONFIG_DRM_AMD_DC_DCN3_0)
85
+void dml_log_pipe_params(
86
+ struct display_mode_lib *mode_lib,
87
+ display_e2e_pipe_params_st *pipes,
88
+ int pipe_cnt);
89
+
90
+void dml_log_mode_support_params(struct display_mode_lib *mode_lib);
91
+#endif // CONFIG_DRM_AMD_DC_DCN3_0
4692 #endif