Contributors: 14
Author Tokens Token Proportion Commits Commit Proportion
Jeykumar Sankaran 902 32.78% 2 8.33%
Dmitry Eremin-Solenikov 751 27.29% 5 20.83%
Stephane Viau 659 23.95% 3 12.50%
Rob Clark 327 11.88% 3 12.50%
Rob Herring 59 2.14% 1 4.17%
Jessica Zhang 22 0.80% 2 8.33%
Wentao Xu 13 0.47% 1 4.17%
Leonard Lausen 8 0.29% 1 4.17%
Oleksandr Andrushchenko 4 0.15% 1 4.17%
Fritz Koenig 2 0.07% 1 4.17%
Thomas Gleixner 2 0.07% 1 4.17%
Jayant Shekhar 1 0.04% 1 4.17%
Ville Syrjälä 1 0.04% 1 4.17%
Sam Ravnborg 1 0.04% 1 4.17%
Total 2752 24


// 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];
}