1
2
3
4
5
6
7
8
9 #include <linux/platform_device.h>
10 #include <media/v4l2-device.h>
11 #include <media/v4l2-ctrls.h>
12
13 #define G2D_NAME "s5p-g2d"
14 #define TYPE_G2D_3X 3
15 #define TYPE_G2D_4X 4
16
17 struct g2d_dev {
18 struct v4l2_device v4l2_dev;
19 struct v4l2_m2m_dev *m2m_dev;
20 struct video_device *vfd;
21 struct mutex mutex;
22 spinlock_t ctrl_lock;
23 atomic_t num_inst;
24 void __iomem *regs;
25 struct clk *clk;
26 struct clk *gate;
27 struct g2d_ctx *curr;
28 struct g2d_variant *variant;
29 int irq;
30 };
31
32 struct g2d_frame {
33
34 u32 width;
35 u32 height;
36
37 u32 c_width;
38 u32 c_height;
39
40 u32 o_width;
41 u32 o_height;
42
43 struct g2d_fmt *fmt;
44
45 u32 stride;
46 u32 bottom;
47 u32 right;
48 u32 size;
49 };
50
51 struct g2d_ctx {
52 struct v4l2_fh fh;
53 struct g2d_dev *dev;
54 struct g2d_frame in;
55 struct g2d_frame out;
56 struct v4l2_ctrl *ctrl_hflip;
57 struct v4l2_ctrl *ctrl_vflip;
58 struct v4l2_ctrl_handler ctrl_handler;
59 u32 rop;
60 u32 flip;
61 };
62
63 struct g2d_fmt {
64 u32 fourcc;
65 int depth;
66 u32 hw;
67 };
68
69 struct g2d_variant {
70 unsigned short hw_rev;
71 };
72
73 void g2d_reset(struct g2d_dev *d);
74 void g2d_set_src_size(struct g2d_dev *d, struct g2d_frame *f);
75 void g2d_set_src_addr(struct g2d_dev *d, dma_addr_t a);
76 void g2d_set_dst_size(struct g2d_dev *d, struct g2d_frame *f);
77 void g2d_set_dst_addr(struct g2d_dev *d, dma_addr_t a);
78 void g2d_start(struct g2d_dev *d);
79 void g2d_clear_int(struct g2d_dev *d);
80 void g2d_set_rop4(struct g2d_dev *d, u32 r);
81 void g2d_set_flip(struct g2d_dev *d, u32 r);
82 void g2d_set_v41_stretch(struct g2d_dev *d,
83 struct g2d_frame *src, struct g2d_frame *dst);
84 void g2d_set_cmd(struct g2d_dev *d, u32 c);