1 /* SPDX-License-Identifier: GPL-2.0+ */
3 * Copyright (C) 2019-2022 Bootlin
7 #ifndef _LOGICVC_LAYER_H_
8 #define _LOGICVC_LAYER_H_
11 #include <linux/types.h>
12 #include <drm/drm_plane.h>
14 #define LOGICVC_LAYER_COLORSPACE_RGB 0
15 #define LOGICVC_LAYER_COLORSPACE_YUV 1
17 #define LOGICVC_LAYER_ALPHA_LAYER 0
18 #define LOGICVC_LAYER_ALPHA_PIXEL 1
20 struct logicvc_layer_buffer_setup {
26 struct logicvc_layer_config {
35 struct logicvc_layer_formats {
42 struct logicvc_layer {
43 struct logicvc_layer_config config;
44 struct logicvc_layer_formats *formats;
45 struct device_node *of_node;
47 struct drm_plane drm_plane;
48 struct list_head list;
52 int logicvc_layer_buffer_find_setup(struct logicvc_drm *logicvc,
53 struct logicvc_layer *layer,
54 struct drm_plane_state *state,
55 struct logicvc_layer_buffer_setup *setup);
56 struct logicvc_layer *logicvc_layer_get_from_index(struct logicvc_drm *logicvc,
58 struct logicvc_layer *logicvc_layer_get_from_type(struct logicvc_drm *logicvc,
59 enum drm_plane_type type);
60 struct logicvc_layer *logicvc_layer_get_primary(struct logicvc_drm *logicvc);
61 void logicvc_layers_attach_crtc(struct logicvc_drm *logicvc);
62 int logicvc_layers_init(struct logicvc_drm *logicvc);