diff options
Diffstat (limited to 'meta-amdfalconx86/recipes-kernel/linux/linux-yocto/0687-drm-amdgpu-add-new-cgs-interface-to-get-display-info.patch')
-rw-r--r-- | meta-amdfalconx86/recipes-kernel/linux/linux-yocto/0687-drm-amdgpu-add-new-cgs-interface-to-get-display-info.patch | 133 |
1 files changed, 133 insertions, 0 deletions
diff --git a/meta-amdfalconx86/recipes-kernel/linux/linux-yocto/0687-drm-amdgpu-add-new-cgs-interface-to-get-display-info.patch b/meta-amdfalconx86/recipes-kernel/linux/linux-yocto/0687-drm-amdgpu-add-new-cgs-interface-to-get-display-info.patch new file mode 100644 index 00000000..c4c578a8 --- /dev/null +++ b/meta-amdfalconx86/recipes-kernel/linux/linux-yocto/0687-drm-amdgpu-add-new-cgs-interface-to-get-display-info.patch @@ -0,0 +1,133 @@ +From 2d31f806d5fdbaee0cfaace207ee97d03bd901e2 Mon Sep 17 00:00:00 2001 +From: Rex Zhu <Rex.Zhu@amd.com> +Date: Thu, 17 Sep 2015 16:34:14 +0800 +Subject: [PATCH 0687/1050] drm/amdgpu: add new cgs interface to get display + info (v2) + +Add new CGS interfaces to query display info across modules. +This is nedded by the powerplay module for synchronizing with +the display module. + +v2: (agd): fold in refresh rate fix, rebase + +Signed-off-by: Rex Zhu <Rex.Zhu@amd.com> +Reviewed-by: Jammy Zhou <Jammy.Zhou@amd.com> +Reviewed-by: Alex Deucher <alexander.deucher@amd.com> +--- + drivers/gpu/drm/amd/amdgpu/amdgpu_cgs.c | 40 ++++++++++++++++++++++++++++++++ + drivers/gpu/drm/amd/include/cgs_common.h | 20 ++++++++++++++++ + 2 files changed, 60 insertions(+) + +diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_cgs.c b/drivers/gpu/drm/amd/amdgpu/amdgpu_cgs.c +index 19f46d0..8f758ea 100644 +--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_cgs.c ++++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_cgs.c +@@ -758,6 +758,45 @@ static int amdgpu_cgs_query_system_info(void *cgs_device, + return 0; + } + ++static int amdgpu_cgs_get_active_displays_info(void *cgs_device, ++ struct cgs_display_info *info) ++{ ++ CGS_FUNC_ADEV; ++ struct amdgpu_crtc *amdgpu_crtc; ++ struct drm_device *ddev = adev->ddev; ++ struct drm_crtc *crtc; ++ uint32_t line_time_us, vblank_lines; ++ ++ if (info == NULL) ++ return -EINVAL; ++ ++ if (adev->mode_info.num_crtc && adev->mode_info.mode_config_initialized) { ++ list_for_each_entry(crtc, ++ &ddev->mode_config.crtc_list, head) { ++ amdgpu_crtc = to_amdgpu_crtc(crtc); ++ if (crtc->enabled) { ++ info->active_display_mask |= (1 << amdgpu_crtc->crtc_id); ++ info->display_count++; ++ } ++ if (info->mode_info != NULL && ++ crtc->enabled && amdgpu_crtc->enabled && ++ amdgpu_crtc->hw_mode.clock) { ++ line_time_us = (amdgpu_crtc->hw_mode.crtc_htotal * 1000) / ++ amdgpu_crtc->hw_mode.clock; ++ vblank_lines = amdgpu_crtc->hw_mode.crtc_vblank_end - ++ amdgpu_crtc->hw_mode.crtc_vdisplay + ++ (amdgpu_crtc->v_border * 2); ++ info->mode_info->vblank_time_us = vblank_lines * line_time_us; ++ info->mode_info->refresh_rate = drm_mode_vrefresh(&amdgpu_crtc->hw_mode); ++ info->mode_info->ref_clock = adev->clock.spll.reference_freq; ++ info->mode_info++; ++ } ++ } ++ } ++ ++ return 0; ++} ++ + /** \brief evaluate acpi namespace object, handle or pathname must be valid + * \param cgs_device + * \param info input/output arguments for the control method +@@ -1006,6 +1045,7 @@ static const struct cgs_ops amdgpu_cgs_ops = { + amdgpu_cgs_get_firmware_info, + amdgpu_cgs_set_powergating_state, + amdgpu_cgs_set_clockgating_state, ++ amdgpu_cgs_get_active_displays_info, + amdgpu_cgs_call_acpi_method, + amdgpu_cgs_query_system_info, + }; +diff --git a/drivers/gpu/drm/amd/include/cgs_common.h b/drivers/gpu/drm/amd/include/cgs_common.h +index 5ea8db0..2bbffd1 100644 +--- a/drivers/gpu/drm/amd/include/cgs_common.h ++++ b/drivers/gpu/drm/amd/include/cgs_common.h +@@ -142,6 +142,18 @@ struct cgs_firmware_info { + void *kptr; + }; + ++struct cgs_mode_info { ++ uint32_t refresh_rate; ++ uint32_t ref_clock; ++ uint32_t vblank_time_us; ++}; ++ ++struct cgs_display_info { ++ uint32_t display_count; ++ uint32_t active_display_mask; ++ struct cgs_mode_info *mode_info; ++}; ++ + typedef unsigned long cgs_handle_t; + + #define CGS_ACPI_METHOD_ATCS 0x53435441 +@@ -541,6 +553,10 @@ typedef int(*cgs_set_clockgating_state)(void *cgs_device, + enum amd_ip_block_type block_type, + enum amd_clockgating_state state); + ++typedef int(*cgs_get_active_displays_info)( ++ void *cgs_device, ++ struct cgs_display_info *info); ++ + typedef int (*cgs_call_acpi_method)(void *cgs_device, + uint32_t acpi_method, + uint32_t acpi_function, +@@ -592,6 +608,8 @@ struct cgs_ops { + /* cg pg interface*/ + cgs_set_powergating_state set_powergating_state; + cgs_set_clockgating_state set_clockgating_state; ++ /* display manager */ ++ cgs_get_active_displays_info get_active_displays_info; + /* ACPI */ + cgs_call_acpi_method call_acpi_method; + /* get system info */ +@@ -682,6 +700,8 @@ struct cgs_device + CGS_CALL(set_powergating_state, dev, block_type, state) + #define cgs_set_clockgating_state(dev, block_type, state) \ + CGS_CALL(set_clockgating_state, dev, block_type, state) ++#define cgs_get_active_displays_info(dev, info) \ ++ CGS_CALL(get_active_displays_info, dev, info) + #define cgs_call_acpi_method(dev, acpi_method, acpi_function, pintput, poutput, output_count, input_size, output_size) \ + CGS_CALL(call_acpi_method, dev, acpi_method, acpi_function, pintput, poutput, output_count, input_size, output_size) + #define cgs_query_system_info(dev, sys_info) \ +-- +1.9.1 + |