imx-ipu-v3.h 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351
  1. /*
  2. * Copyright 2005-2009 Freescale Semiconductor, Inc.
  3. *
  4. * The code contained herein is licensed under the GNU Lesser General
  5. * Public License. You may obtain a copy of the GNU Lesser General
  6. * Public License Version 2.1 or later at the following locations:
  7. *
  8. * http://www.opensource.org/licenses/lgpl-license.html
  9. * http://www.gnu.org/copyleft/lgpl.html
  10. */
  11. #ifndef __DRM_IPU_H__
  12. #define __DRM_IPU_H__
  13. #include <linux/types.h>
  14. #include <linux/videodev2.h>
  15. #include <linux/bitmap.h>
  16. #include <linux/fb.h>
  17. #include <linux/of.h>
  18. #include <media/v4l2-mediabus.h>
  19. #include <video/videomode.h>
  20. struct ipu_soc;
  21. enum ipuv3_type {
  22. IPUV3EX,
  23. IPUV3M,
  24. IPUV3H,
  25. };
  26. #define IPU_PIX_FMT_GBR24 v4l2_fourcc('G', 'B', 'R', '3')
  27. /*
  28. * Bitfield of Display Interface signal polarities.
  29. */
  30. struct ipu_di_signal_cfg {
  31. unsigned data_pol:1; /* true = inverted */
  32. unsigned clk_pol:1; /* true = rising edge */
  33. unsigned enable_pol:1;
  34. struct videomode mode;
  35. u32 bus_format;
  36. u32 v_to_h_sync;
  37. #define IPU_DI_CLKMODE_SYNC (1 << 0)
  38. #define IPU_DI_CLKMODE_EXT (1 << 1)
  39. unsigned long clkflags;
  40. u8 hsync_pin;
  41. u8 vsync_pin;
  42. };
  43. /*
  44. * Enumeration of CSI destinations
  45. */
  46. enum ipu_csi_dest {
  47. IPU_CSI_DEST_IDMAC, /* to memory via SMFC */
  48. IPU_CSI_DEST_IC, /* to Image Converter */
  49. IPU_CSI_DEST_VDIC, /* to VDIC */
  50. };
  51. /*
  52. * Enumeration of IPU rotation modes
  53. */
  54. enum ipu_rotate_mode {
  55. IPU_ROTATE_NONE = 0,
  56. IPU_ROTATE_VERT_FLIP,
  57. IPU_ROTATE_HORIZ_FLIP,
  58. IPU_ROTATE_180,
  59. IPU_ROTATE_90_RIGHT,
  60. IPU_ROTATE_90_RIGHT_VFLIP,
  61. IPU_ROTATE_90_RIGHT_HFLIP,
  62. IPU_ROTATE_90_LEFT,
  63. };
  64. enum ipu_color_space {
  65. IPUV3_COLORSPACE_RGB,
  66. IPUV3_COLORSPACE_YUV,
  67. IPUV3_COLORSPACE_UNKNOWN,
  68. };
  69. struct ipuv3_channel;
  70. enum ipu_channel_irq {
  71. IPU_IRQ_EOF = 0,
  72. IPU_IRQ_NFACK = 64,
  73. IPU_IRQ_NFB4EOF = 128,
  74. IPU_IRQ_EOS = 192,
  75. };
  76. /*
  77. * Enumeration of IDMAC channels
  78. */
  79. #define IPUV3_CHANNEL_CSI0 0
  80. #define IPUV3_CHANNEL_CSI1 1
  81. #define IPUV3_CHANNEL_CSI2 2
  82. #define IPUV3_CHANNEL_CSI3 3
  83. #define IPUV3_CHANNEL_VDI_MEM_IC_VF 5
  84. #define IPUV3_CHANNEL_MEM_IC_PP 11
  85. #define IPUV3_CHANNEL_MEM_IC_PRP_VF 12
  86. #define IPUV3_CHANNEL_G_MEM_IC_PRP_VF 14
  87. #define IPUV3_CHANNEL_G_MEM_IC_PP 15
  88. #define IPUV3_CHANNEL_IC_PRP_ENC_MEM 20
  89. #define IPUV3_CHANNEL_IC_PRP_VF_MEM 21
  90. #define IPUV3_CHANNEL_IC_PP_MEM 22
  91. #define IPUV3_CHANNEL_MEM_BG_SYNC 23
  92. #define IPUV3_CHANNEL_MEM_BG_ASYNC 24
  93. #define IPUV3_CHANNEL_MEM_FG_SYNC 27
  94. #define IPUV3_CHANNEL_MEM_DC_SYNC 28
  95. #define IPUV3_CHANNEL_MEM_FG_ASYNC 29
  96. #define IPUV3_CHANNEL_MEM_FG_SYNC_ALPHA 31
  97. #define IPUV3_CHANNEL_MEM_DC_ASYNC 41
  98. #define IPUV3_CHANNEL_MEM_ROT_ENC 45
  99. #define IPUV3_CHANNEL_MEM_ROT_VF 46
  100. #define IPUV3_CHANNEL_MEM_ROT_PP 47
  101. #define IPUV3_CHANNEL_ROT_ENC_MEM 48
  102. #define IPUV3_CHANNEL_ROT_VF_MEM 49
  103. #define IPUV3_CHANNEL_ROT_PP_MEM 50
  104. #define IPUV3_CHANNEL_MEM_BG_SYNC_ALPHA 51
  105. int ipu_map_irq(struct ipu_soc *ipu, int irq);
  106. int ipu_idmac_channel_irq(struct ipu_soc *ipu, struct ipuv3_channel *channel,
  107. enum ipu_channel_irq irq);
  108. #define IPU_IRQ_DP_SF_START (448 + 2)
  109. #define IPU_IRQ_DP_SF_END (448 + 3)
  110. #define IPU_IRQ_BG_SF_END IPU_IRQ_DP_SF_END,
  111. #define IPU_IRQ_DC_FC_0 (448 + 8)
  112. #define IPU_IRQ_DC_FC_1 (448 + 9)
  113. #define IPU_IRQ_DC_FC_2 (448 + 10)
  114. #define IPU_IRQ_DC_FC_3 (448 + 11)
  115. #define IPU_IRQ_DC_FC_4 (448 + 12)
  116. #define IPU_IRQ_DC_FC_6 (448 + 13)
  117. #define IPU_IRQ_VSYNC_PRE_0 (448 + 14)
  118. #define IPU_IRQ_VSYNC_PRE_1 (448 + 15)
  119. /*
  120. * IPU Common functions
  121. */
  122. void ipu_set_csi_src_mux(struct ipu_soc *ipu, int csi_id, bool mipi_csi2);
  123. void ipu_set_ic_src_mux(struct ipu_soc *ipu, int csi_id, bool vdi);
  124. void ipu_dump(struct ipu_soc *ipu);
  125. /*
  126. * IPU Image DMA Controller (idmac) functions
  127. */
  128. struct ipuv3_channel *ipu_idmac_get(struct ipu_soc *ipu, unsigned channel);
  129. void ipu_idmac_put(struct ipuv3_channel *);
  130. int ipu_idmac_enable_channel(struct ipuv3_channel *channel);
  131. int ipu_idmac_disable_channel(struct ipuv3_channel *channel);
  132. void ipu_idmac_enable_watermark(struct ipuv3_channel *channel, bool enable);
  133. int ipu_idmac_lock_enable(struct ipuv3_channel *channel, int num_bursts);
  134. int ipu_idmac_wait_busy(struct ipuv3_channel *channel, int ms);
  135. void ipu_idmac_set_double_buffer(struct ipuv3_channel *channel,
  136. bool doublebuffer);
  137. int ipu_idmac_get_current_buffer(struct ipuv3_channel *channel);
  138. bool ipu_idmac_buffer_is_ready(struct ipuv3_channel *channel, u32 buf_num);
  139. void ipu_idmac_select_buffer(struct ipuv3_channel *channel, u32 buf_num);
  140. void ipu_idmac_clear_buffer(struct ipuv3_channel *channel, u32 buf_num);
  141. /*
  142. * IPU Channel Parameter Memory (cpmem) functions
  143. */
  144. struct ipu_rgb {
  145. struct fb_bitfield red;
  146. struct fb_bitfield green;
  147. struct fb_bitfield blue;
  148. struct fb_bitfield transp;
  149. int bits_per_pixel;
  150. };
  151. struct ipu_image {
  152. struct v4l2_pix_format pix;
  153. struct v4l2_rect rect;
  154. dma_addr_t phys0;
  155. dma_addr_t phys1;
  156. };
  157. void ipu_cpmem_zero(struct ipuv3_channel *ch);
  158. void ipu_cpmem_set_resolution(struct ipuv3_channel *ch, int xres, int yres);
  159. void ipu_cpmem_set_stride(struct ipuv3_channel *ch, int stride);
  160. void ipu_cpmem_set_high_priority(struct ipuv3_channel *ch);
  161. void ipu_cpmem_set_buffer(struct ipuv3_channel *ch, int bufnum, dma_addr_t buf);
  162. void ipu_cpmem_interlaced_scan(struct ipuv3_channel *ch, int stride);
  163. void ipu_cpmem_set_axi_id(struct ipuv3_channel *ch, u32 id);
  164. void ipu_cpmem_set_burstsize(struct ipuv3_channel *ch, int burstsize);
  165. void ipu_cpmem_set_block_mode(struct ipuv3_channel *ch);
  166. void ipu_cpmem_set_rotation(struct ipuv3_channel *ch,
  167. enum ipu_rotate_mode rot);
  168. int ipu_cpmem_set_format_rgb(struct ipuv3_channel *ch,
  169. const struct ipu_rgb *rgb);
  170. int ipu_cpmem_set_format_passthrough(struct ipuv3_channel *ch, int width);
  171. void ipu_cpmem_set_yuv_interleaved(struct ipuv3_channel *ch, u32 pixel_format);
  172. void ipu_cpmem_set_yuv_planar_full(struct ipuv3_channel *ch,
  173. u32 pixel_format, int stride,
  174. int u_offset, int v_offset);
  175. void ipu_cpmem_set_yuv_planar(struct ipuv3_channel *ch,
  176. u32 pixel_format, int stride, int height);
  177. int ipu_cpmem_set_fmt(struct ipuv3_channel *ch, u32 drm_fourcc);
  178. int ipu_cpmem_set_image(struct ipuv3_channel *ch, struct ipu_image *image);
  179. void ipu_cpmem_dump(struct ipuv3_channel *ch);
  180. /*
  181. * IPU Display Controller (dc) functions
  182. */
  183. struct ipu_dc;
  184. struct ipu_di;
  185. struct ipu_dc *ipu_dc_get(struct ipu_soc *ipu, int channel);
  186. void ipu_dc_put(struct ipu_dc *dc);
  187. int ipu_dc_init_sync(struct ipu_dc *dc, struct ipu_di *di, bool interlaced,
  188. u32 pixel_fmt, u32 width);
  189. void ipu_dc_enable(struct ipu_soc *ipu);
  190. void ipu_dc_enable_channel(struct ipu_dc *dc);
  191. void ipu_dc_disable_channel(struct ipu_dc *dc);
  192. void ipu_dc_disable(struct ipu_soc *ipu);
  193. /*
  194. * IPU Display Interface (di) functions
  195. */
  196. struct ipu_di *ipu_di_get(struct ipu_soc *ipu, int disp);
  197. void ipu_di_put(struct ipu_di *);
  198. int ipu_di_disable(struct ipu_di *);
  199. int ipu_di_enable(struct ipu_di *);
  200. int ipu_di_get_num(struct ipu_di *);
  201. int ipu_di_adjust_videomode(struct ipu_di *di, struct videomode *mode);
  202. int ipu_di_init_sync_panel(struct ipu_di *, struct ipu_di_signal_cfg *sig);
  203. /*
  204. * IPU Display Multi FIFO Controller (dmfc) functions
  205. */
  206. struct dmfc_channel;
  207. int ipu_dmfc_enable_channel(struct dmfc_channel *dmfc);
  208. void ipu_dmfc_disable_channel(struct dmfc_channel *dmfc);
  209. int ipu_dmfc_alloc_bandwidth(struct dmfc_channel *dmfc,
  210. unsigned long bandwidth_mbs, int burstsize);
  211. void ipu_dmfc_free_bandwidth(struct dmfc_channel *dmfc);
  212. int ipu_dmfc_init_channel(struct dmfc_channel *dmfc, int width);
  213. struct dmfc_channel *ipu_dmfc_get(struct ipu_soc *ipu, int ipuv3_channel);
  214. void ipu_dmfc_put(struct dmfc_channel *dmfc);
  215. /*
  216. * IPU Display Processor (dp) functions
  217. */
  218. #define IPU_DP_FLOW_SYNC_BG 0
  219. #define IPU_DP_FLOW_SYNC_FG 1
  220. #define IPU_DP_FLOW_ASYNC0_BG 2
  221. #define IPU_DP_FLOW_ASYNC0_FG 3
  222. #define IPU_DP_FLOW_ASYNC1_BG 4
  223. #define IPU_DP_FLOW_ASYNC1_FG 5
  224. struct ipu_dp *ipu_dp_get(struct ipu_soc *ipu, unsigned int flow);
  225. void ipu_dp_put(struct ipu_dp *);
  226. int ipu_dp_enable(struct ipu_soc *ipu);
  227. int ipu_dp_enable_channel(struct ipu_dp *dp);
  228. void ipu_dp_disable_channel(struct ipu_dp *dp);
  229. void ipu_dp_disable(struct ipu_soc *ipu);
  230. int ipu_dp_setup_channel(struct ipu_dp *dp,
  231. enum ipu_color_space in, enum ipu_color_space out);
  232. int ipu_dp_set_window_pos(struct ipu_dp *, u16 x_pos, u16 y_pos);
  233. int ipu_dp_set_global_alpha(struct ipu_dp *dp, bool enable, u8 alpha,
  234. bool bg_chan);
  235. /*
  236. * IPU CMOS Sensor Interface (csi) functions
  237. */
  238. struct ipu_csi;
  239. int ipu_csi_init_interface(struct ipu_csi *csi,
  240. struct v4l2_mbus_config *mbus_cfg,
  241. struct v4l2_mbus_framefmt *mbus_fmt);
  242. bool ipu_csi_is_interlaced(struct ipu_csi *csi);
  243. void ipu_csi_get_window(struct ipu_csi *csi, struct v4l2_rect *w);
  244. void ipu_csi_set_window(struct ipu_csi *csi, struct v4l2_rect *w);
  245. void ipu_csi_set_test_generator(struct ipu_csi *csi, bool active,
  246. u32 r_value, u32 g_value, u32 b_value,
  247. u32 pix_clk);
  248. int ipu_csi_set_mipi_datatype(struct ipu_csi *csi, u32 vc,
  249. struct v4l2_mbus_framefmt *mbus_fmt);
  250. int ipu_csi_set_skip_smfc(struct ipu_csi *csi, u32 skip,
  251. u32 max_ratio, u32 id);
  252. int ipu_csi_set_dest(struct ipu_csi *csi, enum ipu_csi_dest csi_dest);
  253. int ipu_csi_enable(struct ipu_csi *csi);
  254. int ipu_csi_disable(struct ipu_csi *csi);
  255. struct ipu_csi *ipu_csi_get(struct ipu_soc *ipu, int id);
  256. void ipu_csi_put(struct ipu_csi *csi);
  257. void ipu_csi_dump(struct ipu_csi *csi);
  258. /*
  259. * IPU Image Converter (ic) functions
  260. */
  261. enum ipu_ic_task {
  262. IC_TASK_ENCODER,
  263. IC_TASK_VIEWFINDER,
  264. IC_TASK_POST_PROCESSOR,
  265. IC_NUM_TASKS,
  266. };
  267. struct ipu_ic;
  268. int ipu_ic_task_init(struct ipu_ic *ic,
  269. int in_width, int in_height,
  270. int out_width, int out_height,
  271. enum ipu_color_space in_cs,
  272. enum ipu_color_space out_cs);
  273. int ipu_ic_task_graphics_init(struct ipu_ic *ic,
  274. enum ipu_color_space in_g_cs,
  275. bool galpha_en, u32 galpha,
  276. bool colorkey_en, u32 colorkey);
  277. void ipu_ic_task_enable(struct ipu_ic *ic);
  278. void ipu_ic_task_disable(struct ipu_ic *ic);
  279. int ipu_ic_task_idma_init(struct ipu_ic *ic, struct ipuv3_channel *channel,
  280. u32 width, u32 height, int burst_size,
  281. enum ipu_rotate_mode rot);
  282. int ipu_ic_enable(struct ipu_ic *ic);
  283. int ipu_ic_disable(struct ipu_ic *ic);
  284. struct ipu_ic *ipu_ic_get(struct ipu_soc *ipu, enum ipu_ic_task task);
  285. void ipu_ic_put(struct ipu_ic *ic);
  286. void ipu_ic_dump(struct ipu_ic *ic);
  287. /*
  288. * IPU Sensor Multiple FIFO Controller (SMFC) functions
  289. */
  290. struct ipu_smfc *ipu_smfc_get(struct ipu_soc *ipu, unsigned int chno);
  291. void ipu_smfc_put(struct ipu_smfc *smfc);
  292. int ipu_smfc_enable(struct ipu_smfc *smfc);
  293. int ipu_smfc_disable(struct ipu_smfc *smfc);
  294. int ipu_smfc_map_channel(struct ipu_smfc *smfc, int csi_id, int mipi_id);
  295. int ipu_smfc_set_burstsize(struct ipu_smfc *smfc, int burstsize);
  296. int ipu_smfc_set_watermark(struct ipu_smfc *smfc, u32 set_level, u32 clr_level);
  297. enum ipu_color_space ipu_drm_fourcc_to_colorspace(u32 drm_fourcc);
  298. enum ipu_color_space ipu_pixelformat_to_colorspace(u32 pixelformat);
  299. enum ipu_color_space ipu_mbus_code_to_colorspace(u32 mbus_code);
  300. int ipu_stride_to_bytes(u32 pixel_stride, u32 pixelformat);
  301. bool ipu_pixelformat_is_planar(u32 pixelformat);
  302. int ipu_degrees_to_rot_mode(enum ipu_rotate_mode *mode, int degrees,
  303. bool hflip, bool vflip);
  304. int ipu_rot_mode_to_degrees(int *degrees, enum ipu_rotate_mode mode,
  305. bool hflip, bool vflip);
  306. struct ipu_client_platformdata {
  307. int csi;
  308. int di;
  309. int dc;
  310. int dp;
  311. int dma[2];
  312. struct device_node *of_node;
  313. };
  314. #endif /* __DRM_IPU_H__ */