[Freedreno] [PATCH] drm/msm/dpu: disable features unsupported by QCM2290

Abhinav Kumar quic_abhinavk at quicinc.com
Wed Jan 25 00:22:49 UTC 2023



On 1/24/2023 12:22 AM, Dmitry Baryshkov wrote:
> On 24/01/2023 03:32, Abhinav Kumar wrote:
>>
>>
>> On 1/22/2023 11:11 PM, Dmitry Baryshkov wrote:
>>> QCM2290 doesn't seem to support reg-dma, smart-dma, UBWC, CDP, exclusion
>>> rectangles and CSC. Drop corresponding features being incorrectly
>>> enabled for qcm2290.
>>>
>>
>> Can you please point me to which vendor DT you are referring to for this?
>>
>> CSC is supported on the VIG SSPPs from what I can see.
> 
> https://github.com/MiCode/kernel_devicetree/blob/psyche-r-oss/qcom/scuba-sde.dtsi 
> 
> 
> No CSC, smart-dma, excl-rect, CDP, etc.

Sorry I am missing something here.

It has one Vig and one DMA

https://github.com/MiCode/kernel_devicetree/blob/psyche-r-oss/qcom/scuba-sde.dtsi#L68

If Vig is present, CSC is supported.

Even for smart DMA I can see it supported 
https://github.com/MiCode/kernel_devicetree/blob/psyche-r-oss/qcom/scuba-sde.dtsi#L76 
on the DMA SSPP.

Same for excl rectangle too 
https://github.com/MiCode/kernel_devicetree/blob/psyche-r-oss/qcom/scuba-sde.dtsi#L74


> 
>> QCM2290 should be using the same MDP version as 6115 from the HW version.
> 
> It is 6.3 vs 6.5 if I remember correctly.
> 
>>
>>
>>> Cc: Loic Poulain <loic.poulain at linaro.org>
>>> Fixes: 5334087ee743 ("drm/msm: add support for QCM2290 MDSS")
>>> Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov at linaro.org>
>>> ---
>>>   .../gpu/drm/msm/disp/dpu1/dpu_hw_catalog.c    | 20 +++++++++++--------
>>>   1 file changed, 12 insertions(+), 8 deletions(-)
>>>
>>> diff --git a/drivers/gpu/drm/msm/disp/dpu1/dpu_hw_catalog.c 
>>> b/drivers/gpu/drm/msm/disp/dpu1/dpu_hw_catalog.c
>>> index 289fb11f99d1..1c3ffa922794 100644
>>> --- a/drivers/gpu/drm/msm/disp/dpu1/dpu_hw_catalog.c
>>> +++ b/drivers/gpu/drm/msm/disp/dpu1/dpu_hw_catalog.c
>>> @@ -12,10 +12,14 @@
>>>   #include "dpu_hw_catalog.h"
>>>   #include "dpu_kms.h"
>>> -#define VIG_MASK \
>>> +#define VIG_BASE_MASK \
>>>       (BIT(DPU_SSPP_SRC) | BIT(DPU_SSPP_QOS) |\
>>> +    BIT(DPU_SSPP_TS_PREFILL))
>>> +
>>> +#define VIG_MASK \
>>> +    (VIG_BASE_MASK | \
>>>       BIT(DPU_SSPP_CSC_10BIT) | BIT(DPU_SSPP_CDP) |\
>>> -    BIT(DPU_SSPP_TS_PREFILL) | BIT(DPU_SSPP_EXCL_RECT))
>>> +    BIT(DPU_SSPP_EXCL_RECT))
>>>   #define VIG_MSM8998_MASK \
>>>       (VIG_MASK | BIT(DPU_SSPP_SCALER_QSEED3))
>>> @@ -29,7 +33,7 @@
>>>   #define VIG_SM8250_MASK \
>>>       (VIG_MASK | BIT(DPU_SSPP_QOS_8LVL) | 
>>> BIT(DPU_SSPP_SCALER_QSEED3LITE))
>>> -#define VIG_QCM2290_MASK (VIG_MASK | BIT(DPU_SSPP_QOS_8LVL))
>>> +#define VIG_QCM2290_MASK (VIG_BASE_MASK | BIT(DPU_SSPP_QOS_8LVL))
>>>   #define DMA_MSM8998_MASK \
>>>       (BIT(DPU_SSPP_SRC) | BIT(DPU_SSPP_QOS) |\
>>> @@ -50,6 +54,10 @@
>>>   #define DMA_CURSOR_MSM8998_MASK \
>>>       (DMA_MSM8998_MASK | BIT(DPU_SSPP_CURSOR))
>>> +#define DMA_QCM2290_MASK \
>>> +    (BIT(DPU_SSPP_SRC) | BIT(DPU_SSPP_QOS) | BIT(DPU_SSPP_QOS_8LVL) |\
>>> +    BIT(DPU_SSPP_TS_PREFILL) | BIT(DPU_SSPP_TS_PREFILL_REC1))
>>> +
>>>   #define MIXER_MSM8998_MASK \
>>>       (BIT(DPU_MIXER_SOURCESPLIT) | BIT(DPU_DIM_LAYER))
>>> @@ -316,8 +324,6 @@ static const struct dpu_caps msm8998_dpu_caps = {
>>>   static const struct dpu_caps qcm2290_dpu_caps = {
>>>       .max_mixer_width = DEFAULT_DPU_OUTPUT_LINE_WIDTH,
>>>       .max_mixer_blendstages = 0x4,
>>> -    .smart_dma_rev = DPU_SSPP_SMART_DMA_V2,
>>> -    .ubwc_version = DPU_HW_UBWC_VER_20,
>>>       .has_dim_layer = true,
>>>       .has_idle_pc = true,
>>>       .max_linewidth = 2160,
>>> @@ -1384,7 +1390,7 @@ static const struct dpu_sspp_sub_blks 
>>> qcm2290_dma_sblk_0 = _DMA_SBLK("8", 1);
>>>   static const struct dpu_sspp_cfg qcm2290_sspp[] = {
>>>       SSPP_BLK("sspp_0", SSPP_VIG0, 0x4000, VIG_QCM2290_MASK,
>>>            qcm2290_vig_sblk_0, 0, SSPP_TYPE_VIG, DPU_CLK_CTRL_VIG0),
>>> -    SSPP_BLK("sspp_8", SSPP_DMA0, 0x24000,  DMA_SDM845_MASK,
>>> +    SSPP_BLK("sspp_8", SSPP_DMA0, 0x24000,  DMA_QCM2290_MASK,
>>>            qcm2290_dma_sblk_0, 1, SSPP_TYPE_DMA, DPU_CLK_CTRL_DMA0),
>>>   };
>>> @@ -2836,8 +2842,6 @@ static const struct dpu_mdss_cfg 
>>> qcm2290_dpu_cfg = {
>>>       .intf = qcm2290_intf,
>>>       .vbif_count = ARRAY_SIZE(sdm845_vbif),
>>>       .vbif = sdm845_vbif,
>>> -    .reg_dma_count = 1,
>>> -    .dma_cfg = &sdm845_regdma,
>>>       .perf = &qcm2290_perf_data,
>>>       .mdss_irqs = IRQ_SC7180_MASK,
>>>   };
> 


More information about the Freedreno mailing list