]> www.infradead.org Git - users/hch/block.git/commitdiff
drm/msm/dpu: Add support for P010 format
authorJessica Zhang <quic_jesszhan@quicinc.com>
Thu, 1 Sep 2022 20:34:22 +0000 (13:34 -0700)
committerDmitry Baryshkov <dmitry.baryshkov@linaro.org>
Wed, 2 Nov 2022 15:59:44 +0000 (18:59 +0300)
Add support for P010 color format. This adds support for both linear and
compressed formats.

Signed-off-by: Jessica Zhang <quic_jesszhan@quicinc.com>
Reviewed-by: Rob Clark <robdclark@gmail.com>
Patchwork: https://patchwork.freedesktop.org/patch/500822/
Link: https://lore.kernel.org/r/20220901203422.217-3-quic_jesszhan@quicinc.com
Signed-off-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
drivers/gpu/drm/msm/disp/dpu1/dpu_formats.c
drivers/gpu/drm/msm/disp/dpu1/dpu_hw_catalog.c
drivers/gpu/drm/msm/disp/dpu1/dpu_plane.c

index 57971c08f57c14772f22ac04718fb44a64d7118c..d95540309d4d8d7bf55ca8f5a00fa9458e5fe235 100644 (file)
@@ -434,6 +434,12 @@ static const struct dpu_format dpu_format_map[] = {
                DPU_CHROMA_H2V1, DPU_FORMAT_FLAG_YUV,
                DPU_FETCH_LINEAR, 2),
 
+       PSEUDO_YUV_FMT_LOOSE(P010,
+               0, COLOR_8BIT, COLOR_8BIT, COLOR_8BIT,
+               C1_B_Cb, C2_R_Cr,
+               DPU_CHROMA_420, DPU_FORMAT_FLAG_DX | DPU_FORMAT_FLAG_YUV,
+               DPU_FETCH_LINEAR, 2),
+
        INTERLEAVED_YUV_FMT(VYUY,
                0, COLOR_8BIT, COLOR_8BIT, COLOR_8BIT,
                C2_R_Cr, C0_G_Y, C1_B_Cb, C0_G_Y,
@@ -536,6 +542,14 @@ static const struct dpu_format dpu_format_map_ubwc[] = {
                DPU_CHROMA_420, DPU_FORMAT_FLAG_YUV |
                                DPU_FORMAT_FLAG_COMPRESSED,
                DPU_FETCH_UBWC, 4, DPU_TILE_HEIGHT_NV12),
+
+       PSEUDO_YUV_FMT_TILED(P010,
+               0, COLOR_8BIT, COLOR_8BIT, COLOR_8BIT,
+               C1_B_Cb, C2_R_Cr,
+               DPU_CHROMA_420, DPU_FORMAT_FLAG_DX |
+                               DPU_FORMAT_FLAG_YUV |
+                               DPU_FORMAT_FLAG_COMPRESSED,
+               DPU_FETCH_UBWC, 4, DPU_TILE_HEIGHT_UBWC),
 };
 
 /* _dpu_get_v_h_subsample_rate - Get subsample rates for all formats we support
@@ -584,7 +598,8 @@ static int _dpu_format_get_media_color_ubwc(const struct dpu_format *fmt)
        int color_fmt = -1;
        int i;
 
-       if (fmt->base.pixel_format == DRM_FORMAT_NV12) {
+       if (fmt->base.pixel_format == DRM_FORMAT_NV12 ||
+           fmt->base.pixel_format == DRM_FORMAT_P010) {
                if (DPU_FORMAT_IS_DX(fmt)) {
                        if (fmt->unpack_tight)
                                color_fmt = COLOR_FMT_NV12_BPP10_UBWC;
index 4e79f9bec8c8ccb6f47b253f1165910e8e0e1789..bae3cc3adb3fa4fd294d9ea1914ed90cbe185c7c 100644 (file)
@@ -210,6 +210,7 @@ static const uint32_t plane_formats_yuv[] = {
        DRM_FORMAT_RGBX4444,
        DRM_FORMAT_BGRX4444,
 
+       DRM_FORMAT_P010,
        DRM_FORMAT_NV12,
        DRM_FORMAT_NV21,
        DRM_FORMAT_NV16,
index 33bdb9ce65a338719b591bc32d88e9420b308138..86719020afe20bf096fad19c281d9cfc849acdc6 100644 (file)
@@ -73,6 +73,7 @@ static const uint32_t qcom_compressed_supported_formats[] = {
        DRM_FORMAT_BGR565,
 
        DRM_FORMAT_NV12,
+       DRM_FORMAT_P010,
 };
 
 /**