isp_scale.h 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259
  1. #ifndef __ISP_SCALE_H__
  2. #define __ISP_SCALE_H__
  3. #include <linux/list.h>
  4. #include <linux/clk.h>
  5. #define XM_printf printk
  6. typedef unsigned char u8_t;
  7. typedef unsigned short u16_t;
  8. typedef unsigned int u32_t;
  9. typedef void (*xm_mid_line_callback) (void *xm_mid_line_user_data);
  10. #define ISBUF_FIFO_DEPTH 4
  11. /*isp scale use and 601in use */
  12. #define ISP_SCALE_EN 0x0
  13. #define ISP_SCALE_WB_START 0x4
  14. #define ISP_SCALE_CONTROL 0x8
  15. #define ISP_SCALE_VIDEO_ADDR1 0xC
  16. #define ISP_SCALE_VIDEO_ADDR2 0x10
  17. #define ISP_SCALE_VIDEO_ADDR3 0x14
  18. #define ISP_SCALE_VIDEO_SOURCE_SIZE 0x18
  19. #define ISP_SCALE_VIDEO_WINDOW_POINT 0x1c
  20. #define ISP_SCALE_VIDEO_WINDOW_SIZE 0x20
  21. #define ISP_SCALE_VIDEO_SIZE 0x24
  22. #define ISP_SCALE_SCALE_CTL 0x28
  23. #define ISP_SCALE_SCALE_VXMOD 0x2c
  24. #define ISP_SCALE_SCALE_CTL0 0x30
  25. #define ISP_SCALE_SCALE_CTL1 0x34
  26. #define ISP_SCALE_RIGHT_BOTTOM_CUT_NUM 0x38
  27. #define ISP_SCALE_SCALE_CTL2 0x3c
  28. #define ISP_SCALE_SCALE_CTL3 0x40
  29. #define ISP_SCALE_SCALE_CTL4 0x44
  30. #define ISP_SCALE_HSCAL_COS_VALUE 0x48
  31. #define ISP_SCALE_WB_DEST_YADDR 0x4c
  32. #define ISP_SCALE_WB_DEST_UADDR 0x50
  33. #define ISP_SCALE_WB_DEST_VADDR 0x54
  34. #define ISP_SCALE_WB_DATA_HSIZE_RAM 0x58
  35. #define ISP_SCALE_RESERVED 0x5c
  36. #define ISP_SCALE_INT_CTL 0x60
  37. #define ISP_SCALE_INT_STATUS 0x64
  38. #define ISP_SCALE_CLCD_INT_CLR 0x68
  39. #define ISP_SCALE_WR_Y_VCNT 0x6C
  40. //#defin rISP_SCALE_WB_YADDR 0x4c
  41. //#defin rISP_SCALE_WB_UVADDR 0x50
  42. #define ISP_SCALE_WB_STATUS 0x70
  43. #define ISP_SCALE_WB_CTL 0x74
  44. #define ISP_SCALE_WB_FINISH_YADDR 0x78
  45. #define ISP_SCALE_WB_FINISH_UADDR 0x78
  46. #define ISP_SCALE_FRAME_MASK 0x7c
  47. // \u8bbe\u7f6e\u6700\u5927\u652f\u6301\u7684ISP scalar\u5206\u8fa8\u7387
  48. // 1) \u5f53ISP scalar\u4ec5\u7528\u4e8eLCD\u663e\u793a\u8f93\u51fa\u65f6, \u53ef\u5c06ISP scalar\u7684\u5206\u8fa8\u7387\u8bbe\u7f6e\u4e3a\u663e\u793a\u5c4f\u7684\u89c6\u9891OSD\u5c3a\u5bf8
  49. // 2) \u5f53ISP scalar\u7528\u4e8eLCD\u663e\u793a\u8f93\u51fa\u53ca\u5176\u4ed6\u8f93\u51fa\u65f6, \u5c06ISP scalar\u7684\u5206\u8fa8\u7387\u8bbe\u7f6e\u4e3a\u6700\u5927\u5c3a\u5bf8
  50. #define MAX_SCALAR_WIDTH 480
  51. #define MAX_SCALAR_HEIGHT 272
  52. #define XM_ISP_SCALAR_ERRCODE_OK (0)
  53. #define XM_ISP_SCALAR_ERRCODE_ILLEGAL_PARA (-1) // \u65e0\u6548\u7684\u53c2\u6570
  54. #define XM_ISP_SCALAR_ERRCODE_DEV_NO_INIT (-2) // \u8bbe\u5907\u672a\u521d\u59cb\u5316
  55. #define XM_ISP_SCALAR_ERRCODE_OBJ_RE_CREATE (-3) // scalar\u4e3a\u4e92\u65a5\u5bf9\u8c61,\u6709\u4e14\u4ec5\u6709\u4e00\u4e2a\u5bf9\u8c61\u53ef\u4ee5\u521b\u5efa
  56. #define XM_ISP_SCALAR_ERRCODE_OBJ_INVALID (-4) // \u65e0\u6548\u5bf9\u8c61
  57. enum {
  58. XM_ISP_SCALAR_FORMAT_YUV420 = 0, // YUV420 planar (Y\U\V\u6570\u636e\u662f\u5206\u5f00\u5b58\u653e)
  59. XM_ISP_SCALAR_FORMAT_Y_UV420, // NV12, YUV420 Semi-Planar (U\u3001V\u662f\u4ea4\u53c9\u5b58\u653e)
  60. XM_ISP_SCALAR_FORMAT_YUV422, // YUV422 Planar (Y\U\V\u6570\u636e\u662f\u5206\u5f00\u5b58\u653e)
  61. XM_ISP_SCALAR_FORMAT_Y_UV422 // YUV422 Semi-Planar (U\u3001V\u662f\u4ea4\u53c9\u5b58\u653e)
  62. };
  63. // \u6e90\u56fe\u50cf\u901a\u9053\u5b9a\u4e49
  64. enum {
  65. XM_ISP_SCALAR_SRC_CHANNEL_ISP = 0, // ISP\u8f93\u51fa\u901a\u9053
  66. XM_ISP_SCALAR_SRC_CHANNEL_ITU601 // ITU601\u8f93\u51fa\u901a\u9053
  67. };
  68. // \u89c6\u9891\u56fe\u50cf\u7684\u884c\u540c\u6b65(hsync)/\u5217\u540c\u6b65(vsync)\u4fe1\u53f7\u6781\u6027\u5b9a\u4e49
  69. enum {
  70. XM_ISP_SCALAR_SRC_SYNC_PLOARITY_HIGH_LEVEL = 0, // \u9ad8\u7535\u5e73\u6709\u6548(ISP VIDEO\u8f93\u51fa\u7f3a\u7701\u4e3a\u9ad8\u7535\u5e73)
  71. XM_ISP_SCALAR_SRC_SYNC_PLOARITY_LOW_LEVEL = 1, // \u4f4e\u7535\u5e73\u6709\u6548
  72. };
  73. enum {
  74. XM_ISP_SCALAR_SRC_YCBCR_UYVY = 0,
  75. XM_ISP_SCALAR_SRC_YCBCR_YUYV = 1
  76. };
  77. #define XM_ISP_SCALAR_CALLBACK_COMMAND_READY 0x00000001 // ISP-Scalar\u5e27\u5df2\u6b63\u786e\u63a5\u6536\u5b8c\u6bd5, \u7b49\u5f85\u8c03\u7528\u8005\u5904\u7406
  78. #define XM_ISP_SCALAR_CALLBACK_COMMAND_RECYCLE 0x00000002 // ISP-Scalar\u5e27\u65e0\u6548, \u8c03\u7528\u8005\u9700\u8981\u5c06\u8be5\u5e27\u56de\u6536
  79. #define XM_ISP_SCALAR_CALLBACK_COMMAND_RESET 0x00000003 // ISP-Scalar\u5f02\u5e38, \u8c03\u7528\u8005\u9700\u8981\u590d\u4f4disp-scalar\u5bf9\u8c61\u5e76\u91cd\u65b0\u6267\u884c
  80. // 5 R/W 0 AXI SCALE write back middle finish interupt
  81. // 2 R/W 0 AXI SCALE write back bresp error interrupt
  82. // 0 R/W 0 AXI SCALE write back frame finish interupt
  83. #define FRAME_FINISH (1 << 0)
  84. #define write_back_bresp_error_interrupt (1 << 2)
  85. #define write_back_middle_finish_interupt (1 << 5)
  86. // 2 R/W 0 AXI SCALE write back middle finish interupt clear
  87. // Write 1 to clear
  88. // 1 R/W 0 AXI SCALE write back bresp error interrupt clear
  89. // Write 1 to clear
  90. //0 R/W 0 AXI SCALE write back frame finish interupt clear
  91. // Write 1 to clear
  92. #define CLEAR_FRAME_FINISH (1 << 0)
  93. #define write_back_bresp_error_interrupt_clear (1 << 1)
  94. #define write_back_middle_finish_interupt_clear (1 << 2)
  95. // ISP Scalar \u914d\u7f6e\u53c2\u6570\u8868
  96. // \u5b9a\u4e49\u4e86\u5982\u4f55\u5c06\u6e90\u89c6\u9891\u56fe\u50cf\u7684\u5b9a\u4e49\u533a\u57df(\u6e90\u7a97\u53e3, \u5305\u542b\u6307\u7a97\u53e3\u4f4d\u7f6e/\u7a97\u53e3\u5927\u5c0f )\u6216\u6574\u4e2a\u56fe\u50cf\u590d\u5236\u5230\u76ee\u6807\u89c6\u9891\u56fe\u50cf\u7684\u5b9a\u4e49\u533a\u57df(\u76ee\u6807\u7a97\u53e3, \u5305\u542b\u7a97\u53e3\u4f4d\u7f6e/\u7a97\u53e3\u5927\u5c0f)
  97. typedef struct _xm_isp_scalar_configuration_parameters {
  98. u16_t src_channel; // \u6e90\u56fe\u50cf\u7684\u8f93\u5165\u901a\u9053\u9009\u62e9 (\u5185\u90e8isp\u8f93\u51fa \u6216\u8005 \u5916\u90e8itu601\u8f93\u5165)
  99. // \u5185\u90e8isp\u8f93\u51fa\u4e00\u822c\u4e3aY_UV420(NV12)\u683c\u5f0f
  100. // \u5916\u90e8itu601\u8f93\u5165\u4e00\u822c\u4e3aYUV422, YUV420\u7b49\u683c\u5f0f
  101. u8_t src_hsync_polarity; // \u6e90\u56fe\u50cf\u7684\u884c\u540c\u6b65\u4fe1\u53f7\u6781\u6027\u9009\u62e9
  102. u8_t src_vsync_polarity; // \u6e90\u56fe\u50cf\u7684\u5217\u540c\u6b65\u4fe1\u53f7\u6781\u6027\u9009\u62e9
  103. // \u6e90\u56fe\u50cf\u7684\u5b9a\u4e49(cmos sensor\u6216\u8005601 in)
  104. u16_t src_format; // YUV422/Y_UV422/YUV420/Y_UV420
  105. u16_t src_ycbcr_sequence; // y/cbcr\u7684\u987a\u5e8f, 0:uyvy 1:yuyv
  106. u16_t src_width; // \u6e90\u56fe\u50cf\u7684\u5bbd\u5ea6
  107. u16_t src_height; // \u6e90\u56fe\u50cf\u7684\u9ad8\u5ea6
  108. u16_t src_stride; // \u6e90\u56fe\u50cf\u7684\u884c\u5bbd\u5ea6
  109. // \u6e90\u7a97\u53e3\u5b9a\u4e49(\u81ea\u5de6\u5411\u53f3, \u81ea\u4e0a\u800c\u4e0b)
  110. u16_t src_window_x; // \u6e90\u7a97\u53e3\u76f8\u5bf9\u4e8e\u6e90\u56fe\u50cf\u539f\u70b9\u7684X\u65b9\u5411\u504f\u79fb
  111. u16_t src_window_y; // \u6e90\u7a97\u53e3\u76f8\u5bf9\u4e8e\u6e90\u56fe\u50cf\u539f\u70b9\u7684Y\u65b9\u5411\u504f\u79fb
  112. u16_t src_window_width; // \u6e90\u7a97\u53e3\u7684\u5bbd\u5ea6
  113. u16_t src_window_height; // \u6e90\u7a97\u53e3\u7684\u9ad8\u5ea6
  114. // \u76ee\u6807\u56fe\u50cf\u5b9a\u4e49
  115. u16_t dst_format; // \u4ec5\u652f\u6301Y_UV420(NV12)
  116. u16_t dst_width; // \u76ee\u6807\u56fe\u50cf\u7684\u5bbd\u5ea6
  117. u16_t dst_height; // \u76ee\u6807\u56fe\u50cf\u7684\u9ad8\u5ea6
  118. u16_t dst_stride; // \u76ee\u6807\u56fe\u50cf\u7684\u884c\u5bbd\u5ea6, \u5fc5\u987b\u4e3a16\u7684\u500d\u6570
  119. // \u76ee\u6807\u7a97\u53e3\u5b9a\u4e49(\u81ea\u5de6\u5411\u53f3, \u81ea\u4e0a\u800c\u4e0b)
  120. u16_t dst_window_x; // \u76ee\u6807\u7a97\u53e3\u76f8\u5bf9\u4e8e\u76ee\u6807\u56fe\u50cf\u539f\u70b9\u7684X\u65b9\u5411\u504f\u79fb
  121. u16_t dst_window_y; // \u76ee\u6807\u7a97\u53e3\u76f8\u5bf9\u4e8e\u76ee\u6807\u56fe\u50cf\u539f\u70b9\u7684Y\u65b9\u5411\u504f\u79fb
  122. u16_t dst_window_width; // \u76ee\u6807\u7a97\u53e3\u7684\u5bbd\u5ea6
  123. u16_t dst_window_height; // \u76ee\u6807\u7a97\u53e3\u7684\u9ad8\u5ea6
  124. // \u90e8\u5206\u5904\u7406\u5b8c\u6210\u884c\u4e2d\u65ad
  125. u16_t mid_line; // mid_line\u8ba1\u6570\u503c(\u4ee5\u884c\u4e3a\u5355\u4f4d)
  126. void * mid_line_user_data; // \u7528\u6237\u79c1\u6709\u6570\u636e
  127. xm_mid_line_callback mid_line_user_callback; // \u7528\u6237\u56de\u8c03\u51fd\u6570
  128. } xm_isp_scalar_configuration_parameters;
  129. enum isp_buf_status{
  130. ISBUF_STATUS_FREE,
  131. ISBUF_STATUS_BUSY,
  132. ISBUF_STATUS_READY,
  133. };
  134. struct isp_scale_buf {
  135. unsigned int yaddr;
  136. unsigned int uvaddr;
  137. };
  138. struct ispbuf_id {
  139. int id;
  140. struct list_head list;
  141. };
  142. struct ark_isp_scale_context {
  143. int irq;
  144. struct device *dev;
  145. void __iomem *mmio_base;
  146. void __iomem *sys_base;
  147. struct clk *clk;
  148. spinlock_t lock;
  149. int isbuf_num;
  150. struct isp_scale_buf isbuf[ISBUF_FIFO_DEPTH];
  151. int isbuf_status[ISBUF_FIFO_DEPTH];
  152. struct ispbuf_id isbuf_id[ISBUF_FIFO_DEPTH];
  153. struct list_head isbuf_push_list;
  154. xm_isp_scalar_configuration_parameters config;
  155. };
  156. struct ark_isp_scale_device {
  157. const char *driver_name;
  158. const char *name;
  159. int major;
  160. int minor_start;
  161. int minor_num;
  162. int num;
  163. int irq;
  164. struct cdev cdev;
  165. struct class *isp_scale_class;
  166. struct device *isp_scale_device;
  167. struct fasync_struct *async_queue_wb;
  168. wait_queue_head_t frame_finish_waitq;
  169. struct ark_isp_scale_context context;
  170. };
  171. struct isp_scale_init_para {
  172. unsigned int src_channel;
  173. unsigned int src_hsync_polarity;
  174. unsigned int src_vsync_polarity;
  175. unsigned int src_format;
  176. unsigned int src_ycbcr_sequence;
  177. unsigned int src_width;
  178. unsigned int src_height;
  179. unsigned int src_window_x;
  180. unsigned int src_window_y;
  181. unsigned int src_window_width;
  182. unsigned int src_window_height;
  183. unsigned int dst_width;
  184. unsigned int dst_height;
  185. unsigned int mid_line_counter;
  186. };
  187. struct isp_scale_sbuf_para {
  188. int num;
  189. struct isp_scale_buf buf[ISBUF_FIFO_DEPTH];
  190. };
  191. /*************************************************************************
  192. * Ioctl command definition
  193. *************************************************************************/
  194. #define ISP_SCALE_IOCTL_BASE 0x98
  195. #define ISP_SCALE_IOCTL_INIT _IOW(ISP_SCALE_IOCTL_BASE, 0, struct isp_scale_init_para)
  196. #define ISP_SCALE_IOCTL_SET_BUFFER _IOW(ISP_SCALE_IOCTL_BASE, 1, struct isp_scale_sbuf_para)
  197. #define ISP_SCALE_IOCTL_START _IO(ISP_SCALE_IOCTL_BASE, 2)
  198. #define ISP_SCALE_IOCTL_STOP _IO(ISP_SCALE_IOCTL_BASE, 3)
  199. #define ISP_SCALE_IOCTL_GET_READY _IOR(ISP_SCALE_IOCTL_BASE, 4, struct isp_scale_buf)
  200. #define ISP_SCALE_IOCTL_SET_FREE _IOW(ISP_SCALE_IOCTL_BASE, 5, struct isp_scale_buf)
  201. int xm_isp_scalar_config (struct ark_isp_scale_context *context,
  202. xm_isp_scalar_configuration_parameters *scalar_parameters);
  203. int ark_isp_scale_dev_init(struct ark_isp_scale_context *context);
  204. irqreturn_t ark_isp_scale_intr_handler(int irq, void *dev_id);
  205. void isp_scale_buffer_init(struct ark_isp_scale_context *context);
  206. void isp_scale_softreset(struct ark_isp_scale_context *context);
  207. static inline void isp_scale_push_buffer(struct ark_isp_scale_context *context,
  208. int frameid)
  209. {
  210. writel(context->isbuf[frameid].yaddr, context->mmio_base + ISP_SCALE_WB_DEST_YADDR);
  211. writel(context->isbuf[frameid].uvaddr, context->mmio_base + ISP_SCALE_WB_DEST_UADDR);
  212. }
  213. #endif