]> asedeno.scripts.mit.edu Git - linux.git/commitdiff
drm/amd/display: Implement backlight_ops.get_brightness
authorDavid Francis <David.Francis@amd.com>
Thu, 19 Jul 2018 15:25:05 +0000 (11:25 -0400)
committerAlex Deucher <alexander.deucher@amd.com>
Mon, 6 Aug 2018 19:35:24 +0000 (14:35 -0500)
[Why]
This hook that is supposed to read the actual backlight value
is used in a few places throughout the kernel to setup or force
update on backlight

[How]
Create a dc function that calls the existing abm function, and
call that function from amdgpu

Signed-off-by: David Francis <David.Francis@amd.com>
Reviewed-by: Harry Wentland <Harry.Wentland@amd.com>
Acked-by: Bhawanpreet Lakha <Bhawanpreet.Lakha@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
drivers/gpu/drm/amd/display/dc/core/dc_link.c
drivers/gpu/drm/amd/display/dc/dc_link.h

index c1631d61336e1272dcd45d4f6a3f997b581d3375..dcae658fbc50ffbdb2de9f3277819ed228ede002 100644 (file)
@@ -1320,7 +1320,12 @@ static int amdgpu_dm_backlight_update_status(struct backlight_device *bd)
 
 static int amdgpu_dm_backlight_get_brightness(struct backlight_device *bd)
 {
-       return bd->props.brightness;
+       struct amdgpu_display_manager *dm = bl_get_data(bd);
+       int ret = dc_link_get_backlight_level(dm->backlight_link);
+
+       if (ret == DC_ERROR_UNEXPECTED)
+               return bd->props.brightness;
+       return ret;
 }
 
 static const struct backlight_ops amdgpu_dm_backlight_ops = {
index ce65b4d5062ecd8fc613b5505b1b361bf01379c1..9a6448e2089c5438719a76c24bfe2e724cbc065e 100644 (file)
@@ -2026,6 +2026,15 @@ enum dc_status dc_link_validate_mode_timing(
        return DC_OK;
 }
 
+int dc_link_get_backlight_level(const struct dc_link *link)
+{
+       struct abm *abm = link->ctx->dc->res_pool->abm;
+
+       if (abm == NULL || abm->funcs->get_current_backlight_8_bit == NULL)
+               return DC_ERROR_UNEXPECTED;
+
+       return (int) abm->funcs->get_current_backlight_8_bit(abm);
+}
 
 bool dc_link_set_backlight_level(const struct dc_link *link, uint32_t level,
                uint32_t frame_ramp, const struct dc_stream_state *stream)
index 070a56926308ac4d314792a39fb3642371301e82..22f4ddd219d1d5d7dfbf976ff3f83f021fd9560f 100644 (file)
@@ -141,6 +141,8 @@ static inline struct dc_link *dc_get_link_at_index(struct dc *dc, uint32_t link_
 bool dc_link_set_backlight_level(const struct dc_link *dc_link, uint32_t level,
                uint32_t frame_ramp, const struct dc_stream_state *stream);
 
+int dc_link_get_backlight_level(const struct dc_link *dc_link);
+
 bool dc_link_set_abm_disable(const struct dc_link *dc_link);
 
 bool dc_link_set_psr_enable(const struct dc_link *dc_link, bool enable, bool wait);