#ifndef _MDSS_ROTATOR_H_ #define _MDSS_ROTATOR_H_ #include <linux/msm_mdp_ext.h> #define MDSS_ROTATOR_IOCTL_MAGIC 'w' /* open a rotation session */ #define MDSS_ROTATION_OPEN \ _IOWR(MDSS_ROTATOR_IOCTL_MAGIC, 1, struct mdp_rotation_config *) /* change the rotation session configuration */ #define MDSS_ROTATION_CONFIG \ _IOWR(MDSS_ROTATOR_IOCTL_MAGIC, 2, struct mdp_rotation_config *) /* queue the rotation request */ #define MDSS_ROTATION_REQUEST \ _IOWR(MDSS_ROTATOR_IOCTL_MAGIC, 3, struct mdp_rotation_request *) /* close a rotation session with the specified rotation session ID */ #define MDSS_ROTATION_CLOSE _IOW(MDSS_ROTATOR_IOCTL_MAGIC, 4, unsigned int) /********************************************************************** Rotation request flag **********************************************************************/ /* no rotation flag, i.e. color space conversion */ #define MDP_ROTATION_NOP 0x01 /* left/right flip */ #define MDP_ROTATION_FLIP_LR 0x02 /* up/down flip */ #define MDP_ROTATION_FLIP_UD 0x04 /* rotate 90 degree */ #define MDP_ROTATION_90 0x08 /* rotate 180 degre */ #define MDP_ROTATION_180 (MDP_ROTATION_FLIP_LR | MDP_ROTATION_FLIP_UD) /* rotate 270 degree */ #define MDP_ROTATION_270 (MDP_ROTATION_90 | MDP_ROTATION_180) /* format is interlaced */ #define MDP_ROTATION_DEINTERLACE 0x10 /* enable bwc */ #define MDP_ROTATION_BWC_EN 0x40 /* secure data */ #define MDP_ROTATION_SECURE 0x80 /********************************************************************** Rotation commit flag **********************************************************************/ /* Flag indicates to validate the rotation request */ #define MDSS_ROTATION_REQUEST_VALIDATE 0x01 #define MDP_ROTATION_REQUEST_VERSION_1_0 0x00010000 /* * Client can let driver to allocate the hardware resources with * this particular hw resource id. */ #define MDSS_ROTATION_HW_ANY 0xFFFFFFFF /********************************************************************** configuration structures **********************************************************************/ struct mdp_rotation_buf_info { uint32_t width; uint32_t height; uint32_t format; struct mult_factor comp_ratio; }; struct mdp_rotation_config { uint32_t version; uint32_t session_id; struct mdp_rotation_buf_info input; struct mdp_rotation_buf_info output; uint32_t frame_rate; uint32_t flags; uint32_t reserved[6]; }; struct mdp_rotation_item { /* rotation request flag */ uint32_t flags; /* Source crop rectangle */ struct mdp_rect src_rect; /* Destination rectangle */ struct mdp_rect dst_rect; /* Input buffer for the request */ struct mdp_layer_buffer input; /* The output buffer for the request */ struct mdp_layer_buffer output; /* * DMA pipe selection for this request by client: * 0: DMA pipe 0 * 1: DMA pipe 1 * or MDSS_ROTATION_HW_ANY if client wants * driver to allocate any that is available */ uint32_t pipe_idx; /* * Write-back block selection for this request by client: * 0: Write-back block 0 * 1: Write-back block 1 * or MDSS_ROTATION_HW_ANY if client wants * driver to allocate any that is available */ uint32_t wb_idx; /* Which session ID is this request scheduled on */ uint32_t session_id; /* 32bits reserved value for future usage */ uint32_t reserved[6]; }; struct mdp_rotation_request { /* 32bit version indicates the request structure */ uint32_t version; uint32_t flags; /* Number of rotation request items in the list */ uint32_t count; /* Pointer to a list of rotation request items */ struct mdp_rotation_item *list; /* 32bits reserved value for future usage*/ uint32_t reserved[6]; }; #endif /* _MDSS_ROTATOR_H_*/