drivers/dma-buf/heaps/cma_heap.c                                    |    1 
 drivers/gpu/drm/amd/amdgpu/amdgpu_connectors.c                      |   10 +-
 drivers/gpu/drm/amd/amdgpu/amdgpu_device.c                          |    3 
 drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.c                             |    3 
 drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c                               |   21 
+----
 drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c                               |   11 +--
 drivers/gpu/drm/amd/amdkfd/kfd_device.c                             |   12 +--
 drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c                   |    5 -
 drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_irq.c               |    5 -
 drivers/gpu/drm/amd/display/dc/clk_mgr/dcn21/rn_clk_mgr.c           |   36 
++++++----
 drivers/gpu/drm/amd/display/dc/clk_mgr/dcn21/rn_clk_mgr_vbios_smu.c |    2 
 drivers/gpu/drm/amd/display/dc/clk_mgr/dcn301/vg_clk_mgr.c          |    9 ++
 drivers/gpu/drm/amd/display/dc/core/dc.c                            |   20 
+++++
 drivers/gpu/drm/amd/display/dc/core/dc_link_dp.c                    |    8 +-
 drivers/gpu/drm/amd/display/dc/dcn10/dcn10_hubp.c                   |   18 
-----
 drivers/gpu/drm/amd/display/dc/dcn10/dcn10_hubp.h                   |    4 -
 drivers/gpu/drm/amd/display/dc/dcn10/dcn10_mpc.c                    |   12 ---
 drivers/gpu/drm/amd/display/dc/dcn10/dcn10_mpc.h                    |    1 
 drivers/gpu/drm/amd/display/dc/dcn20/dcn20_hubp.c                   |    2 
 drivers/gpu/drm/amd/display/dc/dcn20/dcn20_hwseq.c                  |   12 ---
 drivers/gpu/drm/amd/display/dc/dcn20/dcn20_mpc.c                    |    1 
 drivers/gpu/drm/amd/display/dc/dcn20/dcn20_resource.c               |    2 
 drivers/gpu/drm/amd/display/dc/dcn30/dcn30_hubp.c                   |    2 
 drivers/gpu/drm/amd/display/dc/dcn30/dcn30_mpc.c                    |    1 
 drivers/gpu/drm/amd/display/dc/inc/hw/hubp.h                        |    2 
 drivers/gpu/drm/amd/display/dc/inc/hw/mpc.h                         |    4 -
 drivers/gpu/drm/amd/display/dmub/inc/dmub_cmd.h                     |    4 -
 drivers/gpu/drm/amd/display/modules/hdcp/hdcp1_execution.c          |    8 --
 drivers/gpu/drm/amd/display/modules/hdcp/hdcp2_execution.c          |    7 -
 drivers/gpu/drm/amd/display/modules/power/power_helpers.c           |   35 
++-------
 drivers/gpu/drm/amd/display/modules/power/power_helpers.h           |    1 
 drivers/gpu/drm/amd/pm/inc/smu_v11_0.h                              |    2 
 drivers/gpu/drm/amd/pm/swsmu/smu11/vangogh_ppt.c                    |    9 --
 drivers/gpu/drm/arm/display/komeda/komeda_dev.c                     |    1 
 drivers/gpu/drm/arm/display/komeda/komeda_kms.c                     |    4 -
 drivers/gpu/drm/arm/display/komeda/komeda_pipeline.c                |    3 
 drivers/gpu/drm/arm/display/komeda/komeda_pipeline_state.c          |    4 -
 drivers/gpu/drm/ttm/ttm_pool.c                                      |   29 
++++----
 38 files changed, 132 insertions(+), 182 deletions(-)

New commits:
commit 26cdd49cacf557bf57177242dd0062095da90814
Author: Kevin Brace <kevinbr...@gmx.com>
Date:   Sat Dec 26 18:39:56 2020 -0800

    Revert "git logMerge tag 'drm-next-2020-12-24' of"
    
    This reverts commit 6fe6635f49c993f2a2031908b5b5fd96d9992d13, reversing
    changes made to 82d8d2c0d3970526f5f607ec12d423c083d68cf9.

diff --git a/drivers/dma-buf/heaps/cma_heap.c b/drivers/dma-buf/heaps/cma_heap.c
index 3c4e34301172..5e7c3436310c 100644
--- a/drivers/dma-buf/heaps/cma_heap.c
+++ b/drivers/dma-buf/heaps/cma_heap.c
@@ -20,7 +20,6 @@
 #include <linux/module.h>
 #include <linux/scatterlist.h>
 #include <linux/slab.h>
-#include <linux/vmalloc.h>
 
 
 struct cma_heap {
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_connectors.c 
b/drivers/gpu/drm/amd/amdgpu/amdgpu_connectors.c
index b9c11c2b2885..65d1b23d7e74 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_connectors.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_connectors.c
@@ -1414,12 +1414,10 @@ out:
                pm_runtime_put_autosuspend(connector->dev->dev);
        }
 
-       if (connector->connector_type == DRM_MODE_CONNECTOR_DisplayPort ||
-           connector->connector_type == DRM_MODE_CONNECTOR_eDP)
-               drm_dp_set_subconnector_property(&amdgpu_connector->base,
-                                                ret,
-                                                amdgpu_dig_connector->dpcd,
-                                                
amdgpu_dig_connector->downstream_ports);
+       drm_dp_set_subconnector_property(&amdgpu_connector->base,
+                                        ret,
+                                        amdgpu_dig_connector->dpcd,
+                                        
amdgpu_dig_connector->downstream_ports);
        return ret;
 }
 
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c 
b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
index 1cb7d73f7317..7d2f7a2240b8 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_device.c
@@ -5069,7 +5069,8 @@ out:
  * @pdev: pointer to PCI device
  *
  * Called when the error recovery driver tells us that its
- * OK to resume normal operation.
+ * OK to resume normal operation. Use completion to allow
+ * halted scsi ops to resume.
  */
 void amdgpu_pci_resume(struct pci_dev *pdev)
 {
diff --git a/drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.c 
b/drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.c
index 6e679db5e46f..c2ced5be6d7b 100644
--- a/drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.c
+++ b/drivers/gpu/drm/amd/amdgpu/amdgpu_gmc.c
@@ -496,8 +496,7 @@ void amdgpu_gmc_get_vbios_allocations(struct amdgpu_device 
*adev)
                break;
        }
 
