blob: bb4aec056c6cd4f8ac721756289ac6d8b062b767 [file] [log] [blame]
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -07001#ifndef __MSM_ROTATOR_H__
Kobi Cohen Arazi18b04782011-07-26 12:11:34 -07002#define __MSM_ROTATOR_H__
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -07003
4#include <linux/types.h>
5#include <linux/msm_mdp.h>
6
7#define MSM_ROTATOR_IOCTL_MAGIC 'R'
8
9#define MSM_ROTATOR_IOCTL_START \
10 _IOWR(MSM_ROTATOR_IOCTL_MAGIC, 1, struct msm_rotator_img_info)
11#define MSM_ROTATOR_IOCTL_ROTATE \
12 _IOW(MSM_ROTATOR_IOCTL_MAGIC, 2, struct msm_rotator_data_info)
13#define MSM_ROTATOR_IOCTL_FINISH \
14 _IOW(MSM_ROTATOR_IOCTL_MAGIC, 3, int)
Ken Zhanga50db542013-02-20 14:48:06 -050015#define MSM_ROTATOR_IOCTL_BUFFER_SYNC \
16 _IOW(MSM_ROTATOR_IOCTL_MAGIC, 4, struct msm_rotator_buf_sync)
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070017
18#define ROTATOR_VERSION_01 0xA5B4C301
19
20enum rotator_clk_type {
21 ROTATOR_CORE_CLK,
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070022 ROTATOR_PCLK,
23 ROTATOR_IMEM_CLK
24};
25
Ken Zhanga50db542013-02-20 14:48:06 -050026struct msm_rotator_buf_sync {
27 uint32_t session_id;
28 uint32_t flags;
29 int acq_fen_fd;
30 int rel_fen_fd;
31};
32
Padmanabhan Komanduru3dfc4312013-04-12 17:22:00 +053033struct rot_buf_type {
34 struct ion_handle *ihdl;
35 uint32_t write_addr;
36 uint32_t read_addr;
37};
38
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070039struct msm_rotator_img_info {
40 unsigned int session_id;
41 struct msmfb_img src;
42 struct msmfb_img dst;
43 struct mdp_rect src_rect;
44 unsigned int dst_x;
45 unsigned int dst_y;
46 unsigned char rotations;
47 int enable;
Adrian Salido-Moreno67273e52011-10-21 19:04:18 -070048 unsigned int downscale_ratio;
Ravishangar Kalyanam1eca3522012-05-31 18:02:24 -070049 unsigned int secure;
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070050};
51
52struct msm_rotator_data_info {
53 int session_id;
54 struct msmfb_data src;
55 struct msmfb_data dst;
56 unsigned int version_key;
57 struct msmfb_data src_chroma;
58 struct msmfb_data dst_chroma;
Ken Zhang93b9f9a2013-04-08 18:56:58 -040059 uint32_t wait_for_finish;
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070060};
61
62struct msm_rot_clocks {
63 const char *clk_name;
64 enum rotator_clk_type clk_type;
65 unsigned int clk_rate;
66};
67
68struct msm_rotator_platform_data {
69 unsigned int number_of_clocks;
70 unsigned int hardware_version_number;
71 struct msm_rot_clocks *rotator_clks;
Nagamalleswararao Ganji5fabbd62011-11-06 23:10:43 -080072#ifdef CONFIG_MSM_BUS_SCALING
73 struct msm_bus_scale_pdata *bus_scale_table;
74#endif
Olav Hauganef95ae32012-05-15 09:50:30 -070075 char rot_iommu_split_domain;
Bryan Huntsman3f2bc4d2011-08-16 17:27:22 -070076};
77#endif
78