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