-       if (amdgpu_sriov_vf(adev) ||
-           !amdgpu_device_ip_get_ip_block(adev, AMD_IP_BLOCK_TYPE_DCE)) {
+       if (!amdgpu_device_ip_get_ip_block(adev, AMD_IP_BLOCK_TYPE_DCE)) {
                size = 0;
        } else {
                size = amdgpu_gmc_get_vbios_fb_size(adev);
diff --git a/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c 
b/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c
index 5f4805e4d04a..fc9bb94eaaf4 100644
--- a/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c
+++ b/drivers/gpu/drm/amd/amdgpu/gfx_v9_0.c
@@ -1647,7 +1647,7 @@ static int gfx_v9_0_init_microcode(struct amdgpu_device 
*adev)
        }
 
        /* No CPG in Arcturus */
-       if (adev->gfx.num_gfx_rings) {
+       if (adev->asic_type != CHIP_ARCTURUS) {
                r = gfx_v9_0_init_cp_gfx_microcode(adev, chip_name);
                if (r)
                        return r;
@@ -2633,14 +2633,7 @@ static void gfx_v9_0_wait_for_rlc_serdes(struct 
amdgpu_device *adev)
 static void gfx_v9_0_enable_gui_idle_interrupt(struct amdgpu_device *adev,
                                               bool enable)
 {
-       u32 tmp;
-
-       /* don't toggle interrupts that are only applicable
-        * to me0 pipe0 on AISCs that have me0 removed */
-       if (!adev->gfx.num_gfx_rings)
-               return;
-
-       tmp= RREG32_SOC15(GC, 0, mmCP_INT_CNTL_RING0);
+       u32 tmp = RREG32_SOC15(GC, 0, mmCP_INT_CNTL_RING0);
 
        tmp = REG_SET_FIELD(tmp, CP_INT_CNTL_RING0, CNTX_BUSY_INT_ENABLE, 
enable ? 1 : 0);
        tmp = REG_SET_FIELD(tmp, CP_INT_CNTL_RING0, CNTX_EMPTY_INT_ENABLE, 
enable ? 1 : 0);
@@ -3829,7 +3822,7 @@ static int gfx_v9_0_cp_resume(struct amdgpu_device *adev)
                gfx_v9_0_enable_gui_idle_interrupt(adev, false);
 
        if (adev->firmware.load_type != AMDGPU_FW_LOAD_PSP) {
-               if (adev->gfx.num_gfx_rings) {
+               if (adev->asic_type != CHIP_ARCTURUS) {
                        /* legacy firmware loading */
                        r = gfx_v9_0_cp_gfx_load_microcode(adev);
                        if (r)
@@ -3845,7 +3838,7 @@ static int gfx_v9_0_cp_resume(struct amdgpu_device *adev)
        if (r)
                return r;
 
-       if (adev->gfx.num_gfx_rings) {
+       if (adev->asic_type != CHIP_ARCTURUS) {
                r = gfx_v9_0_cp_gfx_resume(adev);
                if (r)
                        return r;
@@ -3855,7 +3848,7 @@ static int gfx_v9_0_cp_resume(struct amdgpu_device *adev)
        if (r)
                return r;
 
-       if (adev->gfx.num_gfx_rings) {
+       if (adev->asic_type != CHIP_ARCTURUS) {
                ring = &adev->gfx.gfx_ring[0];
                r = amdgpu_ring_test_helper(ring);
                if (r)
@@ -3891,7 +3884,7 @@ static void gfx_v9_0_init_tcp_config(struct amdgpu_device 
*adev)
 
 static void gfx_v9_0_cp_enable(struct amdgpu_device *adev, bool enable)
 {
-       if (adev->gfx.num_gfx_rings)
+       if (adev->asic_type != CHIP_ARCTURUS)
                gfx_v9_0_cp_gfx_enable(adev, enable);
        gfx_v9_0_cp_compute_enable(adev, enable);
 }
@@ -4032,7 +4025,7 @@ static int gfx_v9_0_soft_reset(void *handle)
                /* stop the rlc */
                adev->gfx.rlc.funcs->stop(adev);
 
-               if (adev->gfx.num_gfx_rings)
+               if (adev->asic_type != CHIP_ARCTURUS)
                        /* Disable GFX parsing/prefetching */
                        gfx_v9_0_cp_gfx_enable(adev, false);
 
diff --git a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c 
b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
index e22268f9dba7..e1531d97f486 100644
--- a/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
+++ b/drivers/gpu/drm/amd/amdgpu/gmc_v9_0.c
@@ -1577,10 +1577,13 @@ static int gmc_v9_0_hw_init(void *handle)
        gmc_v9_0_init_golden_registers(adev);
 
        if (adev->mode_info.num_crtc) {
-               /* Lockout access through VGA aperture*/
-               WREG32_FIELD15(DCE, 0, VGA_HDP_CONTROL, VGA_MEMORY_DISABLE, 1);
-               /* disable VGA render */
-               WREG32_FIELD15(DCE, 0, VGA_RENDER_CONTROL, VGA_VSTATUS_CNTL, 0);
+               if (adev->asic_type != CHIP_ARCTURUS) {
+                       /* Lockout access through VGA aperture*/
+                       WREG32_FIELD15(DCE, 0, VGA_HDP_CONTROL, 
VGA_MEMORY_DISABLE, 1);
+
+                       /* disable VGA render */
+                       WREG32_FIELD15(DCE, 0, VGA_RENDER_CONTROL, 
VGA_VSTATUS_CNTL, 0);
+               }
        }
 
        amdgpu_device_program_register_sequence(adev,
diff --git a/drivers/gpu/drm/amd/amdkfd/kfd_device.c 
b/drivers/gpu/drm/amd/amdkfd/kfd_device.c
index 72c893fff61a..50922ff2927b 100644
--- a/drivers/gpu/drm/amd/amdkfd/kfd_device.c
+++ b/drivers/gpu/drm/amd/amdkfd/kfd_device.c
@@ -422,7 +422,7 @@ static const struct kfd_device_info navi10_device_info = {
        .mqd_size_aligned = MQD_SIZE_ALIGNED,
        .needs_iommu_device = false,
        .supports_cwsr = true,
-       .needs_pci_atomics = true,
+       .needs_pci_atomics = false,
        .num_sdma_engines = 2,
        .num_xgmi_sdma_engines = 0,
        .num_sdma_queues_per_engine = 8,
@@ -440,7 +440,7 @@ static const struct kfd_device_info navi12_device_info = {
        .mqd_size_aligned = MQD_SIZE_ALIGNED,
        .needs_iommu_device = false,
        .supports_cwsr = true,
-       .needs_pci_atomics = true,
+       .needs_pci_atomics = false,
        .num_sdma_engines = 2,
        .num_xgmi_sdma_engines = 0,
        .num_sdma_queues_per_engine = 8,
@@ -458,7 +458,7 @@ static const struct kfd_device_info navi14_device_info = {
        .mqd_size_aligned = MQD_SIZE_ALIGNED,
        .needs_iommu_device = false,
        .supports_cwsr = true,
-       .needs_pci_atomics = true,
+       .needs_pci_atomics = false,
        .num_sdma_engines = 2,
        .num_xgmi_sdma_engines = 0,
        .num_sdma_queues_per_engine = 8,
@@ -476,7 +476,7 @@ static const struct kfd_device_info 
sienna_cichlid_device_info = {
        .mqd_size_aligned = MQD_SIZE_ALIGNED,
        .needs_iommu_device = false,
        .supports_cwsr = true,
-       .needs_pci_atomics = true,
+       .needs_pci_atomics = false,
        .num_sdma_engines = 4,
        .num_xgmi_sdma_engines = 0,
        .num_sdma_queues_per_engine = 8,
@@ -494,7 +494,7 @@ static const struct kfd_device_info 
navy_flounder_device_info = {
        .mqd_size_aligned = MQD_SIZE_ALIGNED,
        .needs_iommu_device = false,
        .supports_cwsr = true,
-       .needs_pci_atomics = true,
+       .needs_pci_atomics = false,
        .num_sdma_engines = 2,
        .num_xgmi_sdma_engines = 0,
        .num_sdma_queues_per_engine = 8,
@@ -530,7 +530,7 @@ static const struct kfd_device_info 
dimgrey_cavefish_device_info = {
        .mqd_size_aligned = MQD_SIZE_ALIGNED,
        .needs_iommu_device = false,
        .supports_cwsr = true,
-       .needs_pci_atomics = true,
+       .needs_pci_atomics = false,
        .num_sdma_engines = 2,
        .num_xgmi_sdma_engines = 0,
        .num_sdma_queues_per_engine = 8,
diff --git a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c 
b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
index 519080e9a233..2c4dbdeec46a 100644
--- a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
+++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm.c
@@ -2386,8 +2386,7 @@ void amdgpu_dm_update_connector_after_detect(
 
                        drm_connector_update_edid_property(connector,
                                                           aconnector->edid);
-                       aconnector->num_modes = drm_add_edid_modes(connector, 
aconnector->edid);
-                       drm_connector_list_update(connector);
+                       drm_add_edid_modes(connector, aconnector->edid);
 
                        if (aconnector->dc_link->aux_mode)
                                drm_dp_cec_set_edid(&aconnector->dm_dp_aux.aux,
@@ -9368,7 +9367,7 @@ static int amdgpu_dm_atomic_check(struct drm_device *dev,
                if (ret)
                        goto fail;
 
-               if (dm_old_crtc_state->dsc_force_changed)
+               if (dm_old_crtc_state->dsc_force_changed && new_crtc_state)
                        new_crtc_state->mode_changed = true;
        }
 
diff --git a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_irq.c 
b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_irq.c
index 26ed70e5538a..357778556b06 100644
--- a/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_irq.c
+++ b/drivers/gpu/drm/amd/display/amdgpu_dm/amdgpu_dm_irq.c
@@ -165,10 +165,7 @@ static struct list_head *remove_irq_handler(struct 
amdgpu_device *adev,
                handler = list_entry(entry, struct amdgpu_dm_irq_handler_data,
                                     list);
 
-               if (handler == NULL)
-                       continue;
-
-               if (ih == handler->handler) {
+               if (ih == handler) {
                        /* Found our handler. Remove it from the list. */
                        list_del(&handler->list);
                        handler_removed = true;
diff --git a/drivers/gpu/drm/amd/display/dc/clk_mgr/dcn21/rn_clk_mgr.c 
b/drivers/gpu/drm/amd/display/dc/clk_mgr/dcn21/rn_clk_mgr.c
index 01b1853b7750..d00b02553d62 100644
--- a/drivers/gpu/drm/amd/display/dc/clk_mgr/dcn21/rn_clk_mgr.c
+++ b/drivers/gpu/drm/amd/display/dc/clk_mgr/dcn21/rn_clk_mgr.c
@@ -75,8 +75,15 @@ int rn_get_active_display_cnt_wa(
        for (i = 0; i < dc->link_count; i++) {
                const struct dc_link *link = dc->links[i];
 
+               /*
+                * Only notify active stream or virtual stream.
+                * Need to notify virtual stream to work around
+                * headless case. HPD does not fire when system is in
+                * S0i2.
+                */
                /* abusing the fact that the dig and phy are coupled to see if 
the phy is enabled */
-               if (link->link_enc->funcs->is_dig_enabled(link->link_enc))
+               if (link->connector_signal == SIGNAL_TYPE_VIRTUAL ||
+                               
link->link_enc->funcs->is_dig_enabled(link->link_enc))
                        display_count++;
        }
 
@@ -227,11 +234,12 @@ void rn_update_clocks(struct clk_mgr *clk_mgr_base,
                                        rn_vbios_smu_set_dppclk(clk_mgr, 
clk_mgr_base->clks.dppclk_khz);
 
                // always update dtos unless clock is lowered and not safe to 
lower
-               rn_update_clocks_update_dpp_dto(
-                               clk_mgr,
-                               context,
-                               clk_mgr_base->clks.actual_dppclk_khz,
-                               safe_to_lower);
+               if (new_clocks->dppclk_khz >= 
dc->current_state->bw_ctx.bw.dcn.clk.dppclk_khz)
+                       rn_update_clocks_update_dpp_dto(
+                                       clk_mgr,
+                                       context,
+                                       clk_mgr_base->clks.actual_dppclk_khz,
+                                       safe_to_lower);
        }
 
        if (update_dispclk &&
@@ -730,32 +738,32 @@ static struct wm_table ddr4_wm_table_rn = {
                        .wm_inst = WM_A,
                        .wm_type = WM_TYPE_PSTATE_CHG,
                        .pstate_latency_us = 11.72,
-                       .sr_exit_time_us = 11.90,
-                       .sr_enter_plus_exit_time_us = 12.80,
+                       .sr_exit_time_us = 9.09,
+                       .sr_enter_plus_exit_time_us = 10.14,
                        .valid = true,
                },
                {
                        .wm_inst = WM_B,
                        .wm_type = WM_TYPE_PSTATE_CHG,
                        .pstate_latency_us = 11.72,
-                       .sr_exit_time_us = 13.18,
-                       .sr_enter_plus_exit_time_us = 14.30,
+                       .sr_exit_time_us = 11.12,
+                       .sr_enter_plus_exit_time_us = 12.48,
                        .valid = true,
                },
                {
                        .wm_inst = WM_C,
                        .wm_type = WM_TYPE_PSTATE_CHG,
                        .pstate_latency_us = 11.72,
-                       .sr_exit_time_us = 13.18,
-                       .sr_enter_plus_exit_time_us = 14.30,
+                       .sr_exit_time_us = 11.12,
+                       .sr_enter_plus_exit_time_us = 12.48,
                        .valid = true,
                },
                {
                        .wm_inst = WM_D,
                        .wm_type = WM_TYPE_PSTATE_CHG,
                        .pstate_latency_us = 11.72,
-                       .sr_exit_time_us = 13.18,
-                       .sr_enter_plus_exit_time_us = 14.30,
+                       .sr_exit_time_us = 11.12,
+                       .sr_enter_plus_exit_time_us = 12.48,
                        .valid = true,
                },
        }
diff --git 
a/drivers/gpu/drm/amd/display/dc/clk_mgr/dcn21/rn_clk_mgr_vbios_smu.c 
b/drivers/gpu/drm/amd/display/dc/clk_mgr/dcn21/rn_clk_mgr_vbios_smu.c
index 7deeec9d1c7c..11a7b583d561 100644
--- a/drivers/gpu/drm/amd/display/dc/clk_mgr/dcn21/rn_clk_mgr_vbios_smu.c
+++ b/drivers/gpu/drm/amd/display/dc/clk_mgr/dcn21/rn_clk_mgr_vbios_smu.c
@@ -99,7 +99,7 @@ int rn_vbios_smu_send_msg_with_param(struct clk_mgr_internal 
*clk_mgr, unsigned
        /* Trigger the message transaction by writing the message ID */
        REG_WRITE(MP1_SMN_C2PMSG_67, msg_id);
 
-       result = rn_smu_wait_for_response(clk_mgr, 10, 200000);
+       result = rn_smu_wait_for_response(clk_mgr, 10, 1000);
 
        ASSERT(result == VBIOSSMC_Result_OK || result == 
VBIOSSMC_Result_UnknownCmd);
 
diff --git a/drivers/gpu/drm/amd/display/dc/clk_mgr/dcn301/vg_clk_mgr.c 
b/drivers/gpu/drm/amd/display/dc/clk_mgr/dcn301/vg_clk_mgr.c
index 991b9c5beaa3..9a8e66bba9c0 100644
--- a/drivers/gpu/drm/amd/display/dc/clk_mgr/dcn301/vg_clk_mgr.c
+++ b/drivers/gpu/drm/amd/display/dc/clk_mgr/dcn301/vg_clk_mgr.c
@@ -74,8 +74,15 @@ int vg_get_active_display_cnt_wa(
        for (i = 0; i < dc->link_count; i++) {
                const struct dc_link *link = dc->links[i];
 
+               /*
+                * Only notify active stream or virtual stream.
+                * Need to notify virtual stream to work around
+                * headless case. HPD does not fire when system is in
+                * S0i2.
+                */
                /* abusing the fact that the dig and phy are coupled to see if 
the phy is enabled */
-               if (link->link_enc->funcs->is_dig_enabled(link->link_enc))
+               if (link->connector_signal == SIGNAL_TYPE_VIRTUAL ||
+                               
link->link_enc->funcs->is_dig_enabled(link->link_enc))
                        display_count++;
        }
 
diff --git a/drivers/gpu/drm/amd/display/dc/core/dc.c 
b/drivers/gpu/drm/amd/display/dc/core/dc.c
index 58eb0d69873a..7339d9855ec8 100644
--- a/drivers/gpu/drm/amd/display/dc/core/dc.c
+++ b/drivers/gpu/drm/amd/display/dc/core/dc.c
@@ -2625,6 +2625,26 @@ static void commit_planes_for_stream(struct dc *dc,
                }
        }
 
+       if (update_type != UPDATE_TYPE_FAST) {
+               // If changing VTG FP2: wait until back in vactive to program 
FP2
+               // Need to ensure that pipe unlock happens soon after to 
minimize race condition
+               for (i = 0; i < dc->res_pool->pipe_count; i++) {
+                       struct pipe_ctx *pipe_ctx = 
&context->res_ctx.pipe_ctx[i];
+
+                       if (pipe_ctx->top_pipe || pipe_ctx->stream != stream)
+                               continue;
+
+                       if (!pipe_ctx->update_flags.bits.global_sync)
+                               continue;
+
+                       
pipe_ctx->stream_res.tg->funcs->wait_for_state(pipe_ctx->stream_res.tg, 
CRTC_STATE_VBLANK);
+                       
pipe_ctx->stream_res.tg->funcs->wait_for_state(pipe_ctx->stream_res.tg, 
CRTC_STATE_VACTIVE);
+
+                       pipe_ctx->stream_res.tg->funcs->set_vtg_params(
+                                       pipe_ctx->stream_res.tg, 
&pipe_ctx->stream->timing, true);
+               }
+       }
+
        if ((update_type != UPDATE_TYPE_FAST) && 
dc->hwss.interdependent_update_lock)
                dc->hwss.interdependent_update_lock(dc, context, false);
        else
diff --git a/drivers/gpu/drm/amd/display/dc/core/dc_link_dp.c 
b/drivers/gpu/drm/amd/display/dc/core/dc_link_dp.c
index 2fc12239b22c..6b11d4af54af 100644
--- a/drivers/gpu/drm/amd/display/dc/core/dc_link_dp.c
+++ b/drivers/gpu/drm/amd/display/dc/core/dc_link_dp.c
@@ -3173,7 +3173,13 @@ static void get_active_converter_info(
        }
 
        /* DPCD 0x5 bit 0 = 1, it indicate it's branch device */
-       link->dpcd_caps.is_branch_dev = ds_port.fields.PORT_PRESENT;
+       if (ds_port.fields.PORT_TYPE == DOWNSTREAM_DP) {
+               link->dpcd_caps.is_branch_dev = false;
+       }
+
+       else {
+               link->dpcd_caps.is_branch_dev = ds_port.fields.PORT_PRESENT;
+       }
 
        switch (ds_port.fields.PORT_TYPE) {
        case DOWNSTREAM_VGA:
diff --git a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_hubp.c 
b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_hubp.c
index 9e796dfeac20..41679ad531c5 100644
--- a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_hubp.c
+++ b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_hubp.c
@@ -1241,22 +1241,6 @@ void hubp1_vtg_sel(struct hubp *hubp, uint32_t otg_inst)
        REG_UPDATE(DCHUBP_CNTL, HUBP_VTG_SEL, otg_inst);
 }
 
-bool hubp1_in_blank(struct hubp *hubp)
-{
-       uint32_t in_blank;
-       struct dcn10_hubp *hubp1 = TO_DCN10_HUBP(hubp);
-
-       REG_GET(DCHUBP_CNTL, HUBP_IN_BLANK, &in_blank);
-       return in_blank ? true : false;
-}
-
-void hubp1_soft_reset(struct hubp *hubp, bool reset)
-{
-       struct dcn10_hubp *hubp1 = TO_DCN10_HUBP(hubp);
-
-       REG_UPDATE(DCHUBP_CNTL, HUBP_DISABLE, reset ? 1 : 0);
-}
-
 void hubp1_init(struct hubp *hubp)
 {
        //do nothing
@@ -1288,8 +1272,6 @@ static const struct hubp_funcs dcn10_hubp_funcs = {
 
        .dmdata_set_attributes = NULL,
        .dmdata_load = NULL,
-       .hubp_soft_reset = hubp1_soft_reset,
-       .hubp_in_blank = hubp1_in_blank,
 };
 
 /*****************************************/
diff --git a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_hubp.h 
b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_hubp.h
index a9a6ed7f4f99..780af5b3c16f 100644
--- a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_hubp.h
+++ b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_hubp.h
@@ -260,7 +260,6 @@
        HUBP_SF(HUBP0_DCHUBP_CNTL, HUBP_NO_OUTSTANDING_REQ, mask_sh),\
        HUBP_SF(HUBP0_DCHUBP_CNTL, HUBP_VTG_SEL, mask_sh),\
        HUBP_SF(HUBP0_DCHUBP_CNTL, HUBP_DISABLE, mask_sh),\
-       HUBP_SF(HUBP0_DCHUBP_CNTL, HUBP_IN_BLANK, mask_sh),\
        HUBP_SF(HUBP0_DCSURF_ADDR_CONFIG, NUM_PIPES, mask_sh),\
        HUBP_SF(HUBP0_DCSURF_ADDR_CONFIG, NUM_BANKS, mask_sh),\
        HUBP_SF(HUBP0_DCSURF_ADDR_CONFIG, PIPE_INTERLEAVE, mask_sh),\
@@ -456,7 +455,6 @@
        type HUBP_VTG_SEL;\
        type HUBP_UNDERFLOW_STATUS;\
        type HUBP_UNDERFLOW_CLEAR;\
-       type HUBP_IN_BLANK;\
        type NUM_PIPES;\
        type NUM_BANKS;\
        type PIPE_INTERLEAVE;\
@@ -774,7 +772,5 @@ void hubp1_vready_workaround(struct hubp *hubp,
 
 void hubp1_init(struct hubp *hubp);
 void hubp1_read_state_common(struct hubp *hubp);
-bool hubp1_in_blank(struct hubp *hubp);
-void hubp1_soft_reset(struct hubp *hubp, bool reset);
 
 #endif
diff --git a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_mpc.c 
b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_mpc.c
index a46cb20596fe..3fcd408e9103 100644
--- a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_mpc.c
+++ b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_mpc.c
@@ -467,17 +467,6 @@ void mpc1_cursor_lock(struct mpc *mpc, int opp_id, bool 
lock)
        REG_SET(CUR[opp_id], 0, CUR_VUPDATE_LOCK_SET, lock ? 1 : 0);
 }
 
-unsigned int mpc1_get_mpc_out_mux(struct mpc *mpc, int opp_id)
-{
-       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
-       uint32_t val;
-
-       if (opp_id < MAX_OPP && REG(MUX[opp_id]))
-               REG_GET(MUX[opp_id], MPC_OUT_MUX, &val);
-
-       return val;
-}
-
 static const struct mpc_funcs dcn10_mpc_funcs = {
        .read_mpcc_state = mpc1_read_mpcc_state,
        .insert_plane = mpc1_insert_plane,
@@ -494,7 +483,6 @@ static const struct mpc_funcs dcn10_mpc_funcs = {
        .set_denorm_clamp = NULL,
        .set_output_csc = NULL,
        .set_output_gamma = NULL,
-       .get_mpc_out_mux = mpc1_get_mpc_out_mux,
 };
 
 void dcn10_mpc_construct(struct dcn10_mpc *mpc10,
diff --git a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_mpc.h 
b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_mpc.h
index dbfffc6383dc..66a4719c22a0 100644
--- a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_mpc.h
+++ b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_mpc.h
@@ -200,5 +200,4 @@ void mpc1_read_mpcc_state(
 
 void mpc1_cursor_lock(struct mpc *mpc, int opp_id, bool lock);
 
-unsigned int mpc1_get_mpc_out_mux(struct mpc *mpc, int opp_id);
 #endif
diff --git a/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_hubp.c 
b/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_hubp.c
index 0df0da2e6a4d..b7e44e53a342 100644
--- a/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_hubp.c
+++ b/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_hubp.c
@@ -1595,8 +1595,6 @@ static struct hubp_funcs dcn20_hubp_funcs = {
        .hubp_set_flip_control_surface_gsl = hubp2_set_flip_control_surface_gsl,
        .hubp_init = hubp1_init,
        .validate_dml_output = hubp2_validate_dml_output,
-       .hubp_in_blank = hubp1_in_blank,
-       .hubp_soft_reset = hubp1_soft_reset,
 };
 
 
diff --git a/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_hwseq.c 
b/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_hwseq.c
index cb822df21b7c..31a477194d3b 100644
--- a/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_hwseq.c
+++ b/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_hwseq.c
@@ -1586,10 +1586,7 @@ static void dcn20_program_pipe(
                        && !pipe_ctx->top_pipe && !pipe_ctx->prev_odm_pipe)
                hws->funcs.blank_pixel_data(dc, pipe_ctx, 
!pipe_ctx->plane_state->visible);
 
-       /* Only update TG on top pipe */
-       if (pipe_ctx->update_flags.bits.global_sync && !pipe_ctx->top_pipe
-                       && !pipe_ctx->prev_odm_pipe) {
-
+       if (pipe_ctx->update_flags.bits.global_sync) {
                pipe_ctx->stream_res.tg->funcs->program_global_sync(
                                pipe_ctx->stream_res.tg,
                                pipe_ctx->pipe_dlg_param.vready_offset,
@@ -1597,11 +1594,8 @@ static void dcn20_program_pipe(
                                pipe_ctx->pipe_dlg_param.vupdate_offset,
                                pipe_ctx->pipe_dlg_param.vupdate_width);
 
-               
pipe_ctx->stream_res.tg->funcs->wait_for_state(pipe_ctx->stream_res.tg, 
CRTC_STATE_VBLANK);
-               
pipe_ctx->stream_res.tg->funcs->wait_for_state(pipe_ctx->stream_res.tg, 
CRTC_STATE_VACTIVE);
-
                pipe_ctx->stream_res.tg->funcs->set_vtg_params(
-                               pipe_ctx->stream_res.tg, 
&pipe_ctx->stream->timing, true);
+                               pipe_ctx->stream_res.tg, 
&pipe_ctx->stream->timing, false);
 
                if (hws->funcs.setup_vupdate_interrupt)
                        hws->funcs.setup_vupdate_interrupt(dc, pipe_ctx);
@@ -2576,4 +2570,4 @@ void dcn20_set_disp_pattern_generator(const struct dc *dc,
 {
        
pipe_ctx->stream_res.opp->funcs->opp_set_disp_pattern_generator(pipe_ctx->stream_res.opp,
 test_pattern,
                        color_space, color_depth, solid_color, width, height, 
offset);
-}
+}
\ No newline at end of file
diff --git a/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_mpc.c 
b/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_mpc.c
index 6a99fdd55e8c..99cc095dc33c 100644
--- a/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_mpc.c
+++ b/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_mpc.c
@@ -556,7 +556,6 @@ const struct mpc_funcs dcn20_mpc_funcs = {
        .set_ocsc_default = mpc2_set_ocsc_default,
        .set_output_gamma = mpc2_set_output_gamma,
        .power_on_mpc_mem_pwr = mpc20_power_on_ogam_lut,
-       .get_mpc_out_mux = mpc1_get_mpc_out_mux,
 };
 
 void dcn20_mpc_construct(struct dcn20_mpc *mpc20,
diff --git a/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_resource.c 
b/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_resource.c
index e04ecf0fc0db..ff36db5edf6c 100644
--- a/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_resource.c
+++ b/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_resource.c
@@ -1933,7 +1933,7 @@ bool dcn20_split_stream_for_odm(
                next_odm_pipe->stream_res.opp = 
pool->opps[next_odm_pipe->pipe_idx];
        else
                next_odm_pipe->stream_res.opp = 
next_odm_pipe->top_pipe->stream_res.opp;
-       if (next_odm_pipe->stream->timing.flags.DSC == 1 && 
!next_odm_pipe->top_pipe) {
+       if (next_odm_pipe->stream->timing.flags.DSC == 1) {
                dcn20_acquire_dsc(dc, res_ctx, &next_odm_pipe->stream_res.dsc, 
next_odm_pipe->pipe_idx);
                ASSERT(next_odm_pipe->stream_res.dsc);
                if (next_odm_pipe->stream_res.dsc == NULL)
diff --git a/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_hubp.c 
b/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_hubp.c
index 88ffa9ff1ed1..af462fe4260d 100644
--- a/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_hubp.c
+++ b/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_hubp.c
@@ -509,8 +509,6 @@ static struct hubp_funcs dcn30_hubp_funcs = {
        .hubp_clear_underflow = hubp2_clear_underflow,
        .hubp_set_flip_control_surface_gsl = hubp2_set_flip_control_surface_gsl,
        .hubp_init = hubp3_init,
-       .hubp_in_blank = hubp1_in_blank,
-       .hubp_soft_reset = hubp1_soft_reset,
 };
 
 bool hubp3_construct(
diff --git a/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_mpc.c 
b/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_mpc.c
index 3e6f76096119..d7d053fc6e91 100644
--- a/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_mpc.c
+++ b/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_mpc.c
@@ -1428,7 +1428,6 @@ const struct mpc_funcs dcn30_mpc_funcs = {
        .program_3dlut = mpc3_program_3dlut,
        .release_rmu = mpcc3_release_rmu,
        .power_on_mpc_mem_pwr = mpc20_power_on_ogam_lut,
-       .get_mpc_out_mux = mpc1_get_mpc_out_mux,
 
 };
 
diff --git a/drivers/gpu/drm/amd/display/dc/inc/hw/hubp.h 
b/drivers/gpu/drm/amd/display/dc/inc/hw/hubp.h
index 22f3f643ed1b..315e3061c592 100644
--- a/drivers/gpu/drm/amd/display/dc/inc/hw/hubp.h
+++ b/drivers/gpu/drm/amd/display/dc/inc/hw/hubp.h
@@ -188,8 +188,6 @@ struct hubp_funcs {
        void (*set_unbounded_requesting)(
                struct hubp *hubp,
                bool enable);
-       bool (*hubp_in_blank)(struct hubp *hubp);
-       void (*hubp_soft_reset)(struct hubp *hubp, bool reset);
 
 };
 
diff --git a/drivers/gpu/drm/amd/display/dc/inc/hw/mpc.h 
b/drivers/gpu/drm/amd/display/dc/inc/hw/mpc.h
index 75c77ad9cbfe..879f502ae530 100644
--- a/drivers/gpu/drm/amd/display/dc/inc/hw/mpc.h
+++ b/drivers/gpu/drm/amd/display/dc/inc/hw/mpc.h
@@ -359,10 +359,6 @@ struct mpc_funcs {
 
        int (*release_rmu)(struct mpc *mpc, int mpcc_id);
 
-       unsigned int (*get_mpc_out_mux)(
-                       struct mpc *mpc,
-                       int opp_id);
-
 };
 
 #endif
diff --git a/drivers/gpu/drm/amd/display/dmub/inc/dmub_cmd.h 
b/drivers/gpu/drm/amd/display/dmub/inc/dmub_cmd.h
index 249a076d6f69..f512bda96917 100644
--- a/drivers/gpu/drm/amd/display/dmub/inc/dmub_cmd.h
+++ b/drivers/gpu/drm/amd/display/dmub/inc/dmub_cmd.h
@@ -47,10 +47,10 @@
 
 /* Firmware versioning. */
 #ifdef DMUB_EXPOSE_VERSION
-#define DMUB_FW_VERSION_GIT_HASH 0xf51b86a
+#define DMUB_FW_VERSION_GIT_HASH 0xa18e25995
 #define DMUB_FW_VERSION_MAJOR 0
 #define DMUB_FW_VERSION_MINOR 0
-#define DMUB_FW_VERSION_REVISION 47
+#define DMUB_FW_VERSION_REVISION 46
 #define DMUB_FW_VERSION_TEST 0
 #define DMUB_FW_VERSION_VBIOS 0
 #define DMUB_FW_VERSION_HOTFIX 0
diff --git a/drivers/gpu/drm/amd/display/modules/hdcp/hdcp1_execution.c 
b/drivers/gpu/drm/amd/display/modules/hdcp/hdcp1_execution.c
index 73ca49f05bd3..f244b72e74e0 100644
--- a/drivers/gpu/drm/amd/display/modules/hdcp/hdcp1_execution.c
+++ b/drivers/gpu/drm/amd/display/modules/hdcp/hdcp1_execution.c
@@ -128,12 +128,8 @@ static inline uint8_t get_device_count(struct mod_hdcp 
*hdcp)
 
 static inline enum mod_hdcp_status check_device_count(struct mod_hdcp *hdcp)
 {
-       /* Some MST display may choose to report the internal panel as an HDCP 
RX.
-        * To update this condition with 1(because the immediate repeater's 
internal
-        * panel is possibly not included in DEVICE_COUNT) + 
get_device_count(hdcp).
-        * Device count must be greater than or equal to tracked hdcp displays.
-        */
-       return ((1 + get_device_count(hdcp)) < get_active_display_count(hdcp)) ?
+       /* device count must be greater than or equal to tracked hdcp displays 
*/
+       return (get_device_count(hdcp) < get_active_display_count(hdcp)) ?
                        MOD_HDCP_STATUS_HDCP1_DEVICE_COUNT_MISMATCH_FAILURE :
                        MOD_HDCP_STATUS_SUCCESS;
 }
diff --git a/drivers/gpu/drm/amd/display/modules/hdcp/hdcp2_execution.c 
b/drivers/gpu/drm/amd/display/modules/hdcp/hdcp2_execution.c
index a0895a7efda2..549c113abcf7 100644
--- a/drivers/gpu/drm/amd/display/modules/hdcp/hdcp2_execution.c
+++ b/drivers/gpu/drm/amd/display/modules/hdcp/hdcp2_execution.c
@@ -207,11 +207,8 @@ static inline uint8_t get_device_count(struct mod_hdcp 
*hdcp)
 
 static enum mod_hdcp_status check_device_count(struct mod_hdcp *hdcp)
 {
-       /* Some MST display may choose to report the internal panel as an HDCP 
RX.   */
-       /* To update this condition with 1(because the immediate repeater's 
internal */
-       /* panel is possibly not included in DEVICE_COUNT) + 
get_device_count(hdcp). */
-       /* Device count must be greater than or equal to tracked hdcp displays. 
     */
-       return ((1 + get_device_count(hdcp)) < get_active_display_count(hdcp)) ?
+       /* device count must be greater than or equal to tracked hdcp displays 
*/
+       return (get_device_count(hdcp) < get_active_display_count(hdcp)) ?
                        MOD_HDCP_STATUS_HDCP2_DEVICE_COUNT_MISMATCH_FAILURE :
                        MOD_HDCP_STATUS_SUCCESS;
 }
diff --git a/drivers/gpu/drm/amd/display/modules/power/power_helpers.c 
b/drivers/gpu/drm/amd/display/modules/power/power_helpers.c
index 4fd8bce95d84..cc983f662157 100644
--- a/drivers/gpu/drm/amd/display/modules/power/power_helpers.c
+++ b/drivers/gpu/drm/amd/display/modules/power/power_helpers.c
@@ -82,24 +82,22 @@ struct abm_parameters {
        unsigned char deviation_gain;
        unsigned char min_knee;
        unsigned char max_knee;
-       unsigned short blRampReduction;
-       unsigned short blRampStart;
 };
 
 static const struct abm_parameters abm_settings_config0[abm_defines_max_level] 
= {
-//  min_red  max_red  bright_pos  dark_pos  bright_gain  contrast  dev   
min_knee  max_knee  blStart  blRed
-       {0xff,   0xbf,    0x20,   0x00,     0xff,        0x99,     0xb3, 0x40,  
   0xe0,     0xCCCC,  0xCCCC},
-       {0xde,   0x85,    0x20,   0x00,     0xff,        0x90,     0xa8, 0x40,  
   0xdf,     0xCCCC,  0xCCCC},
-       {0xb0,   0x50,    0x20,   0x00,     0xc0,        0x88,     0x78, 0x70,  
   0xa0,     0xCCCC,  0xCCCC},
-       {0x82,   0x40,    0x20,   0x00,     0x00,        0xff,     0xb3, 0x70,  
   0x70,     0xCCCC,  0xCCCC},
+//  min_red  max_red  bright_pos  dark_pos  brightness_gain  contrast  
deviation  min_knee  max_knee
+       {0xff,   0xbf,    0x20,       0x00,     0xff,            0x99,     
0xb3,      0x40,     0xe0},
+       {0xde,   0x85,    0x20,       0x00,     0xff,            0x90,     
0xa8,      0x40,     0xdf},
+       {0xb0,   0x50,    0x20,       0x00,     0xc0,            0x88,     
0x78,      0x70,     0xa0},
+       {0x82,   0x40,    0x20,       0x00,     0x00,            0xff,     
0xb3,      0x70,     0x70},
 };
 
 static const struct abm_parameters abm_settings_config1[abm_defines_max_level] 
= {
-//  min_red  max_red  bright_pos  dark_pos  bright_gain  contrast  dev   
min_knee  max_knee  blStart  blRed
-       {0xf0,   0xd9,    0x20,   0x00,     0x00,        0xff,     0xb3, 0x70,  
   0x70,     0xCCCC,  0xCCCC},
-       {0xcd,   0xa5,    0x20,   0x00,     0x00,        0xff,     0xb3, 0x70,  
   0x70,     0xCCCC,  0xCCCC},
-       {0x99,   0x65,    0x20,   0x00,     0x00,        0xff,     0xb3, 0x70,  
   0x70,     0xCCCC,  0xCCCC},
-       {0x82,   0x4d,    0x20,   0x00,     0x00,        0xff,     0xb3, 0x70,  
   0x70,     0xCCCC,  0xCCCC},
+//  min_red  max_red  bright_pos  dark_pos  brightness_gain  contrast  
deviation  min_knee  max_knee
+       {0xf0,   0xd9,    0x20,       0x00,     0x00,            0xff,     
0xb3,      0x70,     0x70},
+       {0xcd,   0xa5,    0x20,       0x00,     0x00,            0xff,     
0xb3,      0x70,     0x70},
+       {0x99,   0x65,    0x20,       0x00,     0x00,            0xff,     
0xb3,      0x70,     0x70},
+       {0x82,   0x4d,    0x20,       0x00,     0x00,            0xff,     
0xb3,      0x70,     0x70},
 };
 
 static const struct abm_parameters * const abm_settings[] = {
@@ -664,7 +662,6 @@ bool dmub_init_abm_config(struct resource_pool *res_pool,
 {
        struct iram_table_v_2_2 ram_table;
        struct abm_config_table config;
-       unsigned int set = params.set;
        bool result = false;
        uint32_t i, j = 0;
 
@@ -713,18 +710,6 @@ bool dmub_init_abm_config(struct resource_pool *res_pool,
                config.max_knee[i] = ram_table.max_knee[i];
        }
 
-       if (params.backlight_ramping_override) {
-               for (i = 0; i < NUM_AGGR_LEVEL; i++) {
-                       config.blRampReduction[i] = 
params.backlight_ramping_reduction;
-                       config.blRampStart[i] = params.backlight_ramping_start;
-                       }
-               } else {
-                       for (i = 0; i < NUM_AGGR_LEVEL; i++) {
-                               config.blRampReduction[i] = 
abm_settings[set][i].blRampReduction;
-                               config.blRampStart[i] = 
abm_settings[set][i].blRampStart;
-                               }
-                       }
-
        config.min_abm_backlight = ram_table.min_abm_backlight;
 
 #if defined(CONFIG_DRM_AMD_DC_DCN)
diff --git a/drivers/gpu/drm/amd/display/modules/power/power_helpers.h 
b/drivers/gpu/drm/amd/display/modules/power/power_helpers.h
index 6f2eecce6baa..fa4728d88092 100644
--- a/drivers/gpu/drm/amd/display/modules/power/power_helpers.h
+++ b/drivers/gpu/drm/amd/display/modules/power/power_helpers.h
@@ -39,7 +39,6 @@ enum abm_defines {
 struct dmcu_iram_parameters {
        unsigned int *backlight_lut_array;
        unsigned int backlight_lut_array_size;
-       bool backlight_ramping_override;
        unsigned int backlight_ramping_reduction;
        unsigned int backlight_ramping_start;
        unsigned int min_abm_backlight;
diff --git a/drivers/gpu/drm/amd/pm/inc/smu_v11_0.h 
b/drivers/gpu/drm/amd/pm/inc/smu_v11_0.h
index 13de692a4213..e5aa0725147c 100644
--- a/drivers/gpu/drm/amd/pm/inc/smu_v11_0.h
+++ b/drivers/gpu/drm/amd/pm/inc/smu_v11_0.h
@@ -30,7 +30,7 @@
 #define SMU11_DRIVER_IF_VERSION_NV10 0x36
 #define SMU11_DRIVER_IF_VERSION_NV12 0x36
 #define SMU11_DRIVER_IF_VERSION_NV14 0x36
-#define SMU11_DRIVER_IF_VERSION_Sienna_Cichlid 0x3D
+#define SMU11_DRIVER_IF_VERSION_Sienna_Cichlid 0x3B
 #define SMU11_DRIVER_IF_VERSION_Navy_Flounder 0xC
 #define SMU11_DRIVER_IF_VERSION_VANGOGH 0x02
 #define SMU11_DRIVER_IF_VERSION_Dimgrey_Cavefish 0xF
diff --git a/drivers/gpu/drm/amd/pm/swsmu/smu11/vangogh_ppt.c 
b/drivers/gpu/drm/amd/pm/swsmu/smu11/vangogh_ppt.c
index 8cb4fcee9a2c..9bccf2ad038c 100644
--- a/drivers/gpu/drm/amd/pm/swsmu/smu11/vangogh_ppt.c
+++ b/drivers/gpu/drm/amd/pm/swsmu/smu11/vangogh_ppt.c
@@ -724,13 +724,8 @@ static int 
vangogh_set_fine_grain_gfx_freq_parameters(struct smu_context *smu)
 
 static int vangogh_system_features_control(struct smu_context *smu, bool en)
 {
-       struct amdgpu_device *adev = smu->adev;
-
-       if (adev->pm.fw_version >= 0x43f1700)
-               return smu_cmn_send_smc_msg_with_param(smu, 
SMU_MSG_RlcPowerNotify,
-                                               en ? RLC_STATUS_NORMAL : 
RLC_STATUS_OFF, NULL);
-       else
-               return 0;
+       return smu_cmn_send_smc_msg_with_param(smu, SMU_MSG_RlcPowerNotify,
+                                       en ? RLC_STATUS_NORMAL : 
RLC_STATUS_OFF, NULL);
 }
 
 static const struct pptable_funcs vangogh_ppt_funcs = {
diff --git a/drivers/gpu/drm/arm/display/komeda/komeda_dev.c 
b/drivers/gpu/drm/arm/display/komeda/komeda_dev.c
index ca891ae14d36..1f8195bad536 100644
--- a/drivers/gpu/drm/arm/display/komeda/komeda_dev.c
+++ b/drivers/gpu/drm/arm/display/komeda/komeda_dev.c
@@ -152,6 +152,7 @@ static int komeda_parse_dt(struct device *dev, struct 
komeda_dev *mdev)
        ret = of_reserved_mem_device_init(dev);
        if (ret && ret != -ENODEV)
                return ret;
+       ret = 0;
 
        for_each_available_child_of_node(np, child) {
                if (of_node_name_eq(child, "pipeline")) {
diff --git a/drivers/gpu/drm/arm/display/komeda/komeda_kms.c 
b/drivers/gpu/drm/arm/display/komeda/komeda_kms.c
index 034ee08482e0..6b99df696384 100644
--- a/drivers/gpu/drm/arm/display/komeda/komeda_kms.c
+++ b/drivers/gpu/drm/arm/display/komeda/komeda_kms.c
@@ -81,10 +81,10 @@ static void komeda_kms_commit_tail(struct drm_atomic_state 
*old_state)
 
        drm_atomic_helper_commit_modeset_enables(dev, old_state);
 
-       drm_atomic_helper_commit_hw_done(old_state);
-
        drm_atomic_helper_wait_for_flip_done(dev, old_state);
 
+       drm_atomic_helper_commit_hw_done(old_state);
+
        drm_atomic_helper_cleanup_planes(dev, old_state);
 }
 
diff --git a/drivers/gpu/drm/arm/display/komeda/komeda_pipeline.c 
b/drivers/gpu/drm/arm/display/komeda/komeda_pipeline.c
index 719a79728e24..452e505a1fd3 100644
--- a/drivers/gpu/drm/arm/display/komeda/komeda_pipeline.c
+++ b/drivers/gpu/drm/arm/display/komeda/komeda_pipeline.c
@@ -137,10 +137,9 @@ komeda_pipeline_get_first_component(struct komeda_pipeline 
*pipe,
                                    u32 comp_mask)
 {
        struct komeda_component *c = NULL;
-       unsigned long comp_mask_local = (unsigned long)comp_mask;
        int id;
 
-       id = find_first_bit(&comp_mask_local, 32);
+       id = find_first_bit((unsigned long *)&comp_mask, 32);
        if (id < 32)
                c = komeda_pipeline_get_component(pipe, id);
 
diff --git a/drivers/gpu/drm/arm/display/komeda/komeda_pipeline_state.c 
b/drivers/gpu/drm/arm/display/komeda/komeda_pipeline_state.c
index 5c085116de3f..8f32ae7c25d0 100644
--- a/drivers/gpu/drm/arm/display/komeda/komeda_pipeline_state.c
+++ b/drivers/gpu/drm/arm/display/komeda/komeda_pipeline_state.c
@@ -704,10 +704,10 @@ komeda_compiz_set_input(struct komeda_compiz *compiz,
        cin->layer_alpha = dflow->layer_alpha;
 
        old_st = komeda_component_get_old_state(&compiz->base, drm_st);
+       WARN_ON(!old_st);
 
        /* compare with old to check if this input has been changed */
-       if (WARN_ON(!old_st) ||
-           memcmp(&(to_compiz_st(old_st)->cins[idx]), cin, sizeof(*cin)))
+       if (memcmp(&(to_compiz_st(old_st)->cins[idx]), cin, sizeof(*cin)))
                c_st->changed_active_inputs |= BIT(idx);
 
        komeda_component_add_input(c_st, &dflow->input, idx);
diff --git a/drivers/gpu/drm/ttm/ttm_pool.c b/drivers/gpu/drm/ttm/ttm_pool.c
index 7b2f60616750..5455b2044759 100644
--- a/drivers/gpu/drm/ttm/ttm_pool.c
+++ b/drivers/gpu/drm/ttm/ttm_pool.c
@@ -239,6 +239,21 @@ static struct page *ttm_pool_type_take(struct 
ttm_pool_type *pt)
        return p;
 }
 
+/* Count the number of pages available in a pool_type */
+static unsigned int ttm_pool_type_count(struct ttm_pool_type *pt)
+{
+       unsigned int count = 0;
+       struct page *p;
+
+       spin_lock(&pt->lock);
+       /* Only used for debugfs, the overhead doesn't matter */
+       list_for_each_entry(p, &pt->pages, lru)
+               ++count;
+       spin_unlock(&pt->lock);
+
+       return count;
+}
+
 /* Initialize and add a pool type to the global shrinker list */
 static void ttm_pool_type_init(struct ttm_pool_type *pt, struct ttm_pool *pool,
                               enum ttm_caching caching, unsigned int order)
@@ -528,20 +543,6 @@ void ttm_pool_fini(struct ttm_pool *pool)
 EXPORT_SYMBOL(ttm_pool_fini);
 
 #ifdef CONFIG_DEBUG_FS
-/* Count the number of pages available in a pool_type */
-static unsigned int ttm_pool_type_count(struct ttm_pool_type *pt)
-{
-       unsigned int count = 0;
-       struct page *p;
-
-       spin_lock(&pt->lock);
-       /* Only used for debugfs, the overhead doesn't matter */
-       list_for_each_entry(p, &pt->pages, lru)
-               ++count;
-       spin_unlock(&pt->lock);
-
-       return count;
-}
 
 /* Dump information about the different pool types */
 static void ttm_pool_debugfs_orders(struct ttm_pool_type *pt,
_______________________________________________
openchrome-devel mailing list
openchrome-devel@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/openchrome-devel

Reply via email to