1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
/*
* Xilinx DRM KMS Header for Xilinx
*
* Copyright (C) 2013 Xilinx, Inc.
*
* Author: Hyun Woo Kwon <hyunk@xilinx.com>
*
* This software is licensed under the terms of the GNU General Public
* License version 2, as published by the Free Software Foundation, and
* may be copied, distributed, and modified under those terms.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*/
#ifndef _XILINX_DRM_H_
#define _XILINX_DRM_H_
enum xilinx_video_format {
XILINX_VIDEO_FORMAT_YUV422 = 0,
XILINX_VIDEO_FORMAT_YUV444 = 1,
XILINX_VIDEO_FORMAT_RGB = 2,
XILINX_VIDEO_FORMAT_YUV420 = 3,
XILINX_VIDEO_FORMAT_XRGB = 16,
XILINX_VIDEO_FORMAT_NONE = 32,
};
/* convert the xilinx format to the drm format */
int xilinx_drm_format_by_code(unsigned int xilinx_format, u32 *drm_format);
int xilinx_drm_format_by_name(const char *name, u32 *drm_format);
unsigned int xilinx_drm_format_bpp(u32 drm_format);
unsigned int xilinx_drm_format_depth(u32 drm_format);
/* io write operations */
static inline void xilinx_drm_writel(void __iomem *base, int offset, u32 val)
{
writel(val, base + offset);
}
/* io read operations */
static inline u32 xilinx_drm_readl(void __iomem *base, int offset)
{
return readl(base + offset);
}
static inline void xilinx_drm_clr(void __iomem *base, int offset, u32 clr)
{
xilinx_drm_writel(base, offset, xilinx_drm_readl(base, offset) & ~clr);
}
static inline void xilinx_drm_set(void __iomem *base, int offset, u32 set)
{
xilinx_drm_writel(base, offset, xilinx_drm_readl(base, offset) | set);
}
struct drm_device;
bool xilinx_drm_check_format(struct drm_device *drm, uint32_t fourcc);
uint32_t xilinx_drm_get_format(struct drm_device *drm);
unsigned int xilinx_drm_get_align(struct drm_device *drm);
#endif /* _XILINX_DRM_H_ */
|