mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
3176776cf1
Add support for 2-pass rotator operation for downscaling and 90 degree rotation when rotator operates in fast YUV mode. 2-pass is supported for 420 H2V2 formats. Change-Id: Ib8ce802a5a8aabe10c88422e3b8d82708c5b05d4 Signed-off-by: Padmanabhan Komanduru <pkomandu@codeaurora.org>
78 lines
1.7 KiB
C
78 lines
1.7 KiB
C
#ifndef __MSM_ROTATOR_H__
|
|
#define __MSM_ROTATOR_H__
|
|
|
|
#include <linux/types.h>
|
|
#include <linux/msm_mdp.h>
|
|
|
|
#define MSM_ROTATOR_IOCTL_MAGIC 'R'
|
|
|
|
#define MSM_ROTATOR_IOCTL_START \
|
|
_IOWR(MSM_ROTATOR_IOCTL_MAGIC, 1, struct msm_rotator_img_info)
|
|
#define MSM_ROTATOR_IOCTL_ROTATE \
|
|
_IOW(MSM_ROTATOR_IOCTL_MAGIC, 2, struct msm_rotator_data_info)
|
|
#define MSM_ROTATOR_IOCTL_FINISH \
|
|
_IOW(MSM_ROTATOR_IOCTL_MAGIC, 3, int)
|
|
#define MSM_ROTATOR_IOCTL_BUFFER_SYNC \
|
|
_IOW(MSM_ROTATOR_IOCTL_MAGIC, 4, struct msm_rotator_buf_sync)
|
|
|
|
#define ROTATOR_VERSION_01 0xA5B4C301
|
|
|
|
enum rotator_clk_type {
|
|
ROTATOR_CORE_CLK,
|
|
ROTATOR_PCLK,
|
|
ROTATOR_IMEM_CLK
|
|
};
|
|
|
|
struct msm_rotator_buf_sync {
|
|
uint32_t session_id;
|
|
uint32_t flags;
|
|
int acq_fen_fd;
|
|
int rel_fen_fd;
|
|
};
|
|
|
|
struct rot_buf_type {
|
|
struct ion_handle *ihdl;
|
|
uint32_t write_addr;
|
|
uint32_t read_addr;
|
|
};
|
|
|
|
struct msm_rotator_img_info {
|
|
unsigned int session_id;
|
|
struct msmfb_img src;
|
|
struct msmfb_img dst;
|
|
struct mdp_rect src_rect;
|
|
unsigned int dst_x;
|
|
unsigned int dst_y;
|
|
unsigned char rotations;
|
|
int enable;
|
|
unsigned int downscale_ratio;
|
|
unsigned int secure;
|
|
};
|
|
|
|
struct msm_rotator_data_info {
|
|
int session_id;
|
|
struct msmfb_data src;
|
|
struct msmfb_data dst;
|
|
unsigned int version_key;
|
|
struct msmfb_data src_chroma;
|
|
struct msmfb_data dst_chroma;
|
|
uint32_t wait_for_finish;
|
|
};
|
|
|
|
struct msm_rot_clocks {
|
|
const char *clk_name;
|
|
enum rotator_clk_type clk_type;
|
|
unsigned int clk_rate;
|
|
};
|
|
|
|
struct msm_rotator_platform_data {
|
|
unsigned int number_of_clocks;
|
|
unsigned int hardware_version_number;
|
|
struct msm_rot_clocks *rotator_clks;
|
|
#ifdef CONFIG_MSM_BUS_SCALING
|
|
struct msm_bus_scale_pdata *bus_scale_table;
|
|
#endif
|
|
char rot_iommu_split_domain;
|
|
};
|
|
#endif
|
|
|