]> www.infradead.org Git - users/hch/dma-mapping.git/commitdiff
drm/amd/display: add i2c speed arbitration for dc_i2c and hdcp_i2c
authorCharlene Liu <Charlene.Liu@amd.com>
Mon, 21 Sep 2020 18:24:09 +0000 (14:24 -0400)
committerAlex Deucher <alexander.deucher@amd.com>
Tue, 24 Nov 2020 17:07:07 +0000 (12:07 -0500)
[why]
HDCP 1.4 failed on SL8800 SW w/a test driver use.

[how]
slower down the HW i2c speed when used by HW i2c.
this request: each acquired_i2c_engine setup the i2c speed needed.
and set the I2c engine for HDCP use at release_engine.

this covers SW using HW I2c engine and HDCP using HW I2c engine. for
dmcu using HW I2c engine, needs add similar logic in dmcufw.

Signed-off-by: Charlene Liu <Charlene.Liu@amd.com>
Reviewed-by: Chris Park <Chris.Park@amd.com>
Acked-by: Rodrigo Siqueira <Rodrigo.Siqueira@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
drivers/gpu/drm/amd/display/dc/dcn301/dcn301_resource.c
drivers/gpu/drm/amd/display/dc/dcn302/dcn302_resource.c

index 0006d805b3b269221a7ec28afef7bc6e48a8c05f..d15220a4eeb68108ac32825659cdefa3a3857f6e 100644 (file)
@@ -1759,6 +1759,7 @@ static bool dcn301_resource_construct(
        pool->base.mpcc_count = pool->base.res_cap->num_timing_generator;
        dc->caps.max_downscale_ratio = 600;
        dc->caps.i2c_speed_in_khz = 100;
+       dc->caps.i2c_speed_in_khz_hdcp = 5; /*1.4 w/a enabled by default*/
        dc->caps.max_cursor_size = 256;
        dc->caps.dmdata_alloc_size = 2048;
        dc->caps.max_slave_planes = 1;
index 08ef1428550b0b6e68aeb0531f76decce0c85a92..376ccdb85e30c4cfd6dda84539627ac20dba50b4 100644 (file)
@@ -1307,6 +1307,7 @@ static bool dcn302_resource_construct(
        pool->mpcc_count = pool->res_cap->num_timing_generator;
        dc->caps.max_downscale_ratio = 600;
        dc->caps.i2c_speed_in_khz = 100;
+       dc->caps.i2c_speed_in_khz_hdcp = 5; /*1.4 w/a applied by derfault*/
        dc->caps.max_cursor_size = 256;
        dc->caps.dmdata_alloc_size = 2048;