1. 17 1月, 2020 4 次提交
  2. 10 1月, 2020 1 次提交
    • D
      drm/amd/display: MST DSC compute fair share · 8c20a1ed
      David Francis 提交于
      If there is limited link bandwidth on a MST network,
      it must be divided fairly between the streams on that network
      
      Implement an algorithm to determine the correct DSC config
      for each stream
      
      The algorithm:
      This
           [                   ]          ( )
      represents the range of bandwidths possible for a given stream.
      The [] area represents the range of DSC configs, and the ()
      represents no DSC. The bandwidth used increases from left to right.
      
      First, try disabling DSC on all streams
           [                  ]          (|)
           [                     ]            (|)
      Check this against the bandwidth limits of the link and each branch
      (including each endpoint). If it passes, the job is done
      
      Second, try maximum DSC compression on all streams
      that support DSC
           [|         ]        ( )
           [|                ]         ( )
      If this does not pass, then enabling this combination of streams
      is impossible
      
      Otherwise, divide the remaining bandwidth evenly amongst the streams
           [        |  ]         ( )
           [        |      ]        ( )
      
      If one or more of the streams reach minimum compression, evenly
      divide the reamining bandwidth amongst the remaining streams
           [    |] ( )
           [       |]   ( )
           [                 |   ]               ( )
           [                 |      ]                  ( )
      
      If all streams can reach minimum compression, disable compression
      greedily
           [      |]  ( )
           [        |]    ( )
           [                 ]                                (|)
      
      Perform this algorithm on each full update, on each MST link
      with at least one DSC stream on it
      
      After the configs are computed, call
      dcn20_add_dsc_to_stream_resource on each stream with DSC enabled.
      It is only after all streams are created that we can know which
      of them will need DSC.
      
      Do all of this at the end of amdgpu atomic check.  If it fails,
      fail check; This combination of timings cannot be supported.
      
      v2: Use drm_dp_mst_atomic_check to validate bw for certain dsc
      configurations
      
      v3: Use dc_dsc_policy structure to get min and max bpp rate
      for DSC configuration
      Acked-by: NLyude Paul <lyude@redhat.com>
      Reviewed-by: NWenjing Liu <Wenjing.Liu@amd.com>
      Signed-off-by: NDavid Francis <David.Francis@amd.com>
      Signed-off-by: NMikita Lipski <mikita.lipski@amd.com>
      Signed-off-by: NAlex Deucher <alexander.deucher@amd.com>
      8c20a1ed
  3. 08 1月, 2020 1 次提交
    • X
      drm/amd/display: fix kernel_fpu_begin/_end() warnings · c103c5a3
      Xiaojie Yuan 提交于
      kernel_fpu_begin/_end() are already called inside dcn20_resource_construct,
      and calling kernel_fpu_begin/_end() recursively triggers WARN_ON() when
      CONFIG_X86_DEBUG_FPU is enabled.
      
      [  107.060434] WARNING: CPU: 6 PID: 1370 at arch/x86/kernel/fpu/core.c:90 kernel_fpu_begin+0xbd/0xe0
      <snip>
      [  107.268197] Call Trace:
      [  107.270751]  dcn20_patch_bounding_box+0x17/0x100 [amdgpu]
      [  107.276204]  init_soc_bounding_box+0x1b3/0x5f0 [amdgpu]
      [  107.281536]  ? _cond_resched+0x19/0x30
      [  107.285307]  dcn20_resource_construct+0x3a9/0xa90 [amdgpu]
      [  107.290957]  ? dcn20_resource_construct+0x3a9/0xa90 [amdgpu]
      [  107.296621]  ? __alloc_pages_nodemask+0x16a/0x330
      [  107.301476]  ? _cond_resched+0x19/0x30
      [  107.305284]  ? kmem_cache_alloc_trace+0x197/0x230
      [  107.310063]  ? _cond_resched+0x19/0x30
      [  107.313783]  ? kmem_cache_alloc_trace+0x197/0x230
      [  107.318691]  dcn20_create_resource_pool+0x42/0x70 [amdgpu]
      [  107.324315]  dc_create_resource_pool+0x12d/0x170 [amdgpu]
      [  107.329851]  dc_create+0x1b8/0x6a0 [amdgpu]
      [  107.334013]  ? kmem_cache_alloc_trace+0x1e2/0x230
      [  107.338832]  amdgpu_dm_init+0x13e/0x1c0 [amdgpu]
      <snip>
      Signed-off-by: NXiaojie Yuan <xiaojie.yuan@amd.com>
      Reviewed-by: NHarry Wentland <harry.wentland@amd.com>
      Signed-off-by: NAlex Deucher <alexander.deucher@amd.com>
      c103c5a3
  4. 19 12月, 2019 5 次提交
  5. 11 12月, 2019 1 次提交
  6. 06 12月, 2019 4 次提交
  7. 04 12月, 2019 4 次提交
  8. 03 12月, 2019 3 次提交
  9. 19 11月, 2019 3 次提交
  10. 14 11月, 2019 4 次提交
  11. 07 11月, 2019 2 次提交
  12. 30 10月, 2019 1 次提交
  13. 26 10月, 2019 7 次提交