blob: db232037f24a0394151d029676ab41fba363db4b [file] [log] [blame]
Kuninori Morimoto0bbce9e2018-07-26 02:37:32 +00001/* SPDX-License-Identifier: GPL-2.0+ */
Laurent Pinchart6d62ef32015-09-07 17:14:58 +03002/*
3 * rcar_du_vsp.h -- R-Car Display Unit VSP-Based Compositor
4 *
5 * Copyright (C) 2015 Renesas Electronics Corporation
6 *
7 * Contact: Laurent Pinchart (laurent.pinchart@ideasonboard.com)
Laurent Pinchart6d62ef32015-09-07 17:14:58 +03008 */
9
10#ifndef __RCAR_DU_VSP_H__
11#define __RCAR_DU_VSP_H__
12
Laurent Pinchart9a47db82018-12-27 11:26:56 +020013#include <drm/drm_plane.h>
Laurent Pinchart6d62ef32015-09-07 17:14:58 +030014
15struct rcar_du_format_info;
16struct rcar_du_vsp;
17
18struct rcar_du_vsp_plane {
19 struct drm_plane plane;
20 struct rcar_du_vsp *vsp;
21 unsigned int index;
22};
23
24struct rcar_du_vsp {
25 unsigned int index;
26 struct device *vsp;
27 struct rcar_du_device *dev;
28 struct rcar_du_vsp_plane *planes;
29 unsigned int num_planes;
30};
31
32static inline struct rcar_du_vsp_plane *to_rcar_vsp_plane(struct drm_plane *p)
33{
34 return container_of(p, struct rcar_du_vsp_plane, plane);
35}
36
37/**
38 * struct rcar_du_vsp_plane_state - Driver-specific plane state
39 * @state: base DRM plane state
40 * @format: information about the pixel format used by the plane
Laurent Pinchartfa5b4112017-05-17 02:20:07 +030041 * @sg_tables: scatter-gather tables for the frame buffer memory
Laurent Pinchart6d62ef32015-09-07 17:14:58 +030042 */
43struct rcar_du_vsp_plane_state {
44 struct drm_plane_state state;
45
46 const struct rcar_du_format_info *format;
Laurent Pinchartfa5b4112017-05-17 02:20:07 +030047 struct sg_table sg_tables[3];
Laurent Pinchart6d62ef32015-09-07 17:14:58 +030048};
49
50static inline struct rcar_du_vsp_plane_state *
51to_rcar_vsp_plane_state(struct drm_plane_state *state)
52{
53 return container_of(state, struct rcar_du_vsp_plane_state, state);
54}
55
56#ifdef CONFIG_DRM_RCAR_VSP
Laurent Pinchart3e813742017-06-26 13:12:01 +030057int rcar_du_vsp_init(struct rcar_du_vsp *vsp, struct device_node *np,
58 unsigned int crtcs);
Laurent Pinchart6d62ef32015-09-07 17:14:58 +030059void rcar_du_vsp_enable(struct rcar_du_crtc *crtc);
60void rcar_du_vsp_disable(struct rcar_du_crtc *crtc);
61void rcar_du_vsp_atomic_begin(struct rcar_du_crtc *crtc);
62void rcar_du_vsp_atomic_flush(struct rcar_du_crtc *crtc);
63#else
Laurent Pinchart3e813742017-06-26 13:12:01 +030064static inline int rcar_du_vsp_init(struct rcar_du_vsp *vsp,
65 struct device_node *np,
66 unsigned int crtcs)
67{
68 return -ENXIO;
69}
Laurent Pinchart6d62ef32015-09-07 17:14:58 +030070static inline void rcar_du_vsp_enable(struct rcar_du_crtc *crtc) { };
71static inline void rcar_du_vsp_disable(struct rcar_du_crtc *crtc) { };
72static inline void rcar_du_vsp_atomic_begin(struct rcar_du_crtc *crtc) { };
73static inline void rcar_du_vsp_atomic_flush(struct rcar_du_crtc *crtc) { };
74#endif
75
76#endif /* __RCAR_DU_VSP_H__ */