642 lines
22 KiB
C
642 lines
22 KiB
C
// SPDX-License-Identifier: GPL-2.0-only
|
|
/*
|
|
* Copyright (c) 2014 The Linux Foundation. All rights reserved.
|
|
* Copyright (C) 2013 Red Hat
|
|
* Author: Rob Clark <robdclark@gmail.com>
|
|
*/
|
|
|
|
#include <drm/drm_fourcc.h>
|
|
#include <drm/drm_framebuffer.h>
|
|
|
|
#include "msm_drv.h"
|
|
#include "mdp_kms.h"
|
|
|
|
static struct csc_cfg csc_convert[CSC_MAX] = {
|
|
[CSC_RGB2RGB] = {
|
|
.type = CSC_RGB2RGB,
|
|
.matrix = {
|
|
0x0200, 0x0000, 0x0000,
|
|
0x0000, 0x0200, 0x0000,
|
|
0x0000, 0x0000, 0x0200
|
|
},
|
|
.pre_bias = { 0x0, 0x0, 0x0 },
|
|
.post_bias = { 0x0, 0x0, 0x0 },
|
|
.pre_clamp = { 0x0, 0xff, 0x0, 0xff, 0x0, 0xff },
|
|
.post_clamp = { 0x0, 0xff, 0x0, 0xff, 0x0, 0xff },
|
|
},
|
|
[CSC_YUV2RGB] = {
|
|
.type = CSC_YUV2RGB,
|
|
.matrix = {
|
|
0x0254, 0x0000, 0x0331,
|
|
0x0254, 0xff37, 0xfe60,
|
|
0x0254, 0x0409, 0x0000
|
|
},
|
|
.pre_bias = { 0xfff0, 0xff80, 0xff80 },
|
|
.post_bias = { 0x00, 0x00, 0x00 },
|
|
.pre_clamp = { 0x00, 0xff, 0x00, 0xff, 0x00, 0xff },
|
|
.post_clamp = { 0x00, 0xff, 0x00, 0xff, 0x00, 0xff },
|
|
},
|
|
[CSC_RGB2YUV] = {
|
|
.type = CSC_RGB2YUV,
|
|
.matrix = {
|
|
0x0083, 0x0102, 0x0032,
|
|
0x1fb5, 0x1f6c, 0x00e1,
|
|
0x00e1, 0x1f45, 0x1fdc
|
|
},
|
|
.pre_bias = { 0x00, 0x00, 0x00 },
|
|
.post_bias = { 0x10, 0x80, 0x80 },
|
|
.pre_clamp = { 0x00, 0xff, 0x00, 0xff, 0x00, 0xff },
|
|
.post_clamp = { 0x10, 0xeb, 0x10, 0xf0, 0x10, 0xf0 },
|
|
},
|
|
[CSC_YUV2YUV] = {
|
|
.type = CSC_YUV2YUV,
|
|
.matrix = {
|
|
0x0200, 0x0000, 0x0000,
|
|
0x0000, 0x0200, 0x0000,
|
|
0x0000, 0x0000, 0x0200
|
|
},
|
|
.pre_bias = { 0x00, 0x00, 0x00 },
|
|
.post_bias = { 0x00, 0x00, 0x00 },
|
|
.pre_clamp = { 0x00, 0xff, 0x00, 0xff, 0x00, 0xff },
|
|
.post_clamp = { 0x00, 0xff, 0x00, 0xff, 0x00, 0xff },
|
|
},
|
|
};
|
|
|
|
#define MDP_TILE_HEIGHT_DEFAULT 1
|
|
#define MDP_TILE_HEIGHT_UBWC 4
|
|
#define MDP_TILE_HEIGHT_NV12 8
|
|
|
|
#define INTERLEAVED_RGB_FMT(fmt, a, r, g, b, e0, e1, e2, e3, uc, alpha, \
|
|
bp, flg, fm, np) \
|
|
{ \
|
|
.pixel_format = DRM_FORMAT_ ## fmt, \
|
|
.fetch_type = MDP_PLANE_INTERLEAVED, \
|
|
.alpha_enable = alpha, \
|
|
.element = { (e0), (e1), (e2), (e3) }, \
|
|
.bpc_g_y = g, \
|
|
.bpc_b_cb = b, \
|
|
.bpc_r_cr = r, \
|
|
.bpc_a = a, \
|
|
.chroma_sample = CHROMA_FULL, \
|
|
.unpack_count = uc, \
|
|
.bpp = bp, \
|
|
.fetch_mode = fm, \
|
|
.flags = MSM_FORMAT_FLAG_UNPACK_TIGHT | flg, \
|
|
.num_planes = np, \
|
|
.tile_height = MDP_TILE_HEIGHT_DEFAULT \
|
|
}
|
|
|
|
#define INTERLEAVED_RGB_FMT_TILED(fmt, a, r, g, b, e0, e1, e2, e3, uc, \
|
|
alpha, bp, flg, fm, np, th) \
|
|
{ \
|
|
.pixel_format = DRM_FORMAT_ ## fmt, \
|
|
.fetch_type = MDP_PLANE_INTERLEAVED, \
|
|
.alpha_enable = alpha, \
|
|
.element = { (e0), (e1), (e2), (e3) }, \
|
|
.bpc_g_y = g, \
|
|
.bpc_b_cb = b, \
|
|
.bpc_r_cr = r, \
|
|
.bpc_a = a, \
|
|
.chroma_sample = CHROMA_FULL, \
|
|
.unpack_count = uc, \
|
|
.bpp = bp, \
|
|
.fetch_mode = fm, \
|
|
.flags = MSM_FORMAT_FLAG_UNPACK_TIGHT | flg, \
|
|
.num_planes = np, \
|
|
.tile_height = th \
|
|
}
|
|
|
|
#define INTERLEAVED_YUV_FMT(fmt, a, r, g, b, e0, e1, e2, e3, \
|
|
alpha, chroma, count, bp, flg, fm, np) \
|
|
{ \
|
|
.pixel_format = DRM_FORMAT_ ## fmt, \
|
|
.fetch_type = MDP_PLANE_INTERLEAVED, \
|
|
.alpha_enable = alpha, \
|
|
.element = { (e0), (e1), (e2), (e3)}, \
|
|
.bpc_g_y = g, \
|
|
.bpc_b_cb = b, \
|
|
.bpc_r_cr = r, \
|
|
.bpc_a = a, \
|
|
.chroma_sample = chroma, \
|
|
.unpack_count = count, \
|
|
.bpp = bp, \
|
|
.fetch_mode = fm, \
|
|
.flags = MSM_FORMAT_FLAG_UNPACK_TIGHT | flg, \
|
|
.num_planes = np, \
|
|
.tile_height = MDP_TILE_HEIGHT_DEFAULT \
|
|
}
|
|
|
|
#define PSEUDO_YUV_FMT(fmt, a, r, g, b, e0, e1, chroma, flg, fm, np) \
|
|
{ \
|
|
.pixel_format = DRM_FORMAT_ ## fmt, \
|
|
.fetch_type = MDP_PLANE_PSEUDO_PLANAR, \
|
|
.alpha_enable = 0, \
|
|
.element = { (e0), (e1), 0, 0 }, \
|
|
.bpc_g_y = g, \
|
|
.bpc_b_cb = b, \
|
|
.bpc_r_cr = r, \
|
|
.bpc_a = a, \
|
|
.chroma_sample = chroma, \
|
|
.unpack_count = 2, \
|
|
.bpp = 2, \
|
|
.fetch_mode = fm, \
|
|
.flags = MSM_FORMAT_FLAG_UNPACK_TIGHT | flg, \
|
|
.num_planes = np, \
|
|
.tile_height = MDP_TILE_HEIGHT_DEFAULT \
|
|
}
|
|
|
|
#define PSEUDO_YUV_FMT_TILED(fmt, a, r, g, b, e0, e1, chroma, \
|
|
flg, fm, np, th) \
|
|
{ \
|
|
.pixel_format = DRM_FORMAT_ ## fmt, \
|
|
.fetch_type = MDP_PLANE_PSEUDO_PLANAR, \
|
|
.alpha_enable = 0, \
|
|
.element = { (e0), (e1), 0, 0 }, \
|
|
.bpc_g_y = g, \
|
|
.bpc_b_cb = b, \
|
|
.bpc_r_cr = r, \
|
|
.bpc_a = a, \
|
|
.chroma_sample = chroma, \
|
|
.unpack_count = 2, \
|
|
.bpp = 2, \
|
|
.fetch_mode = fm, \
|
|
.flags = MSM_FORMAT_FLAG_UNPACK_TIGHT | flg, \
|
|
.num_planes = np, \
|
|
.tile_height = th \
|
|
}
|
|
|
|
#define PSEUDO_YUV_FMT_LOOSE(fmt, a, r, g, b, e0, e1, chroma, flg, fm, np)\
|
|
{ \
|
|
.pixel_format = DRM_FORMAT_ ## fmt, \
|
|
.fetch_type = MDP_PLANE_PSEUDO_PLANAR, \
|
|
.alpha_enable = 0, \
|
|
.element = { (e0), (e1), 0, 0 }, \
|
|
.bpc_g_y = g, \
|
|
.bpc_b_cb = b, \
|
|
.bpc_r_cr = r, \
|
|
.bpc_a = a, \
|
|
.chroma_sample = chroma, \
|
|
.unpack_count = 2, \
|
|
.bpp = 2, \
|
|
.fetch_mode = fm, \
|
|
.flags = MSM_FORMAT_FLAG_UNPACK_ALIGN_MSB | flg, \
|
|
.num_planes = np, \
|
|
.tile_height = MDP_TILE_HEIGHT_DEFAULT \
|
|
}
|
|
|
|
#define PSEUDO_YUV_FMT_LOOSE_TILED(fmt, a, r, g, b, e0, e1, chroma, \
|
|
flg, fm, np, th) \
|
|
{ \
|
|
.pixel_format = DRM_FORMAT_ ## fmt, \
|
|
.fetch_type = MDP_PLANE_PSEUDO_PLANAR, \
|
|
.alpha_enable = 0, \
|
|
.element = { (e0), (e1), 0, 0 }, \
|
|
.bpc_g_y = g, \
|
|
.bpc_b_cb = b, \
|
|
.bpc_r_cr = r, \
|
|
.bpc_a = a, \
|
|
.chroma_sample = chroma, \
|
|
.unpack_count = 2, \
|
|
.bpp = 2, \
|
|
.fetch_mode = fm, \
|
|
.flags = MSM_FORMAT_FLAG_UNPACK_ALIGN_MSB | flg, \
|
|
.num_planes = np, \
|
|
.tile_height = th \
|
|
}
|
|
|
|
#define PLANAR_YUV_FMT(fmt, a, r, g, b, e0, e1, e2, alpha, chroma, bp, \
|
|
flg, fm, np) \
|
|
{ \
|
|
.pixel_format = DRM_FORMAT_ ## fmt, \
|
|
.fetch_type = MDP_PLANE_PLANAR, \
|
|
.alpha_enable = alpha, \
|
|
.element = { (e0), (e1), (e2), 0 }, \
|
|
.bpc_g_y = g, \
|
|
.bpc_b_cb = b, \
|
|
.bpc_r_cr = r, \
|
|
.bpc_a = a, \
|
|
.chroma_sample = chroma, \
|
|
.unpack_count = 1, \
|
|
.bpp = bp, \
|
|
.fetch_mode = fm, \
|
|
.flags = MSM_FORMAT_FLAG_UNPACK_TIGHT | flg, \
|
|
.num_planes = np, \
|
|
.tile_height = MDP_TILE_HEIGHT_DEFAULT \
|
|
}
|
|
|
|
static const struct msm_format mdp_formats[] = {
|
|
INTERLEAVED_RGB_FMT(ARGB8888,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C1_B_Cb, C0_G_Y, C2_R_Cr, C3_ALPHA, 4,
|
|
true, 4, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(ABGR8888,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, C3_ALPHA, 4,
|
|
true, 4, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(XBGR8888,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, C3_ALPHA, 4,
|
|
false, 4, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(RGBA8888,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C3_ALPHA, C1_B_Cb, C0_G_Y, C2_R_Cr, 4,
|
|
true, 4, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(BGRA8888,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C3_ALPHA, C2_R_Cr, C0_G_Y, C1_B_Cb, 4,
|
|
true, 4, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(BGRX8888,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C3_ALPHA, C2_R_Cr, C0_G_Y, C1_B_Cb, 4,
|
|
false, 4, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(XRGB8888,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C1_B_Cb, C0_G_Y, C2_R_Cr, C3_ALPHA, 4,
|
|
false, 4, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(RGBX8888,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C3_ALPHA, C1_B_Cb, C0_G_Y, C2_R_Cr, 4,
|
|
false, 4, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(RGB888,
|
|
0, BPC8, BPC8, BPC8,
|
|
C1_B_Cb, C0_G_Y, C2_R_Cr, 0, 3,
|
|
false, 3, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(BGR888,
|
|
0, BPC8, BPC8, BPC8,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, 0, 3,
|
|
false, 3, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(RGB565,
|
|
0, BPC5, BPC6, BPC5,
|
|
C1_B_Cb, C0_G_Y, C2_R_Cr, 0, 3,
|
|
false, 2, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(BGR565,
|
|
0, BPC5, BPC6, BPC5,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, 0, 3,
|
|
false, 2, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(ARGB1555,
|
|
BPC1A, BPC5, BPC5, BPC5,
|
|
C1_B_Cb, C0_G_Y, C2_R_Cr, C3_ALPHA, 4,
|
|
true, 2, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(ABGR1555,
|
|
BPC1A, BPC5, BPC5, BPC5,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, C3_ALPHA, 4,
|
|
true, 2, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(RGBA5551,
|
|
BPC1A, BPC5, BPC5, BPC5,
|
|
C3_ALPHA, C1_B_Cb, C0_G_Y, C2_R_Cr, 4,
|
|
true, 2, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(BGRA5551,
|
|
BPC1A, BPC5, BPC5, BPC5,
|
|
C3_ALPHA, C2_R_Cr, C0_G_Y, C1_B_Cb, 4,
|
|
true, 2, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(XRGB1555,
|
|
BPC1A, BPC5, BPC5, BPC5,
|
|
C1_B_Cb, C0_G_Y, C2_R_Cr, C3_ALPHA, 4,
|
|
false, 2, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(XBGR1555,
|
|
BPC1A, BPC5, BPC5, BPC5,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, C3_ALPHA, 4,
|
|
false, 2, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(RGBX5551,
|
|
BPC1A, BPC5, BPC5, BPC5,
|
|
C3_ALPHA, C1_B_Cb, C0_G_Y, C2_R_Cr, 4,
|
|
false, 2, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(BGRX5551,
|
|
BPC1A, BPC5, BPC5, BPC5,
|
|
C3_ALPHA, C2_R_Cr, C0_G_Y, C1_B_Cb, 4,
|
|
false, 2, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(ARGB4444,
|
|
BPC4A, BPC4, BPC4, BPC4,
|
|
C1_B_Cb, C0_G_Y, C2_R_Cr, C3_ALPHA, 4,
|
|
true, 2, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(ABGR4444,
|
|
BPC4A, BPC4, BPC4, BPC4,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, C3_ALPHA, 4,
|
|
true, 2, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(RGBA4444,
|
|
BPC4A, BPC4, BPC4, BPC4,
|
|
C3_ALPHA, C1_B_Cb, C0_G_Y, C2_R_Cr, 4,
|
|
true, 2, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(BGRA4444,
|
|
BPC4A, BPC4, BPC4, BPC4,
|
|
C3_ALPHA, C2_R_Cr, C0_G_Y, C1_B_Cb, 4,
|
|
true, 2, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(XRGB4444,
|
|
BPC4A, BPC4, BPC4, BPC4,
|
|
C1_B_Cb, C0_G_Y, C2_R_Cr, C3_ALPHA, 4,
|
|
false, 2, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(XBGR4444,
|
|
BPC4A, BPC4, BPC4, BPC4,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, C3_ALPHA, 4,
|
|
false, 2, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(RGBX4444,
|
|
BPC4A, BPC4, BPC4, BPC4,
|
|
C3_ALPHA, C1_B_Cb, C0_G_Y, C2_R_Cr, 4,
|
|
false, 2, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(BGRX4444,
|
|
BPC4A, BPC4, BPC4, BPC4,
|
|
C3_ALPHA, C2_R_Cr, C0_G_Y, C1_B_Cb, 4,
|
|
false, 2, 0,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(BGRA1010102,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C3_ALPHA, C2_R_Cr, C0_G_Y, C1_B_Cb, 4,
|
|
true, 4, MSM_FORMAT_FLAG_DX,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(RGBA1010102,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C3_ALPHA, C1_B_Cb, C0_G_Y, C2_R_Cr, 4,
|
|
true, 4, MSM_FORMAT_FLAG_DX,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(ABGR2101010,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, C3_ALPHA, 4,
|
|
true, 4, MSM_FORMAT_FLAG_DX,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(ARGB2101010,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C1_B_Cb, C0_G_Y, C2_R_Cr, C3_ALPHA, 4,
|
|
true, 4, MSM_FORMAT_FLAG_DX,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(XRGB2101010,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C1_B_Cb, C0_G_Y, C2_R_Cr, C3_ALPHA, 4,
|
|
false, 4, MSM_FORMAT_FLAG_DX,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(BGRX1010102,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C3_ALPHA, C2_R_Cr, C0_G_Y, C1_B_Cb, 4,
|
|
false, 4, MSM_FORMAT_FLAG_DX,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(XBGR2101010,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, C3_ALPHA, 4,
|
|
false, 4, MSM_FORMAT_FLAG_DX,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
INTERLEAVED_RGB_FMT(RGBX1010102,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C3_ALPHA, C1_B_Cb, C0_G_Y, C2_R_Cr, 4,
|
|
false, 4, MSM_FORMAT_FLAG_DX,
|
|
MDP_FETCH_LINEAR, 1),
|
|
|
|
/* --- RGB formats above / YUV formats below this line --- */
|
|
|
|
/* 2 plane YUV */
|
|
PSEUDO_YUV_FMT(NV12,
|
|
0, BPC8, BPC8, BPC8,
|
|
C1_B_Cb, C2_R_Cr,
|
|
CHROMA_420, MSM_FORMAT_FLAG_YUV,
|
|
MDP_FETCH_LINEAR, 2),
|
|
|
|
PSEUDO_YUV_FMT(NV21,
|
|
0, BPC8, BPC8, BPC8,
|
|
C2_R_Cr, C1_B_Cb,
|
|
CHROMA_420, MSM_FORMAT_FLAG_YUV,
|
|
MDP_FETCH_LINEAR, 2),
|
|
|
|
PSEUDO_YUV_FMT(NV16,
|
|
0, BPC8, BPC8, BPC8,
|
|
C1_B_Cb, C2_R_Cr,
|
|
CHROMA_H2V1, MSM_FORMAT_FLAG_YUV,
|
|
MDP_FETCH_LINEAR, 2),
|
|
|
|
PSEUDO_YUV_FMT(NV61,
|
|
0, BPC8, BPC8, BPC8,
|
|
C2_R_Cr, C1_B_Cb,
|
|
CHROMA_H2V1, MSM_FORMAT_FLAG_YUV,
|
|
MDP_FETCH_LINEAR, 2),
|
|
|
|
PSEUDO_YUV_FMT_LOOSE(P010,
|
|
0, BPC8, BPC8, BPC8,
|
|
C1_B_Cb, C2_R_Cr,
|
|
CHROMA_420, MSM_FORMAT_FLAG_DX | MSM_FORMAT_FLAG_YUV,
|
|
MDP_FETCH_LINEAR, 2),
|
|
|
|
/* 1 plane YUV */
|
|
INTERLEAVED_YUV_FMT(VYUY,
|
|
0, BPC8, BPC8, BPC8,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, C0_G_Y,
|
|
false, CHROMA_H2V1, 4, 2, MSM_FORMAT_FLAG_YUV,
|
|
MDP_FETCH_LINEAR, 2),
|
|
|
|
INTERLEAVED_YUV_FMT(UYVY,
|
|
0, BPC8, BPC8, BPC8,
|
|
C1_B_Cb, C0_G_Y, C2_R_Cr, C0_G_Y,
|
|
false, CHROMA_H2V1, 4, 2, MSM_FORMAT_FLAG_YUV,
|
|
MDP_FETCH_LINEAR, 2),
|
|
|
|
INTERLEAVED_YUV_FMT(YUYV,
|
|
0, BPC8, BPC8, BPC8,
|
|
C0_G_Y, C1_B_Cb, C0_G_Y, C2_R_Cr,
|
|
false, CHROMA_H2V1, 4, 2, MSM_FORMAT_FLAG_YUV,
|
|
MDP_FETCH_LINEAR, 2),
|
|
|
|
INTERLEAVED_YUV_FMT(YVYU,
|
|
0, BPC8, BPC8, BPC8,
|
|
C0_G_Y, C2_R_Cr, C0_G_Y, C1_B_Cb,
|
|
false, CHROMA_H2V1, 4, 2, MSM_FORMAT_FLAG_YUV,
|
|
MDP_FETCH_LINEAR, 2),
|
|
|
|
/* 3 plane YUV */
|
|
PLANAR_YUV_FMT(YUV420,
|
|
0, BPC8, BPC8, BPC8,
|
|
C2_R_Cr, C1_B_Cb, C0_G_Y,
|
|
false, CHROMA_420, 1, MSM_FORMAT_FLAG_YUV,
|
|
MDP_FETCH_LINEAR, 3),
|
|
|
|
PLANAR_YUV_FMT(YVU420,
|
|
0, BPC8, BPC8, BPC8,
|
|
C1_B_Cb, C2_R_Cr, C0_G_Y,
|
|
false, CHROMA_420, 1, MSM_FORMAT_FLAG_YUV,
|
|
MDP_FETCH_LINEAR, 3),
|
|
};
|
|
|
|
/*
|
|
* UBWC formats table:
|
|
* This table holds the UBWC formats supported.
|
|
* If a compression ratio needs to be used for this or any other format,
|
|
* the data will be passed by user-space.
|
|
*/
|
|
static const struct msm_format mdp_formats_ubwc[] = {
|
|
INTERLEAVED_RGB_FMT_TILED(BGR565,
|
|
0, BPC5, BPC6, BPC5,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, 0, 3,
|
|
false, 2, MSM_FORMAT_FLAG_COMPRESSED,
|
|
MDP_FETCH_UBWC, 2, MDP_TILE_HEIGHT_UBWC),
|
|
|
|
INTERLEAVED_RGB_FMT_TILED(ABGR8888,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, C3_ALPHA, 4,
|
|
true, 4, MSM_FORMAT_FLAG_COMPRESSED,
|
|
MDP_FETCH_UBWC, 2, MDP_TILE_HEIGHT_UBWC),
|
|
|
|
/* ARGB8888 and ABGR8888 purposely have the same color
|
|
* ordering. The hardware only supports ABGR8888 UBWC
|
|
* natively.
|
|
*/
|
|
INTERLEAVED_RGB_FMT_TILED(ARGB8888,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, C3_ALPHA, 4,
|
|
true, 4, MSM_FORMAT_FLAG_COMPRESSED,
|
|
MDP_FETCH_UBWC, 2, MDP_TILE_HEIGHT_UBWC),
|
|
|
|
INTERLEAVED_RGB_FMT_TILED(XBGR8888,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, C3_ALPHA, 4,
|
|
false, 4, MSM_FORMAT_FLAG_COMPRESSED,
|
|
MDP_FETCH_UBWC, 2, MDP_TILE_HEIGHT_UBWC),
|
|
|
|
INTERLEAVED_RGB_FMT_TILED(XRGB8888,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, C3_ALPHA, 4,
|
|
false, 4, MSM_FORMAT_FLAG_COMPRESSED,
|
|
MDP_FETCH_UBWC, 2, MDP_TILE_HEIGHT_UBWC),
|
|
|
|
INTERLEAVED_RGB_FMT_TILED(ABGR2101010,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, C3_ALPHA, 4,
|
|
true, 4, MSM_FORMAT_FLAG_DX | MSM_FORMAT_FLAG_COMPRESSED,
|
|
MDP_FETCH_UBWC, 2, MDP_TILE_HEIGHT_UBWC),
|
|
|
|
INTERLEAVED_RGB_FMT_TILED(XBGR2101010,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, C3_ALPHA, 4,
|
|
true, 4, MSM_FORMAT_FLAG_DX | MSM_FORMAT_FLAG_COMPRESSED,
|
|
MDP_FETCH_UBWC, 2, MDP_TILE_HEIGHT_UBWC),
|
|
|
|
INTERLEAVED_RGB_FMT_TILED(XRGB2101010,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, C3_ALPHA, 4,
|
|
true, 4, MSM_FORMAT_FLAG_DX | MSM_FORMAT_FLAG_COMPRESSED,
|
|
MDP_FETCH_UBWC, 2, MDP_TILE_HEIGHT_UBWC),
|
|
|
|
/* XRGB2101010 and ARGB2101010 purposely have the same color
|
|
* ordering. The hardware only supports ARGB2101010 UBWC
|
|
* natively.
|
|
*/
|
|
INTERLEAVED_RGB_FMT_TILED(ARGB2101010,
|
|
BPC8A, BPC8, BPC8, BPC8,
|
|
C2_R_Cr, C0_G_Y, C1_B_Cb, C3_ALPHA, 4,
|
|
true, 4, MSM_FORMAT_FLAG_DX | MSM_FORMAT_FLAG_COMPRESSED,
|
|
MDP_FETCH_UBWC, 2, MDP_TILE_HEIGHT_UBWC),
|
|
|
|
PSEUDO_YUV_FMT_TILED(NV12,
|
|
0, BPC8, BPC8, BPC8,
|
|
C1_B_Cb, C2_R_Cr,
|
|
CHROMA_420, MSM_FORMAT_FLAG_YUV |
|
|
MSM_FORMAT_FLAG_COMPRESSED,
|
|
MDP_FETCH_UBWC, 4, MDP_TILE_HEIGHT_NV12),
|
|
|
|
PSEUDO_YUV_FMT_TILED(P010,
|
|
0, BPC8, BPC8, BPC8,
|
|
C1_B_Cb, C2_R_Cr,
|
|
CHROMA_420, MSM_FORMAT_FLAG_DX |
|
|
MSM_FORMAT_FLAG_YUV |
|
|
MSM_FORMAT_FLAG_COMPRESSED,
|
|
MDP_FETCH_UBWC, 4, MDP_TILE_HEIGHT_UBWC),
|
|
};
|
|
|
|
const struct msm_format *mdp_get_format(struct msm_kms *kms, uint32_t format,
|
|
uint64_t modifier)
|
|
{
|
|
const struct msm_format *map = NULL;
|
|
ssize_t map_size;
|
|
int i;
|
|
|
|
switch (modifier) {
|
|
case 0:
|
|
map = mdp_formats;
|
|
map_size = ARRAY_SIZE(mdp_formats);
|
|
break;
|
|
case DRM_FORMAT_MOD_QCOM_COMPRESSED:
|
|
map = mdp_formats_ubwc;
|
|
map_size = ARRAY_SIZE(mdp_formats_ubwc);
|
|
break;
|
|
default:
|
|
drm_err(kms->dev, "unsupported format modifier %llX\n", modifier);
|
|
return NULL;
|
|
}
|
|
|
|
for (i = 0; i < map_size; i++) {
|
|
const struct msm_format *f = &map[i];
|
|
|
|
if (f->pixel_format == format)
|
|
return f;
|
|
}
|
|
|
|
drm_err(kms->dev, "unsupported fmt: %p4cc modifier 0x%llX\n",
|
|
&format, modifier);
|
|
|
|
return NULL;
|
|
}
|
|
|
|
struct csc_cfg *mdp_get_default_csc_cfg(enum csc_type type)
|
|
{
|
|
if (WARN_ON(type >= CSC_MAX))
|
|
return NULL;
|
|
|
|
return &csc_convert[type];
|
|
}
|