2019-05-27 13:55:21 +07:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
2016-01-05 00:36:34 +07:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2015 MediaTek Inc.
|
|
|
|
* Author: CK Hu <ck.hu@mediatek.com>
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _MTK_DRM_PLANE_H_
|
|
|
|
#define _MTK_DRM_PLANE_H_
|
|
|
|
|
|
|
|
#include <drm/drm_crtc.h>
|
|
|
|
#include <linux/types.h>
|
|
|
|
|
|
|
|
struct mtk_plane_pending_state {
|
|
|
|
bool config;
|
|
|
|
bool enable;
|
|
|
|
dma_addr_t addr;
|
|
|
|
unsigned int pitch;
|
|
|
|
unsigned int format;
|
|
|
|
unsigned int x;
|
|
|
|
unsigned int y;
|
|
|
|
unsigned int width;
|
|
|
|
unsigned int height;
|
2019-11-06 04:10:21 +07:00
|
|
|
unsigned int rotation;
|
2016-01-05 00:36:34 +07:00
|
|
|
bool dirty;
|
2019-12-10 12:05:22 +07:00
|
|
|
bool async_dirty;
|
|
|
|
bool async_config;
|
2016-01-05 00:36:34 +07:00
|
|
|
};
|
|
|
|
|
|
|
|
struct mtk_plane_state {
|
|
|
|
struct drm_plane_state base;
|
|
|
|
struct mtk_plane_pending_state pending;
|
|
|
|
};
|
|
|
|
|
|
|
|
static inline struct mtk_plane_state *
|
|
|
|
to_mtk_plane_state(struct drm_plane_state *state)
|
|
|
|
{
|
|
|
|
return container_of(state, struct mtk_plane_state, base);
|
|
|
|
}
|
|
|
|
|
2016-08-04 09:59:53 +07:00
|
|
|
int mtk_plane_init(struct drm_device *dev, struct drm_plane *plane,
|
2019-11-06 04:10:21 +07:00
|
|
|
unsigned long possible_crtcs, enum drm_plane_type type,
|
|
|
|
unsigned int supported_rotations);
|
2016-01-05 00:36:34 +07:00
|
|
|
|
|
|
|
#endif
|