Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit eeb14ec8 authored by Philipp Zabel's avatar Philipp Zabel Committed by Greg Kroah-Hartman
Browse files

staging: drm/imx: ipu-dc: add 24-bit GBR support to DC



24-bit GBR order is needed on the display interface connected
to the Television Encoder (TVEv2) on i.MX53.

Signed-off-by: default avatarPhilipp Zabel <p.zabel@pengutronix.de>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent 3d2409d4
Loading
Loading
Loading
Loading
+10 −0
Original line number Original line Diff line number Diff line
#ifndef _IMX_DRM_H_
#ifndef _IMX_DRM_H_
#define _IMX_DRM_H_
#define _IMX_DRM_H_


#include <linux/videodev2.h>

#define IPU_PIX_FMT_GBR24	v4l2_fourcc('G', 'B', 'R', '3')

struct drm_crtc;
struct drm_connector;
struct drm_device;
struct drm_encoder;
struct imx_drm_crtc;
struct imx_drm_crtc;
struct drm_fbdev_cma;
struct drm_fbdev_cma;
struct drm_framebuffer;
struct platform_device;


struct imx_drm_crtc_helper_funcs {
struct imx_drm_crtc_helper_funcs {
	int (*enable_vblank)(struct drm_crtc *crtc);
	int (*enable_vblank)(struct drm_crtc *crtc);
+10 −0
Original line number Original line Diff line number Diff line
@@ -20,6 +20,7 @@
#include <linux/delay.h>
#include <linux/delay.h>
#include <linux/io.h>
#include <linux/io.h>


#include "../imx-drm.h"
#include "imx-ipu-v3.h"
#include "imx-ipu-v3.h"
#include "ipu-prv.h"
#include "ipu-prv.h"


@@ -86,6 +87,7 @@ struct ipu_dc_priv;
enum ipu_dc_map {
enum ipu_dc_map {
	IPU_DC_MAP_RGB24,
	IPU_DC_MAP_RGB24,
	IPU_DC_MAP_RGB565,
	IPU_DC_MAP_RGB565,
	IPU_DC_MAP_GBR24, /* TVEv2 */
};
};


struct ipu_dc {
struct ipu_dc {
@@ -136,6 +138,8 @@ static int ipu_pixfmt_to_map(u32 fmt)
		return IPU_DC_MAP_RGB24;
		return IPU_DC_MAP_RGB24;
	case V4L2_PIX_FMT_RGB565:
	case V4L2_PIX_FMT_RGB565:
		return IPU_DC_MAP_RGB565;
		return IPU_DC_MAP_RGB565;
	case IPU_PIX_FMT_GBR24:
		return IPU_DC_MAP_GBR24;
	default:
	default:
		return -EINVAL;
		return -EINVAL;
	}
	}
@@ -364,6 +368,12 @@ int ipu_dc_init(struct ipu_soc *ipu, struct device *dev,
	ipu_dc_map_config(priv, IPU_DC_MAP_RGB565, 1, 10, 0xfc); /* green */
	ipu_dc_map_config(priv, IPU_DC_MAP_RGB565, 1, 10, 0xfc); /* green */
	ipu_dc_map_config(priv, IPU_DC_MAP_RGB565, 2, 15, 0xf8); /* red */
	ipu_dc_map_config(priv, IPU_DC_MAP_RGB565, 2, 15, 0xf8); /* red */


	/* gbr24 */
	ipu_dc_map_clear(priv, IPU_DC_MAP_GBR24);
	ipu_dc_map_config(priv, IPU_DC_MAP_GBR24, 2, 15, 0xff); /* green */
	ipu_dc_map_config(priv, IPU_DC_MAP_GBR24, 1, 7, 0xff); /* blue */
	ipu_dc_map_config(priv, IPU_DC_MAP_GBR24, 0, 23, 0xff); /* red */

	return 0;
	return 0;
}
}