mirror of
https://github.com/followmsi/android_kernel_google_msm.git
synced 2024-11-06 23:17:41 +00:00
475ec34506
Adds support to enable or disable mixer commit during pipe staging operations. Depending on the current activity, this selection can be made. Change-Id: Ia2f5dbab58f73ef4de90abf7f278332d8d73df46 Signed-off-by: Pradeep Jilagam <pjilagam@codeaurora.org> Signed-off-by: Ajay Dudani <adudani@codeaurora.org> Signed-off-by: Iliyan Malchev <malchev@google.com>
945 lines
28 KiB
C
945 lines
28 KiB
C
/* Copyright (c) 2009-2012, Code Aurora Forum. All rights reserved.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License version 2 and
|
|
* only version 2 as published by the Free Software Foundation.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
*/
|
|
|
|
#ifndef MDP4_H
|
|
#define MDP4_H
|
|
|
|
extern struct mdp_dma_data dma2_data;
|
|
extern struct mdp_dma_data dma_s_data;
|
|
extern struct mdp_dma_data dma_e_data;
|
|
extern struct mdp_dma_data dma_wb_data;
|
|
extern unsigned int mdp_hist_frame_cnt;
|
|
extern struct completion mdp_hist_comp;
|
|
extern boolean mdp_is_in_isr;
|
|
extern uint32 mdp_intr_mask;
|
|
extern spinlock_t mdp_spin_lock;
|
|
extern struct mdp4_statistic mdp4_stat;
|
|
extern uint32 mdp4_extn_disp;
|
|
extern char *mmss_cc_base; /* mutimedia sub system clock control */
|
|
extern spinlock_t dsi_clk_lock;
|
|
extern u32 mdp_max_clk;
|
|
|
|
#define MDP4_OVERLAYPROC0_BASE 0x10000
|
|
#define MDP4_OVERLAYPROC1_BASE 0x18000
|
|
#define MDP4_OVERLAYPROC2_BASE 0x88000
|
|
|
|
#define MDP4_VIDEO_BASE 0x20000
|
|
#define MDP4_VIDEO_OFF 0x10000
|
|
#define MDP4_VIDEO_CSC_OFF 0x4000
|
|
|
|
#define MDP4_RGB_BASE 0x40000
|
|
#define MDP4_RGB_OFF 0x10000
|
|
|
|
/* chip select controller */
|
|
#define CS_CONTROLLER_0 0x0707ffff
|
|
#define CS_CONTROLLER_1 0x03073f3f
|
|
|
|
enum {
|
|
OVERLAY_PERF_LEVEL1 = 1,
|
|
OVERLAY_PERF_LEVEL2,
|
|
OVERLAY_PERF_LEVEL3,
|
|
OVERLAY_PERF_LEVEL4
|
|
};
|
|
|
|
typedef int (*cmd_fxn_t)(struct platform_device *pdev);
|
|
|
|
enum { /* display */
|
|
PRIMARY_INTF_SEL,
|
|
SECONDARY_INTF_SEL,
|
|
EXTERNAL_INTF_SEL
|
|
};
|
|
|
|
enum {
|
|
LCDC_RGB_INTF, /* 0 */
|
|
DTV_INTF = LCDC_RGB_INTF, /* 0 */
|
|
MDDI_LCDC_INTF, /* 1 */
|
|
MDDI_INTF, /* 2 */
|
|
EBI2_INTF, /* 3 */
|
|
TV_INTF = EBI2_INTF, /* 3 */
|
|
DSI_VIDEO_INTF,
|
|
DSI_CMD_INTF
|
|
};
|
|
|
|
enum {
|
|
MDDI_PRIMARY_SET,
|
|
MDDI_SECONDARY_SET,
|
|
MDDI_EXTERNAL_SET
|
|
};
|
|
|
|
enum {
|
|
EBI2_LCD0,
|
|
EBI2_LCD1
|
|
};
|
|
|
|
#define MDP4_3D_NONE 0
|
|
#define MDP4_3D_SIDE_BY_SIDE 1
|
|
#define MDP4_3D_TOP_DOWN 2
|
|
|
|
#define MDP4_PANEL_MDDI BIT(0)
|
|
#define MDP4_PANEL_LCDC BIT(1)
|
|
#define MDP4_PANEL_DTV BIT(2)
|
|
#define MDP4_PANEL_ATV BIT(3)
|
|
#define MDP4_PANEL_DSI_VIDEO BIT(4)
|
|
#define MDP4_PANEL_DSI_CMD BIT(5)
|
|
#define MDP4_PANEL_WRITEBACK BIT(6)
|
|
|
|
enum {
|
|
OVERLAY_MODE_NONE,
|
|
OVERLAY_MODE_BLT
|
|
};
|
|
|
|
enum {
|
|
OVERLAY_REFRESH_ON_DEMAND,
|
|
OVERLAY_REFRESH_VSYNC,
|
|
OVERLAY_REFRESH_VSYNC_HALF,
|
|
OVERLAY_REFRESH_VSYNC_QUARTER
|
|
};
|
|
|
|
enum {
|
|
OVERLAY_FRAMEBUF,
|
|
OVERLAY_DIRECTOUT
|
|
};
|
|
|
|
/* system interrupts */
|
|
#define INTR_OVERLAY0_DONE BIT(0)
|
|
#define INTR_OVERLAY1_DONE BIT(1)
|
|
#define INTR_DMA_S_DONE BIT(2)
|
|
#define INTR_DMA_E_DONE BIT(3)
|
|
#define INTR_DMA_P_DONE BIT(4)
|
|
#define INTR_VG1_HISTOGRAM BIT(5)
|
|
#define INTR_VG2_HISTOGRAM BIT(6)
|
|
#define INTR_PRIMARY_VSYNC BIT(7)
|
|
#define INTR_PRIMARY_INTF_UDERRUN BIT(8)
|
|
#define INTR_EXTERNAL_VSYNC BIT(9)
|
|
#define INTR_EXTERNAL_INTF_UDERRUN BIT(10)
|
|
#define INTR_PRIMARY_RDPTR BIT(11) /* read pointer */
|
|
#define INTR_DMA_P_HISTOGRAM BIT(17)
|
|
#define INTR_DMA_S_HISTOGRAM BIT(26)
|
|
#define INTR_OVERLAY2_DONE BIT(30)
|
|
|
|
#ifdef CONFIG_FB_MSM_OVERLAY
|
|
#define MDP4_ANY_INTR_MASK (INTR_DMA_P_HISTOGRAM | \
|
|
INTR_DMA_S_HISTOGRAM | \
|
|
INTR_VG1_HISTOGRAM | \
|
|
INTR_VG2_HISTOGRAM)
|
|
#else
|
|
#define MDP4_ANY_INTR_MASK (INTR_DMA_P_DONE| \
|
|
INTR_DMA_P_HISTOGRAM | \
|
|
INTR_DMA_S_HISTOGRAM | \
|
|
INTR_VG1_HISTOGRAM | \
|
|
INTR_VG2_HISTOGRAM)
|
|
#endif
|
|
|
|
enum {
|
|
OVERLAY_PIPE_VG1, /* video/graphic */
|
|
OVERLAY_PIPE_VG2,
|
|
OVERLAY_PIPE_RGB1,
|
|
OVERLAY_PIPE_RGB2,
|
|
OVERLAY_PIPE_RGB3,
|
|
OVERLAY_PIPE_VG3,
|
|
OVERLAY_PIPE_VG4,
|
|
OVERLAY_PIPE_MAX
|
|
};
|
|
|
|
enum {
|
|
OVERLAY_TYPE_RGB,
|
|
OVERLAY_TYPE_VIDEO,
|
|
OVERLAY_TYPE_BF
|
|
};
|
|
|
|
enum {
|
|
MDP4_MIXER0,
|
|
MDP4_MIXER1,
|
|
MDP4_MIXER2,
|
|
MDP4_MIXER_MAX
|
|
};
|
|
|
|
enum {
|
|
OVERLAY_PLANE_INTERLEAVED,
|
|
OVERLAY_PLANE_PLANAR,
|
|
OVERLAY_PLANE_PSEUDO_PLANAR
|
|
};
|
|
|
|
enum {
|
|
MDP4_MIXER_STAGE_UNUNSED, /* pipe not used */
|
|
MDP4_MIXER_STAGE_BASE,
|
|
MDP4_MIXER_STAGE0, /* zorder 0 */
|
|
MDP4_MIXER_STAGE1, /* zorder 1 */
|
|
MDP4_MIXER_STAGE2, /* zorder 2 */
|
|
MDP4_MIXER_STAGE3, /* zorder 3 */
|
|
MDP4_MIXER_STAGE_MAX
|
|
};
|
|
|
|
enum {
|
|
MDP4_FRAME_FORMAT_LINEAR,
|
|
MDP4_FRAME_FORMAT_ARGB_TILE,
|
|
MDP4_FRAME_FORMAT_VIDEO_SUPERTILE
|
|
};
|
|
|
|
enum {
|
|
MDP4_CHROMA_RGB,
|
|
MDP4_CHROMA_H2V1,
|
|
MDP4_CHROMA_H1V2,
|
|
MDP4_CHROMA_420
|
|
};
|
|
|
|
#define MDP4_BLEND_BG_TRANSP_EN BIT(9)
|
|
#define MDP4_BLEND_FG_TRANSP_EN BIT(8)
|
|
#define MDP4_BLEND_BG_MOD_ALPHA BIT(7)
|
|
#define MDP4_BLEND_BG_INV_ALPHA BIT(6)
|
|
#define MDP4_BLEND_BG_ALPHA_FG_CONST (0 << 4)
|
|
#define MDP4_BLEND_BG_ALPHA_BG_CONST (1 << 4)
|
|
#define MDP4_BLEND_BG_ALPHA_FG_PIXEL (2 << 4)
|
|
#define MDP4_BLEND_BG_ALPHA_BG_PIXEL (3 << 4)
|
|
#define MDP4_BLEND_FG_MOD_ALPHA BIT(3)
|
|
#define MDP4_BLEND_FG_INV_ALPHA BIT(2)
|
|
#define MDP4_BLEND_FG_ALPHA_FG_CONST (0 << 0)
|
|
#define MDP4_BLEND_FG_ALPHA_BG_CONST (1 << 0)
|
|
#define MDP4_BLEND_FG_ALPHA_FG_PIXEL (2 << 0)
|
|
#define MDP4_BLEND_FG_ALPHA_BG_PIXEL (3 << 0)
|
|
|
|
#define MDP4_FORMAT_SOLID_FILL BIT(22)
|
|
#define MDP4_FORMAT_UNPACK_ALIGN_MSB BIT(18)
|
|
#define MDP4_FORMAT_UNPACK_TIGHT BIT(17)
|
|
#define MDP4_FORMAT_90_ROTATED BIT(12)
|
|
#define MDP4_FORMAT_ALPHA_ENABLE BIT(8)
|
|
|
|
#define MDP4_OP_DEINT_ODD_REF BIT(19)
|
|
#define MDP4_OP_DEINT_EN BIT(18)
|
|
#define MDP4_OP_IGC_LUT_EN BIT(16)
|
|
#define MDP4_OP_DITHER_EN BIT(15)
|
|
#define MDP4_OP_FLIP_UD BIT(14)
|
|
#define MDP4_OP_FLIP_LR BIT(13)
|
|
#define MDP4_OP_CSC_EN BIT(11)
|
|
#define MDP4_OP_DST_DATA_YCBCR BIT(10)
|
|
#define MDP4_OP_SRC_DATA_YCBCR BIT(9)
|
|
#define MDP4_OP_SCALEY_FIR (0 << 4)
|
|
#define MDP4_OP_SCALEY_MN_PHASE (1 << 4)
|
|
#define MDP4_OP_SCALEY_PIXEL_RPT (2 << 4)
|
|
#define MDP4_OP_SCALEX_FIR (0 << 2)
|
|
#define MDP4_OP_SCALEX_MN_PHASE (1 << 2)
|
|
#define MDP4_OP_SCALEX_PIXEL_RPT (2 << 2)
|
|
#define MDP4_OP_SCALE_RGB_ENHANCED (1 << 4)
|
|
#define MDP4_OP_SCALE_RGB_PIXEL_RPT (0 << 3)
|
|
#define MDP4_OP_SCALE_RGB_BILINEAR (1 << 3)
|
|
#define MDP4_OP_SCALE_ALPHA_PIXEL_RPT (0 << 2)
|
|
#define MDP4_OP_SCALE_ALPHA_BILINEAR (1 << 2)
|
|
#define MDP4_OP_SCALEY_EN BIT(1)
|
|
#define MDP4_OP_SCALEX_EN BIT(0)
|
|
|
|
#define MDP4_REV40_UP_SCALING_MAX (8)
|
|
#define MDP4_REV41_OR_LATER_UP_SCALING_MAX (20)
|
|
|
|
#define MDP4_PIPE_PER_MIXER 2
|
|
|
|
#define MDP4_MAX_PLANE 4
|
|
#define VSYNC_PERIOD 16
|
|
|
|
struct mdp4_hsic_regs {
|
|
int32_t params[NUM_HSIC_PARAM];
|
|
int32_t conv_matrix[3][3];
|
|
int32_t pre_limit[6];
|
|
int32_t post_limit[6];
|
|
int32_t pre_bias[3];
|
|
int32_t post_bias[3];
|
|
int32_t dirty;
|
|
};
|
|
|
|
struct mdp4_iommu_pipe_info {
|
|
struct ion_handle *ihdl[MDP4_MAX_PLANE];
|
|
struct ion_handle *prev_ihdl[MDP4_MAX_PLANE];
|
|
u8 mark_unmap;
|
|
};
|
|
|
|
#define IOMMU_FREE_LIST_MAX 32
|
|
|
|
struct iommu_free_list {
|
|
int total;
|
|
int fndx;
|
|
struct ion_handle *ihdl[IOMMU_FREE_LIST_MAX];
|
|
};
|
|
|
|
struct blend_cfg {
|
|
u32 op;
|
|
u32 bg_alpha;
|
|
u32 fg_alpha;
|
|
u32 co3_sel;
|
|
u32 transp_low0;
|
|
u32 transp_low1;
|
|
u32 transp_high0;
|
|
u32 transp_high1;
|
|
int solidfill;
|
|
struct mdp4_overlay_pipe *solidfill_pipe;
|
|
};
|
|
|
|
struct mdp4_overlay_pipe {
|
|
uint32 pipe_used;
|
|
uint32 pipe_type; /* rgb, video/graphic */
|
|
uint32 pipe_num;
|
|
uint32 pipe_ndx;
|
|
uint32 pipe_share;
|
|
uint32 mixer_num; /* which mixer used */
|
|
uint32 mixer_stage; /* which stage of mixer used */
|
|
uint32 src_format;
|
|
uint32 src_width; /* source img width */
|
|
uint32 src_height; /* source img height */
|
|
uint32 is_3d;
|
|
uint32 src_width_3d; /* source img width */
|
|
uint32 src_height_3d; /* source img height */
|
|
uint32 src_w; /* roi */
|
|
uint32 src_h; /* roi */
|
|
uint32 src_x; /* roi */
|
|
uint32 src_y; /* roi */
|
|
uint32 dst_w; /* roi */
|
|
uint32 dst_h; /* roi */
|
|
uint32 dst_x; /* roi */
|
|
uint32 dst_y; /* roi */
|
|
uint32 flags;
|
|
uint32 op_mode;
|
|
uint32 transp;
|
|
uint32 blend_op;
|
|
uint32 phasex_step;
|
|
uint32 phasey_step;
|
|
uint32 alpha;
|
|
uint32 is_fg; /* control alpha & color key */
|
|
uint32 srcp0_addr; /* interleave, luma */
|
|
uint32 srcp0_ystride;
|
|
uint32 srcp1_addr; /* pseudoplanar, chroma plane */
|
|
uint32 srcp1_ystride;
|
|
uint32 srcp2_addr; /* planar color 2*/
|
|
uint32 srcp2_ystride;
|
|
uint32 srcp3_addr; /* alpha/color 3 */
|
|
uint32 srcp3_ystride;
|
|
uint32 fetch_plane;
|
|
uint32 frame_format; /* video */
|
|
uint32 chroma_site; /* video */
|
|
uint32 chroma_sample; /* video */
|
|
uint32 solid_fill;
|
|
uint32 vc1_reduce; /* video */
|
|
uint32 unpack_align_msb;/* 0 to LSB, 1 to MSB */
|
|
uint32 unpack_tight;/* 0 for loose, 1 for tight */
|
|
uint32 unpack_count;/* 0 = 1 component, 1 = 2 component ... */
|
|
uint32 rotated_90; /* has been rotated 90 degree */
|
|
uint32 bpp; /* byte per pixel */
|
|
uint32 alpha_enable;/* source has alpha */
|
|
/*
|
|
* number of bits for source component,
|
|
* 0 = 1 bit, 1 = 2 bits, 2 = 6 bits, 3 = 8 bits
|
|
*/
|
|
uint32 a_bit; /* component 3, alpha */
|
|
uint32 r_bit; /* component 2, R_Cr */
|
|
uint32 b_bit; /* component 1, B_Cb */
|
|
uint32 g_bit; /* component 0, G_lumz */
|
|
/*
|
|
* unpack pattern
|
|
* A = C3, R = C2, B = C1, G = C0
|
|
*/
|
|
uint32 element3; /* 0 = C0, 1 = C1, 2 = C2, 3 = C3 */
|
|
uint32 element2; /* 0 = C0, 1 = C1, 2 = C2, 3 = C3 */
|
|
uint32 element1; /* 0 = C0, 1 = C1, 2 = C2, 3 = C3 */
|
|
uint32 element0; /* 0 = C0, 1 = C1, 2 = C2, 3 = C3 */
|
|
ulong ov_blt_addr; /* blt mode addr */
|
|
ulong dma_blt_addr; /* blt mode addr */
|
|
ulong blt_base;
|
|
ulong blt_offset;
|
|
uint32 blt_cnt;
|
|
uint32 blt_changed;
|
|
uint32 ov_cnt;
|
|
uint32 dmap_cnt;
|
|
uint32 dmae_cnt;
|
|
uint32 blt_end;
|
|
uint32 blt_ov_koff;
|
|
uint32 blt_ov_done;
|
|
uint32 blt_dmap_koff;
|
|
uint32 blt_dmap_done;
|
|
uint32 req_clk;
|
|
uint32 req_bw;
|
|
uint32 luma_align_size;
|
|
struct mdp_overlay_pp_params pp_cfg;
|
|
struct mdp_overlay req_data;
|
|
struct completion comp;
|
|
struct completion dmas_comp;
|
|
struct mdp4_iommu_pipe_info iommu;
|
|
};
|
|
|
|
struct mdp4_statistic {
|
|
ulong intr_tot;
|
|
ulong intr_dma_p;
|
|
ulong intr_dma_s;
|
|
ulong intr_dma_e;
|
|
ulong intr_overlay0;
|
|
ulong intr_overlay1;
|
|
ulong intr_overlay2;
|
|
ulong intr_vsync_p; /* Primary interface */
|
|
ulong intr_underrun_p; /* Primary interface */
|
|
ulong intr_vsync_e; /* external interface */
|
|
ulong intr_underrun_e; /* external interface */
|
|
ulong intr_histogram;
|
|
ulong intr_rdptr;
|
|
ulong dsi_mdp_start;
|
|
ulong dsi_clk_on;
|
|
ulong dsi_clk_off;
|
|
ulong intr_dsi;
|
|
ulong intr_dsi_mdp;
|
|
ulong intr_dsi_cmd;
|
|
ulong intr_dsi_err;
|
|
ulong kickoff_ov0;
|
|
ulong kickoff_ov1;
|
|
ulong kickoff_dmap;
|
|
ulong kickoff_dmae;
|
|
ulong kickoff_dmas;
|
|
ulong blt_dsi_cmd; /* blt */
|
|
ulong blt_dsi_video; /* blt */
|
|
ulong blt_lcdc; /* blt */
|
|
ulong blt_dtv; /* blt */
|
|
ulong blt_mddi; /* blt */
|
|
ulong overlay_set[MDP4_MIXER_MAX];
|
|
ulong overlay_unset[MDP4_MIXER_MAX];
|
|
ulong overlay_play[MDP4_MIXER_MAX];
|
|
ulong overlay_commit[MDP4_MIXER_MAX];
|
|
ulong pipe[OVERLAY_PIPE_MAX];
|
|
ulong wait4vsync0;
|
|
ulong wait4vsync1;
|
|
ulong iommu_map;
|
|
ulong iommu_unmap;
|
|
ulong iommu_drop;
|
|
ulong dsi_clkoff;
|
|
ulong err_mixer;
|
|
ulong err_zorder;
|
|
ulong err_size;
|
|
ulong err_scale;
|
|
ulong err_format;
|
|
ulong err_stage;
|
|
ulong err_play;
|
|
ulong err_underflow;
|
|
};
|
|
|
|
struct vsync_update {
|
|
int update_cnt; /* pipes to be updated */
|
|
struct completion vsync_comp;
|
|
struct mdp4_overlay_pipe plist[OVERLAY_PIPE_MAX];
|
|
};
|
|
|
|
struct mdp4_overlay_pipe *mdp4_overlay_ndx2pipe(int ndx);
|
|
void mdp4_sw_reset(unsigned long bits);
|
|
void mdp4_display_intf_sel(int output, unsigned long intf);
|
|
void mdp4_overlay_cfg(int layer, int blt_mode, int refresh, int direct_out);
|
|
void mdp4_ebi2_lcd_setup(int lcd, unsigned long base, int ystride);
|
|
void mdp4_mddi_setup(int which, unsigned long id);
|
|
unsigned long mdp4_display_status(void);
|
|
void mdp4_enable_clk_irq(void);
|
|
void mdp4_disable_clk_irq(void);
|
|
void mdp4_dma_p_update(struct msm_fb_data_type *mfd);
|
|
void mdp4_dma_s_update(struct msm_fb_data_type *mfd);
|
|
void mdp_pipe_ctrl(MDP_BLOCK_TYPE block, MDP_BLOCK_POWER_STATE state,
|
|
boolean isr);
|
|
void mdp4_pipe_kickoff(uint32 pipe, struct msm_fb_data_type *mfd);
|
|
int mdp4_lcdc_on(struct platform_device *pdev);
|
|
int mdp4_lcdc_off(struct platform_device *pdev);
|
|
void mdp4_lcdc_update(struct msm_fb_data_type *mfd);
|
|
void mdp4_intr_clear_set(ulong clear, ulong set);
|
|
void mdp4_dma_p_cfg(void);
|
|
unsigned is_mdp4_hw_reset(void);
|
|
void mdp4_overlay_cfg_init(void);
|
|
void mdp4_hw_init(void);
|
|
void mdp4_isr_read(int);
|
|
void mdp4_clear_lcdc(void);
|
|
void mdp4_mixer_blend_init(int mixer_num);
|
|
void mdp4_vg_qseed_init(int vg_num);
|
|
void mdp4_vg_csc_setup(int vp_num);
|
|
void mdp4_mixer_csc_setup(uint32 mixer);
|
|
void mdp4_dmap_csc_setup(void);
|
|
void mdp4_vg_csc_update(struct mdp_csc *p);
|
|
irqreturn_t mdp4_isr(int irq, void *ptr);
|
|
void mdp4_overlay_format_to_pipe(uint32 format, struct mdp4_overlay_pipe *pipe);
|
|
uint32 mdp4_overlay_format(struct mdp4_overlay_pipe *pipe);
|
|
uint32 mdp4_overlay_unpack_pattern(struct mdp4_overlay_pipe *pipe);
|
|
uint32 mdp4_overlay_op_mode(struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_lcdc_base_swap(int cndx, struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_lcdc_overlay(struct msm_fb_data_type *mfd);
|
|
|
|
|
|
#ifdef CONFIG_FB_MSM_DTV
|
|
void mdp4_overlay_dtv_start(void);
|
|
void mdp4_overlay_dtv_ov_done_push(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_overlay_dtv_wait_for_ov(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe);
|
|
int mdp4_overlay_dtv_set(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe);
|
|
int mdp4_overlay_dtv_unset(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_dmae_done_dtv(void);
|
|
void mdp4_dtv_wait4vsync(int cndx, long long *vtime);
|
|
void mdp4_dtv_vsync_ctrl(int cndx, int enable);
|
|
void mdp4_dtv_base_swap(int cndx, struct mdp4_overlay_pipe *pipe);
|
|
#else
|
|
static inline void mdp4_overlay_dtv_start(void)
|
|
{
|
|
/* empty */
|
|
}
|
|
static inline void mdp4_overlay_dtv_ov_done_push(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe)
|
|
{
|
|
/* empty */
|
|
}
|
|
static inline void mdp4_overlay_dtv_wait_for_ov(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe)
|
|
{
|
|
/* empty */
|
|
}
|
|
static inline int mdp4_overlay_dtv_set(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe)
|
|
{
|
|
return 0;
|
|
}
|
|
static inline int mdp4_overlay_dtv_unset(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe)
|
|
{
|
|
return 0;
|
|
}
|
|
|
|
static inline void mdp4_dmae_done_dtv(void)
|
|
{
|
|
/* empty */
|
|
}
|
|
static inline void mdp4_dtv_wait4vsync(int cndx, long long *vtime)
|
|
{
|
|
/* empty */
|
|
}
|
|
static inline void mdp4_dtv_vsync_ctrl(int cndx, long long *vtime)
|
|
{
|
|
/* empty */
|
|
}
|
|
static inline void mdp4_dtv_overlay_blt_start(struct msm_fb_data_type *mfd)
|
|
{
|
|
return;
|
|
}
|
|
static inline void mdp4_dtv_overlay_blt_stop(struct msm_fb_data_type *mfd)
|
|
{
|
|
return;
|
|
}
|
|
static inline void mdp4_dtv_base_swap(struct mdp4_overlay_pipe *pipe)
|
|
{
|
|
/* empty */
|
|
}
|
|
#endif /* CONFIG_FB_MSM_DTV */
|
|
|
|
void mdp4_dtv_set_black_screen(void);
|
|
|
|
int mdp4_overlay_dtv_set(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe);
|
|
int mdp4_overlay_dtv_unset(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_dtv_overlay(struct msm_fb_data_type *mfd);
|
|
int mdp4_dtv_on(struct platform_device *pdev);
|
|
int mdp4_dtv_off(struct platform_device *pdev);
|
|
void mdp4_atv_overlay(struct msm_fb_data_type *mfd);
|
|
int mdp4_atv_on(struct platform_device *pdev);
|
|
int mdp4_atv_off(struct platform_device *pdev);
|
|
void mdp4_dsi_video_fxn_register(cmd_fxn_t fxn);
|
|
void mdp4_dsi_video_overlay(struct msm_fb_data_type *mfd);
|
|
void mdp4_lcdc_vsync_ctrl(int cndx, int enable);
|
|
void mdp4_overlay0_done_dsi_video(int cndx);
|
|
void mdp4_overlay0_done_dsi_cmd(int cndx);
|
|
void mdp4_primary_rdptr(void);
|
|
void mdp4_dsi_cmd_overlay(struct msm_fb_data_type *mfd);
|
|
int mdp4_overlay_commit(struct fb_info *info, int mixer);
|
|
int mdp4_dsi_video_pipe_commit(void);
|
|
int mdp4_dsi_cmd_pipe_commit(void);
|
|
int mdp4_lcdc_pipe_commit(void);
|
|
int mdp4_dtv_pipe_commit(void);
|
|
void mdp4_dsi_rdptr_init(int cndx);
|
|
void mdp4_dsi_vsync_init(int cndx);
|
|
void mdp4_lcdc_vsync_init(int cndx);
|
|
void mdp4_dtv_vsync_init(int cndx);
|
|
void mdp4_overlay_dsi_state_set(int state);
|
|
int mdp4_overlay_dsi_state_get(void);
|
|
void mdp4_overlay_rgb_setup(struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_overlay_reg_flush(struct mdp4_overlay_pipe *pipe, int all);
|
|
void mdp4_mixer_blend_setup(int mixer);
|
|
struct mdp4_overlay_pipe *mdp4_overlay_stage_pipe(int mixer, int stage);
|
|
void mdp4_mixer_stage_up(struct mdp4_overlay_pipe *pipe, int commit);
|
|
void mdp4_mixer_stage_down(struct mdp4_overlay_pipe *pipe, int commit);
|
|
void mdp4_mixer_pipe_cleanup(int mixer);
|
|
int mdp4_mixer_stage_can_run(struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_overlayproc_cfg(struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_mddi_overlay(struct msm_fb_data_type *mfd);
|
|
int mdp4_overlay_format2type(uint32 format);
|
|
int mdp4_overlay_format2pipe(struct mdp4_overlay_pipe *pipe);
|
|
int mdp4_overlay_get(struct fb_info *info, struct mdp_overlay *req);
|
|
int mdp4_overlay_set(struct fb_info *info, struct mdp_overlay *req);
|
|
int mdp4_overlay_wait4vsync(struct fb_info *info, long long *vtime);
|
|
int mdp4_overlay_vsync_ctrl(struct fb_info *info, int enable);
|
|
int mdp4_overlay_unset(struct fb_info *info, int ndx);
|
|
int mdp4_overlay_unset_mixer(int mixer);
|
|
int mdp4_overlay_play_wait(struct fb_info *info,
|
|
struct msmfb_overlay_data *req);
|
|
int mdp4_overlay_play(struct fb_info *info, struct msmfb_overlay_data *req);
|
|
struct mdp4_overlay_pipe *mdp4_overlay_pipe_alloc(int ptype, int mixer);
|
|
void mdp4_overlay_dma_commit(int mixer);
|
|
void mdp4_overlay_vsync_commit(struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_mixer_stage_commit(int mixer);
|
|
void mdp4_dsi_cmd_do_update(int cndx, struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_lcdc_pipe_queue(int cndx, struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_dtv_pipe_queue(int cndx, struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_overlay_pipe_free(struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_overlay_dmap_cfg(struct msm_fb_data_type *mfd, int lcdc);
|
|
void mdp4_overlay_dmap_xy(struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_overlay_dmae_cfg(struct msm_fb_data_type *mfd, int atv);
|
|
void mdp4_overlay_dmae_xy(struct mdp4_overlay_pipe *pipe);
|
|
int mdp4_overlay_pipe_staged(int mixer);
|
|
void mdp4_lcdc_primary_vsyn(void);
|
|
void mdp4_overlay0_done_lcdc(int cndx);
|
|
void mdp4_overlay0_done_mddi(struct mdp_dma_data *dma);
|
|
void mdp4_dma_p_done_mddi(struct mdp_dma_data *dma);
|
|
void mdp4_dmap_done_dsi_cmd(int cndx);
|
|
void mdp4_dmap_done_dsi_video(int cndx);
|
|
void mdp4_dmap_done_lcdc(int cndx);
|
|
void mdp4_overlay1_done_dtv(void);
|
|
void mdp4_overlay1_done_atv(void);
|
|
void mdp4_primary_vsync_lcdc(void);
|
|
void mdp4_external_vsync_dtv(void);
|
|
void mdp4_lcdc_wait4vsync(int cndx, long long *vtime);
|
|
void mdp4_overlay_lcdc_vsync_push(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_mddi_overlay_dmas_restore(void);
|
|
|
|
#ifndef CONFIG_FB_MSM_MIPI_DSI
|
|
void mdp4_mddi_dma_busy_wait(struct msm_fb_data_type *mfd);
|
|
void mdp4_mddi_overlay_restore(void);
|
|
#else
|
|
static inline void mdp4_mddi_kickoff_video(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe)
|
|
{
|
|
/* empty */
|
|
}
|
|
static inline void mdp4_mddi_dma_busy_wait(struct msm_fb_data_type *mfd)
|
|
{
|
|
/* empty */
|
|
}
|
|
static inline void mdp4_mddi_blt_dmap_busy_wait(struct msm_fb_data_type *mfd)
|
|
{
|
|
/* empty */
|
|
}
|
|
static inline void mdp4_mddi_overlay_restore(void)
|
|
{
|
|
/* empty */
|
|
}
|
|
static inline void mdp4_mddi_overlay_blt_start(struct msm_fb_data_type *mfd)
|
|
{
|
|
/*empty*/
|
|
}
|
|
static inline void mdp4_mddi_overlay_blt_stop(struct msm_fb_data_type *mfd)
|
|
{
|
|
/*empty*/
|
|
}
|
|
static inline void mdp4_mddi_overlay_blt_offset(struct msm_fb_data_type *mfd,
|
|
struct msmfb_overlay_blt *req)
|
|
{
|
|
/* empty */
|
|
}
|
|
static inline void mdp4_mddi_overlay_blt(struct msm_fb_data_type *mfd,
|
|
struct msmfb_overlay_blt *req)
|
|
{
|
|
/* empty*/
|
|
}
|
|
#endif
|
|
|
|
void mdp4_mddi_overlay_kickoff(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_rgb_igc_lut_setup(int num);
|
|
void mdp4_vg_igc_lut_setup(int num);
|
|
void mdp4_mixer_gc_lut_setup(int mixer_num);
|
|
void mdp4_fetch_cfg(uint32 clk);
|
|
uint32 mdp4_rgb_igc_lut_cvt(uint32 ndx);
|
|
void mdp4_vg_qseed_init(int);
|
|
int mdp4_overlay_blt(struct fb_info *info, struct msmfb_overlay_blt *req);
|
|
|
|
#ifdef CONFIG_FB_MSM_MIPI_DSI
|
|
void mdp4_dsi_cmd_blt_start(struct msm_fb_data_type *mfd);
|
|
void mdp4_dsi_cmd_blt_stop(struct msm_fb_data_type *mfd);
|
|
void mdp4_dsi_video_blt_start(struct msm_fb_data_type *mfd);
|
|
void mdp4_dsi_video_blt_stop(struct msm_fb_data_type *mfd);
|
|
void mdp4_dsi_cmd_overlay_blt(struct msm_fb_data_type *mfd,
|
|
struct msmfb_overlay_blt *req);
|
|
|
|
void mdp4_dsi_video_overlay_blt(struct msm_fb_data_type *mfd,
|
|
struct msmfb_overlay_blt *req);
|
|
void mdp4_dsi_video_base_swap(int cndx, struct mdp4_overlay_pipe *pipe);
|
|
|
|
#ifdef CONFIG_FB_MSM_MDP40
|
|
static inline void mdp3_dsi_cmd_dma_busy_wait(struct msm_fb_data_type *mfd)
|
|
{
|
|
/* empty */
|
|
}
|
|
#endif
|
|
#else /* CONFIG_FB_MSM_MIPI_DSI */
|
|
int mdp4_mddi_overlay_blt_offset(struct msm_fb_data_type *mfd,
|
|
struct msmfb_overlay_blt *req);
|
|
void mdp4_mddi_overlay_blt(struct msm_fb_data_type *mfd,
|
|
struct msmfb_overlay_blt *req);
|
|
int mdp4_mddi_overlay_blt_start(struct msm_fb_data_type *mfd);
|
|
int mdp4_mddi_overlay_blt_stop(struct msm_fb_data_type *mfd);
|
|
void mdp4_mddi_blt_dmap_busy_wait(struct msm_fb_data_type *mfd);
|
|
static inline int mdp4_dsi_overlay_blt_start(struct msm_fb_data_type *mfd)
|
|
{
|
|
return -ENODEV;
|
|
}
|
|
static inline int mdp4_dsi_overlay_blt_stop(struct msm_fb_data_type *mfd)
|
|
{
|
|
return -ENODEV;
|
|
}
|
|
static inline void mdp4_dsi_video_blt_start(struct msm_fb_data_type *mfd)
|
|
{
|
|
}
|
|
static inline void mdp4_dsi_video_blt_stop(struct msm_fb_data_type *mfd)
|
|
{
|
|
}
|
|
static inline void mdp4_dsi_overlay_blt(
|
|
struct msm_fb_data_type *mfd, struct msmfb_overlay_blt *req)
|
|
{
|
|
}
|
|
static inline int mdp4_dsi_overlay_blt_offset(
|
|
struct msm_fb_data_type *mfd, struct msmfb_overlay_blt *req)
|
|
{
|
|
return -ENODEV;
|
|
}
|
|
static inline void mdp4_dsi_video_overlay_blt(
|
|
struct msm_fb_data_type *mfd, struct msmfb_overlay_blt *req)
|
|
{
|
|
}
|
|
static inline void mdp4_dsi_cmd_overlay_blt(
|
|
struct msm_fb_data_type *mfd, struct msmfb_overlay_blt *req)
|
|
{
|
|
}
|
|
static inline void mdp4_dsi_video_base_swap(int cndx,
|
|
struct mdp4_overlay_pipe *pipe)
|
|
{
|
|
/* empty */
|
|
}
|
|
static inline void mdp4_dsi_cmd_blt_start(struct msm_fb_data_type *mfd)
|
|
{
|
|
}
|
|
static inline void mdp4_dsi_cmd_blt_stop(struct msm_fb_data_type *mfd)
|
|
{
|
|
}
|
|
#endif /* CONFIG_FB_MSM_MIPI_DSI */
|
|
|
|
void mdp4_lcdc_overlay_blt(struct msm_fb_data_type *mfd,
|
|
struct msmfb_overlay_blt *req);
|
|
int mdp4_lcdc_overlay_blt_offset(struct msm_fb_data_type *mfd,
|
|
struct msmfb_overlay_blt *req);
|
|
void mdp4_lcdc_overlay_blt_start(struct msm_fb_data_type *mfd);
|
|
void mdp4_lcdc_overlay_blt_stop(struct msm_fb_data_type *mfd);
|
|
void mdp4_dtv_overlay_blt_start(struct msm_fb_data_type *mfd);
|
|
void mdp4_dtv_overlay_blt_stop(struct msm_fb_data_type *mfd);
|
|
void mdp4_overlay_panel_mode(int mixer_num, uint32 mode);
|
|
void mdp4_overlay_panel_mode_unset(int mixer_num, uint32 mode);
|
|
int mdp4_overlay_mixer_play(int mixer_num);
|
|
uint32 mdp4_overlay_panel_list(void);
|
|
void mdp4_lcdc_overlay_kickoff(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe);
|
|
|
|
void mdp4_mddi_kickoff_video(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe);
|
|
|
|
void mdp4_mddi_read_ptr_intr(void);
|
|
|
|
void mdp4_dsi_cmd_dma_busy_check(void);
|
|
|
|
|
|
|
|
#ifdef CONFIG_FB_MSM_MIPI_DSI
|
|
void mdp_dsi_cmd_overlay_suspend(struct msm_fb_data_type *mfd);
|
|
int mdp4_dsi_cmd_on(struct platform_device *pdev);
|
|
int mdp4_dsi_cmd_off(struct platform_device *pdev);
|
|
int mdp4_dsi_video_off(struct platform_device *pdev);
|
|
int mdp4_dsi_video_on(struct platform_device *pdev);
|
|
void mdp4_primary_vsync_dsi_video(void);
|
|
void mdp4_dsi_cmd_base_swap(int cndx, struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_dsi_cmd_wait4vsync(int cndx, long long *vtime);
|
|
void mdp4_dsi_video_wait4vsync(int cndx, long long *vtime);
|
|
void mdp4_dsi_cmd_pipe_queue(int cndx, struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_dsi_video_pipe_queue(int cndx, struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_dsi_cmd_vsync_ctrl(int cndx, int enable);
|
|
void mdp4_dsi_video_vsync_ctrl(int cndx, int enable);
|
|
#ifdef CONFIG_FB_MSM_MDP303
|
|
static inline void mdp4_dsi_cmd_del_timer(void)
|
|
{
|
|
/* empty */
|
|
}
|
|
#else /* CONFIG_FB_MSM_MIPI_DSI */
|
|
void mdp4_dsi_cmd_del_timer(void);
|
|
#endif
|
|
#else /* CONFIG_FB_MSM_MIPI_DSI */
|
|
|
|
static inline int mdp4_dsi_cmd_on(struct platform_device *pdev)
|
|
{
|
|
return 0;
|
|
}
|
|
static inline int mdp4_dsi_cmd_off(struct platform_device *pdev)
|
|
{
|
|
return 0;
|
|
}
|
|
static inline int mdp4_dsi_video_on(struct platform_device *pdev)
|
|
{
|
|
return 0;
|
|
}
|
|
static inline int mdp4_dsi_video_off(struct platform_device *pdev)
|
|
{
|
|
return 0;
|
|
}
|
|
static inline void mdp4_primary_vsync_dsi_video(void)
|
|
{
|
|
}
|
|
static inline void mdp4_dsi_cmd_base_swap(int cndx,
|
|
struct mdp4_overlay_pipe *pipe)
|
|
{
|
|
}
|
|
static inline void mdp4_dsi_cmd_wait4vsync(int cndx, long long *vtime)
|
|
{
|
|
}
|
|
static inline void mdp4_dsi_video_wait4vsync(int cndx, long long *vtime)
|
|
{
|
|
}
|
|
static inline void mdp4_dsi_cmd_pipe_queue(int cndx,
|
|
struct mdp4_overlay_pipe *pipe)
|
|
{
|
|
}
|
|
static inline void mdp4_dsi_video_pipe_queue(int cndx,
|
|
struct mdp4_overlay_pipe *pipe)
|
|
{
|
|
}
|
|
static inline void mdp4_dsi_cmd_vsync_ctrl(int cndx, int enable)
|
|
{
|
|
}
|
|
static inline void mdp4_dsi_video_vsync_ctrl(int cndx, int enable)
|
|
{
|
|
}
|
|
|
|
static inline void mdp4_overlay_dsi_video_start(void)
|
|
{
|
|
/* empty */
|
|
}
|
|
#ifdef CONFIG_FB_MSM_MDP40
|
|
static inline void mdp_dsi_cmd_overlay_suspend(struct msm_fb_data_type *mfd)
|
|
{
|
|
/* empty */
|
|
}
|
|
#endif
|
|
#endif /* CONFIG_FB_MSM_MIPI_DSI */
|
|
|
|
void mdp4_dsi_cmd_kickoff_ui(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_dsi_cmd_kickoff_video(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_dsi_cmd_overlay_kickoff(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_overlay_panel_3d(int mixer_num, uint32 panel_3d);
|
|
int mdp4_overlay_3d_sbys(struct fb_info *info, struct msmfb_overlay_3d *req);
|
|
void mdp4_dsi_cmd_3d_sbys(struct msm_fb_data_type *mfd,
|
|
struct msmfb_overlay_3d *r3d);
|
|
void mdp4_dsi_video_3d_sbys(struct msm_fb_data_type *mfd,
|
|
struct msmfb_overlay_3d *r3d);
|
|
|
|
void mdp4_backlight_init(int cndx);
|
|
void mdp4_backlight_put_level(int cndx, int level);
|
|
|
|
int mdp4_mixer_info(int mixer_num, struct mdp_mixer_info *info);
|
|
|
|
void mdp_dmap_vsync_set(int enable);
|
|
int mdp_dmap_vsync_get(void);
|
|
void mdp_hw_cursor_done(void);
|
|
void mdp_hw_cursor_init(void);
|
|
int mdp4_mddi_overlay_cursor(struct fb_info *info, struct fb_cursor *cursor);
|
|
int mdp_ppp_blit(struct fb_info *info, struct mdp_blit_req *req);
|
|
void mdp4_overlay_resource_release(void);
|
|
uint32_t mdp4_ss_table_value(int8_t param, int8_t index);
|
|
void mdp4_overlay_borderfill_stage_down(struct mdp4_overlay_pipe *pipe);
|
|
|
|
#ifdef CONFIG_FB_MSM_MDP303
|
|
static inline int mdp4_overlay_borderfill_supported(void)
|
|
{
|
|
return 0;
|
|
}
|
|
#else
|
|
int mdp4_overlay_borderfill_supported(void);
|
|
#endif
|
|
|
|
int mdp4_overlay_writeback_on(struct platform_device *pdev);
|
|
int mdp4_overlay_writeback_off(struct platform_device *pdev);
|
|
void mdp4_writeback_overlay(struct msm_fb_data_type *mfd);
|
|
void mdp4_overlay1_done_writeback(struct mdp_dma_data *dma);
|
|
|
|
int mdp4_writeback_start(struct fb_info *info);
|
|
int mdp4_writeback_stop(struct fb_info *info);
|
|
int mdp4_writeback_dequeue_buffer(struct fb_info *info,
|
|
struct msmfb_data *data);
|
|
int mdp4_writeback_queue_buffer(struct fb_info *info,
|
|
struct msmfb_data *data);
|
|
void mdp4_writeback_dma_stop(struct msm_fb_data_type *mfd);
|
|
int mdp4_writeback_init(struct fb_info *info);
|
|
int mdp4_writeback_terminate(struct fb_info *info);
|
|
|
|
uint32_t mdp_block2base(uint32_t block);
|
|
int mdp_hist_lut_config(struct mdp_hist_lut_data *data);
|
|
|
|
void mdp4_hsic_update(struct mdp4_overlay_pipe *pipe);
|
|
int mdp4_csc_config(struct mdp_csc_cfg_data *config);
|
|
void mdp4_csc_write(struct mdp_csc_cfg *data, uint32_t base);
|
|
int mdp4_csc_enable(struct mdp_csc_cfg_data *config);
|
|
int mdp4_pcc_cfg(struct mdp_pcc_cfg_data *cfg_ptr);
|
|
int mdp4_argc_cfg(struct mdp_pgc_lut_data *pgc_ptr);
|
|
int mdp4_qseed_cfg(struct mdp_qseed_cfg_data *cfg);
|
|
int mdp4_qseed_access_cfg(struct mdp_qseed_cfg *cfg, uint32_t base);
|
|
u32 mdp4_allocate_writeback_buf(struct msm_fb_data_type *mfd, u32 mix_num);
|
|
void mdp4_init_writeback_buf(struct msm_fb_data_type *mfd, u32 mix_num);
|
|
void mdp4_free_writeback_buf(struct msm_fb_data_type *mfd, u32 mix_num);
|
|
|
|
int mdp4_igc_lut_config(struct mdp_igc_lut_data *cfg);
|
|
void mdp4_overlay_iommu_pipe_free(int ndx, int all);
|
|
void mdp4_overlay_iommu_free_list(int mixer, struct ion_handle *ihdl);
|
|
void mdp4_overlay_iommu_unmap_freelist(int mixer);
|
|
void mdp4_overlay_iommu_vsync_cnt(void);
|
|
void mdp4_iommu_unmap(struct mdp4_overlay_pipe *pipe);
|
|
void mdp4_iommu_attach(void);
|
|
int mdp4_v4l2_overlay_set(struct fb_info *info, struct mdp_overlay *req,
|
|
struct mdp4_overlay_pipe **ppipe);
|
|
void mdp4_v4l2_overlay_clear(struct mdp4_overlay_pipe *pipe);
|
|
int mdp4_v4l2_overlay_play(struct fb_info *info, struct mdp4_overlay_pipe *pipe,
|
|
unsigned long srcp0_addr, unsigned long srcp1_addr,
|
|
unsigned long srcp2_addr);
|
|
int mdp4_overlay_mdp_pipe_req(struct mdp4_overlay_pipe *pipe,
|
|
struct msm_fb_data_type *mfd);
|
|
int mdp4_overlay_mdp_perf_req(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *plist);
|
|
void mdp4_overlay_mdp_perf_upd(struct msm_fb_data_type *mfd, int flag);
|
|
|
|
#ifndef CONFIG_FB_MSM_WRITEBACK_MSM_PANEL
|
|
static inline void mdp4_writeback_dma_busy_wait(struct msm_fb_data_type *mfd)
|
|
{
|
|
/* empty */
|
|
}
|
|
static inline void mdp4_writeback_kickoff_video(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe)
|
|
{
|
|
/* empty */
|
|
}
|
|
#else
|
|
void mdp4_writeback_dma_busy_wait(struct msm_fb_data_type *mfd);
|
|
void mdp4_writeback_kickoff_video(struct msm_fb_data_type *mfd,
|
|
struct mdp4_overlay_pipe *pipe);
|
|
#endif
|
|
|
|
#endif /* MDP_H */
|