192e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling#ifndef __MSM_ROTATOR_H__
292e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling#define __MSM_ROTATOR_H__
392e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling
492e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling#include <linux/types.h>
592e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling#include <linux/msm_mdp.h>
692e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling
792e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling#define MSM_ROTATOR_IOCTL_MAGIC 'R'
892e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling
992e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling#define MSM_ROTATOR_IOCTL_START   \
1092e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling		_IOWR(MSM_ROTATOR_IOCTL_MAGIC, 1, struct msm_rotator_img_info)
1192e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling#define MSM_ROTATOR_IOCTL_ROTATE   \
1292e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling		_IOW(MSM_ROTATOR_IOCTL_MAGIC, 2, struct msm_rotator_data_info)
1392e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling#define MSM_ROTATOR_IOCTL_FINISH   \
1492e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling		_IOW(MSM_ROTATOR_IOCTL_MAGIC, 3, int)
1592e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling
1692e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling#define ROTATOR_VERSION_01	0xA5B4C301
1792e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling
1892e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gillingenum rotator_clk_type {
1992e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	ROTATOR_CORE_CLK,
2092e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	ROTATOR_PCLK,
2192e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	ROTATOR_IMEM_CLK
2292e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling};
2392e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling
2492e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gillingstruct msm_rotator_img_info {
2592e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	unsigned int session_id;
2692e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	struct msmfb_img  src;
2792e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	struct msmfb_img  dst;
2892e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	struct mdp_rect src_rect;
2992e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	unsigned int    dst_x;
3092e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	unsigned int    dst_y;
3192e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	unsigned char   rotations;
3292e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	int enable;
3392e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	unsigned int	downscale_ratio;
3492e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	unsigned int secure;
3592e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling};
3692e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling
3792e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gillingstruct msm_rotator_data_info {
3892e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	int session_id;
3992e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	struct msmfb_data src;
4092e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	struct msmfb_data dst;
4192e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	unsigned int version_key;
4292e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	struct msmfb_data src_chroma;
4392e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	struct msmfb_data dst_chroma;
4492e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling};
4592e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling
4692e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gillingstruct msm_rot_clocks {
4792e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	const char *clk_name;
4892e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	enum rotator_clk_type clk_type;
4992e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	unsigned int clk_rate;
5092e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling};
5192e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling
5292e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gillingstruct msm_rotator_platform_data {
5392e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	unsigned int number_of_clocks;
5492e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	unsigned int hardware_version_number;
5592e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	struct msm_rot_clocks *rotator_clks;
5692e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling#ifdef CONFIG_MSM_BUS_SCALING
5792e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	struct msm_bus_scale_pdata *bus_scale_table;
5892e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling#endif
5992e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling	char rot_iommu_split_domain;
6092e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling};
6192e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling#endif
6292e19fda794d2d9b3a8dcf2301f29b2af4da4b8aErik Gilling
63