drm/amd/display: fix mapping to non-allocated address
authorjsg <jsg@openbsd.org>
Mon, 27 Mar 2023 03:57:03 +0000 (03:57 +0000)
committerjsg <jsg@openbsd.org>
Mon, 27 Mar 2023 03:57:03 +0000 (03:57 +0000)
From Brandon Syu
8ce8a443ddd9002861a4ee8a7e33a0c02717422f in linux-6.1.y/6.1.16
9190d4a263264eabf715f5fc1827da45e3fdc247 in mainline linux

sys/dev/pci/drm/amd/display/dc/gpio/dcn20/hw_factory_dcn20.c
sys/dev/pci/drm/amd/display/dc/gpio/dcn30/hw_factory_dcn30.c
sys/dev/pci/drm/amd/display/dc/gpio/dcn32/hw_factory_dcn32.c
sys/dev/pci/drm/amd/display/dc/gpio/ddc_regs.h

index 9b63c6c..e0bd0c7 100644 (file)
@@ -138,7 +138,8 @@ static const struct ddc_sh_mask ddc_shift[] = {
        DDC_MASK_SH_LIST_DCN2(__SHIFT, 3),
        DDC_MASK_SH_LIST_DCN2(__SHIFT, 4),
        DDC_MASK_SH_LIST_DCN2(__SHIFT, 5),
-       DDC_MASK_SH_LIST_DCN2(__SHIFT, 6)
+       DDC_MASK_SH_LIST_DCN2(__SHIFT, 6),
+       DDC_MASK_SH_LIST_DCN2_VGA(__SHIFT)
 };
 
 static const struct ddc_sh_mask ddc_mask[] = {
@@ -147,7 +148,8 @@ static const struct ddc_sh_mask ddc_mask[] = {
        DDC_MASK_SH_LIST_DCN2(_MASK, 3),
        DDC_MASK_SH_LIST_DCN2(_MASK, 4),
        DDC_MASK_SH_LIST_DCN2(_MASK, 5),
-       DDC_MASK_SH_LIST_DCN2(_MASK, 6)
+       DDC_MASK_SH_LIST_DCN2(_MASK, 6),
+       DDC_MASK_SH_LIST_DCN2_VGA(_MASK)
 };
 
 #include "../generic_regs.h"
index 6c4f75c..fd0c6e0 100644 (file)
@@ -147,7 +147,8 @@ static const struct ddc_sh_mask ddc_shift[] = {
        DDC_MASK_SH_LIST_DCN2(__SHIFT, 3),
        DDC_MASK_SH_LIST_DCN2(__SHIFT, 4),
        DDC_MASK_SH_LIST_DCN2(__SHIFT, 5),
-       DDC_MASK_SH_LIST_DCN2(__SHIFT, 6)
+       DDC_MASK_SH_LIST_DCN2(__SHIFT, 6),
+       DDC_MASK_SH_LIST_DCN2_VGA(__SHIFT)
 };
 
 static const struct ddc_sh_mask ddc_mask[] = {
@@ -156,7 +157,8 @@ static const struct ddc_sh_mask ddc_mask[] = {
        DDC_MASK_SH_LIST_DCN2(_MASK, 3),
        DDC_MASK_SH_LIST_DCN2(_MASK, 4),
        DDC_MASK_SH_LIST_DCN2(_MASK, 5),
-       DDC_MASK_SH_LIST_DCN2(_MASK, 6)
+       DDC_MASK_SH_LIST_DCN2(_MASK, 6),
+       DDC_MASK_SH_LIST_DCN2_VGA(_MASK)
 };
 
 #include "../generic_regs.h"
index 0ea52ba..9f6872a 100644 (file)
@@ -149,7 +149,8 @@ static const struct ddc_sh_mask ddc_shift[] = {
        DDC_MASK_SH_LIST_DCN2(__SHIFT, 3),
        DDC_MASK_SH_LIST_DCN2(__SHIFT, 4),
        DDC_MASK_SH_LIST_DCN2(__SHIFT, 5),
-       DDC_MASK_SH_LIST_DCN2(__SHIFT, 6)
+       DDC_MASK_SH_LIST_DCN2(__SHIFT, 6),
+       DDC_MASK_SH_LIST_DCN2_VGA(__SHIFT)
 };
 
 static const struct ddc_sh_mask ddc_mask[] = {
@@ -158,7 +159,8 @@ static const struct ddc_sh_mask ddc_mask[] = {
        DDC_MASK_SH_LIST_DCN2(_MASK, 3),
        DDC_MASK_SH_LIST_DCN2(_MASK, 4),
        DDC_MASK_SH_LIST_DCN2(_MASK, 5),
-       DDC_MASK_SH_LIST_DCN2(_MASK, 6)
+       DDC_MASK_SH_LIST_DCN2(_MASK, 6),
+       DDC_MASK_SH_LIST_DCN2_VGA(_MASK)
 };
 
 #include "../generic_regs.h"
index 308a543..59884ef 100644 (file)
        (PHY_AUX_CNTL__AUX## cd ##_PAD_RXSEL## mask_sh),\
        (DC_GPIO_AUX_CTRL_5__DDC_PAD## cd ##_I2CMODE## mask_sh)}
 
+#define DDC_MASK_SH_LIST_DCN2_VGA(mask_sh) \
+       {DDC_MASK_SH_LIST_COMMON(mask_sh),\
+       0,\
+       0,\
+       0,\
+       0}
+
 struct ddc_registers {
        struct gpio_registers gpio;
        uint32_t ddc_setup;