jpeg_drv_enc.c 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454
  1. #include <linux/kernel.h>
  2. /* #include <linux/xlog.h> */
  3. #include "jpeg_drv_reg.h"
  4. #include "jpeg_drv_common.h"
  5. #define JPEG_ENC_RST_BIT 0x1
  6. #define JPEG_ENC_CTRL_ENABLE_BIT 0x01
  7. #define JPEG_ENC_CTRL_DIS_GMC_BIT 0x02
  8. #define JPEG_ENC_CTRL_INT_EN_BIT 0x04
  9. #define JPEG_ENC_CTRL_YUV_BIT 0x18
  10. #define JPEG_ENC_CTRL_FILE_FORMAT_BIT 0x20
  11. #define JPEG_ENC_CTRL_GRAY_EN_BIT 0x80
  12. #define JPEG_ENC_CTRL_ULTRA_HIGH_EN_BIT 0x200
  13. #define JPEG_ENC_CTRL_RESTART_EN_BIT 0x400
  14. #define JPEG_ENC_CTRL_BURST_TYPE_MASK 0x00007000
  15. #define JPEG_ENC_CTRL_BURST_TYPE_SHIFT_COUNT 12
  16. #define JPEG_ENC_EN_DIS_GMC (1 << 2)
  17. #define JPEG_ENC_EN_JFIF_EXIF (1 << 5)
  18. #define JPEG_ENC_EN_SELF_INIT (1 << 16)
  19. #define JPEG_ENC_DEBUG_INFO0_GMC_IDLE_MASK (1 << 13)
  20. kal_uint32 _jpeg_enc_int_status = 0;
  21. int jpeg_isr_enc_lisr(void)
  22. {
  23. unsigned int tmp, tmp1;
  24. /* _jpeg_enc_int_status = REG_JPEG_ENC_INTERRUPT_STATUS; */
  25. tmp1 = REG_JPEG_ENC_INTERRUPT_STATUS;
  26. tmp = tmp1 & (JPEG_DRV_ENC_INT_STATUS_MASK_ALLIRQ);
  27. if (tmp) {
  28. _jpeg_enc_int_status = tmp;
  29. /* / clear the interrupt status register */
  30. /* if(_jpeg_enc_int_status) */
  31. /* { */
  32. IMG_REG_WRITE(0, REG_ADDR_JPEG_ENC_INTERRUPT_STATUS);
  33. return 0;
  34. /* } */
  35. } else if (_jpeg_enc_int_status) {
  36. IMG_REG_WRITE(0, REG_ADDR_JPEG_ENC_INTERRUPT_STATUS);
  37. return 0;
  38. }
  39. return -1;
  40. }
  41. kal_uint32 jpeg_drv_enc_set_src_image(kal_uint32 width, kal_uint32 height, kal_uint32 yuv_format,
  42. kal_uint32 totalEncDU)
  43. {
  44. kal_uint32 ret = 1;
  45. ret &= jpeg_drv_enc_set_img_size(width, height);
  46. ret &= jpeg_drv_enc_set_encFormat(yuv_format);
  47. ret &= jpeg_drv_enc_set_blk_num(totalEncDU);
  48. return ret;
  49. }
  50. kal_uint32 jpeg_drv_enc_set_src_buf(kal_uint32 yuv_format, kal_uint32 img_stride,
  51. kal_uint32 mem_stride, kal_uint32 srcAddr, kal_uint32 srcAddr_C)
  52. {
  53. kal_uint32 ret = 1;
  54. if (yuv_format == 0x00 || yuv_format == 0x01) {
  55. if ((mem_stride & 0x1f) || (img_stride & 0x1f)) {
  56. JPEG_MSG
  57. ("JPEGENC: set image/memory stride not align 0x1f in fmt %x(%x/%x)!!\n",
  58. yuv_format, mem_stride, img_stride);
  59. ret = 0;
  60. }
  61. }
  62. ret &= jpeg_drv_enc_set_image_stride(img_stride);
  63. ret &= jpeg_drv_enc_set_memory_stride(mem_stride);
  64. ret &= jpeg_drv_enc_set_luma_addr(srcAddr);
  65. ret &= jpeg_drv_enc_set_chroma_addr(srcAddr_C);
  66. return ret;
  67. }
  68. kal_uint32 jpeg_drv_enc_ctrl_cfg(kal_uint32 exif_en, kal_uint32 quality,
  69. kal_uint32 restart_interval)
  70. {
  71. jpeg_drv_enc_set_quality(quality);
  72. jpeg_drv_enc_set_restart_interval(restart_interval);
  73. jpeg_drv_enc_set_EncodeMode(exif_en);
  74. return 1;
  75. }
  76. void jpeg_drv_enc_dump_reg(void)
  77. {
  78. unsigned int reg_value = 0;
  79. unsigned int index = 0;
  80. JPEG_MSG("===== JPEG ENC DUMP =====\n");
  81. for (index = 0x100; index < JPEG_ENC_REG_COUNT; index += 4) {
  82. /* reg_value = ioread32(JPEG_ENC_BASE + index); */
  83. IMG_REG_READ(reg_value, JPEG_ENC_BASE + index);
  84. JPEG_MSG("+0x%x 0x%08x\n", index, reg_value);
  85. }
  86. }
  87. void jpeg_drv_enc_start(void)
  88. {
  89. unsigned int u4Value;
  90. u4Value = REG_JPEG_ENC_CTRL;
  91. u4Value |= (JPEG_ENC_CTRL_INT_EN_BIT | JPEG_ENC_CTRL_ENABLE_BIT);
  92. IMG_REG_WRITE((u4Value), REG_ADDR_JPEG_ENC_CTRL);
  93. /* REG_JPEG_ENC_CTRL |= (JPEG_ENC_CTRL_INT_EN_BIT | JPEG_ENC_CTRL_ENABLE_BIT); */
  94. }
  95. /* workaround for jpeg odd read operation at cg gating state */
  96. void jpeg_drv_enc_verify_state_and_reset(void)
  97. {
  98. unsigned int temp, value;
  99. IMG_REG_WRITE((0), REG_ADDR_JPEG_ENC_RSTB);
  100. IMG_REG_WRITE((0), REG_ADDR_JPEG_ENC_RSTB);
  101. IMG_REG_WRITE((1), REG_ADDR_JPEG_ENC_RSTB);
  102. IMG_REG_WRITE((1), REG_ADDR_JPEG_ENC_RSTB);
  103. IMG_REG_READ(temp, REG_ADDR_JPEG_ENC_ULTRA_THRES);
  104. IMG_REG_READ(value, REG_ADDR_JPEG_ENC_DMA_ADDR0);
  105. /* issue happen, need to do 1 read at cg gating state */
  106. if (value == 0xFFFFFFFF) {
  107. JPEG_MSG("JPGENC APB R/W issue found, start to do recovery!\n");
  108. jpeg_drv_enc_power_off();
  109. IMG_REG_READ(value, REG_ADDR_JPEG_ENC_ULTRA_THRES);
  110. jpeg_drv_enc_power_on();
  111. }
  112. IMG_REG_WRITE((0), REG_ADDR_JPEG_ENC_CODEC_SEL);
  113. _jpeg_enc_int_status = 0;
  114. }
  115. void jpeg_drv_enc_reset(void)
  116. {
  117. IMG_REG_WRITE((0), REG_ADDR_JPEG_ENC_RSTB);
  118. IMG_REG_WRITE((1), REG_ADDR_JPEG_ENC_RSTB);
  119. IMG_REG_WRITE((0), REG_ADDR_JPEG_ENC_CODEC_SEL);
  120. _jpeg_enc_int_status = 0;
  121. }
  122. kal_uint32 jpeg_drv_enc_warm_reset(void)
  123. {
  124. kal_uint32 timeout = 0xFFFFF;
  125. REG_JPEG_ENC_CTRL &= ~JPEG_ENC_CTRL_ENABLE_BIT;
  126. REG_JPEG_ENC_CTRL |= JPEG_ENC_CTRL_ENABLE_BIT;
  127. while (0 == (REG_JPEG_ENC_DEBUG_INFO0 & JPEG_ENC_DEBUG_INFO0_GMC_IDLE_MASK)) {
  128. timeout--;
  129. if (0 == timeout) {
  130. JPEG_MSG("Wait for GMC IDLE timeout\n");
  131. return 0;
  132. }
  133. }
  134. REG_JPEG_ENC_RSTB &= ~(JPEG_ENC_RST_BIT);
  135. REG_JPEG_ENC_RSTB |= JPEG_ENC_RST_BIT;
  136. IMG_REG_WRITE((0), REG_ADDR_JPEG_ENC_CODEC_SEL);
  137. _jpeg_enc_int_status = 0;
  138. return 1;
  139. }
  140. kal_uint32 jpeg_drv_enc_set_encFormat(kal_uint32 encFormat)
  141. {
  142. kal_uint32 val;
  143. unsigned int u4Value;
  144. if (encFormat & (~3)) {
  145. JPEG_ERR("JPEG_DRV_ENC: set encFormat Err %d!!\n", encFormat);
  146. return 0;
  147. }
  148. val = (encFormat & 3) << 3;
  149. #if 0
  150. /* REG_JPEG_ENC_CTRL &= ~JPEG_ENC_CTRL_YUV_BIT; */
  151. /* */
  152. /* REG_JPEG_ENC_CTRL |= val; */
  153. #else
  154. u4Value = REG_JPEG_ENC_CTRL;
  155. u4Value &= ~JPEG_ENC_CTRL_YUV_BIT;
  156. u4Value |= val;
  157. IMG_REG_WRITE((u4Value), REG_ADDR_JPEG_ENC_CTRL);
  158. #endif
  159. return 1;
  160. }
  161. kal_uint32 jpeg_drv_enc_set_quality(kal_uint32 quality)
  162. {
  163. unsigned int u4Value;
  164. if (quality == 0x8 || quality == 0xC) {
  165. JPEG_MSG("JPEGENC: set quality failed\n");
  166. return 0;
  167. }
  168. u4Value = REG_JPEG_ENC_QUALITY;
  169. u4Value = (u4Value & 0xFFFF0000) | quality;
  170. IMG_REG_WRITE((u4Value), REG_ADDR_JPEG_ENC_QUALITY);
  171. return 1;
  172. }
  173. kal_uint32 jpeg_drv_enc_set_img_size(kal_uint32 width, kal_uint32 height)
  174. {
  175. unsigned int u4Value;
  176. if ((width & 0xffff0000) || (height & 0xffff0000)) {
  177. JPEG_MSG("JPEGENC: img size exceed 65535, (%x, %x)!!\n", width, height);
  178. return 0;
  179. }
  180. u4Value = (width << 16) | height;
  181. IMG_REG_WRITE((u4Value), REG_ADDR_JPEG_ENC_IMG_SIZE);
  182. return 1;
  183. }
  184. kal_uint32 jpeg_drv_enc_set_blk_num(kal_uint32 blk_num) /* NO_USE */
  185. {
  186. if (blk_num < 4)
  187. return 0;
  188. IMG_REG_WRITE((blk_num), REG_ADDR_JPEG_ENC_BLK_NUM);
  189. return 1;
  190. }
  191. kal_uint32 jpeg_drv_enc_set_luma_addr(kal_uint32 src_luma_addr)
  192. {
  193. if (src_luma_addr & 0x0F)
  194. JPEG_MSG("JPEGENC: set LUMA addr not align (%x)!!\n", src_luma_addr);
  195. IMG_REG_WRITE((src_luma_addr), REG_ADDR_JPEG_ENC_SRC_LUMA_ADDR);
  196. return 1;
  197. }
  198. kal_uint32 jpeg_drv_enc_set_chroma_addr(kal_uint32 src_chroma_addr)
  199. {
  200. if (src_chroma_addr & 0x0F)
  201. JPEG_MSG("JPEGENC: set CHROMA addr not align (%x)!!\n", src_chroma_addr);
  202. IMG_REG_WRITE((src_chroma_addr), REG_ADDR_JPEG_ENC_SRC_CHROMA_ADDR);
  203. return 1;
  204. }
  205. kal_uint32 jpeg_drv_enc_set_memory_stride(kal_uint32 mem_stride)
  206. {
  207. if (mem_stride & 0x0F) {
  208. JPEG_MSG("JPEGENC: set memory stride failed, not align to 0x1f (%x)!!\n",
  209. mem_stride);
  210. return 0;
  211. }
  212. IMG_REG_WRITE((mem_stride), REG_ADDR_JPEG_ENC_STRIDE);
  213. return 1;
  214. }
  215. kal_uint32 jpeg_drv_enc_set_image_stride(kal_uint32 img_stride)
  216. {
  217. if (img_stride & 0x0F) {
  218. JPEG_MSG("JPEGENC: set image stride failed, not align to 0x0f (%x)!!\n",
  219. img_stride);
  220. return 0;
  221. }
  222. IMG_REG_WRITE((img_stride), REG_ADDR_JPEG_ENC_IMG_STRIDE);
  223. return 1;
  224. }
  225. void jpeg_drv_enc_set_restart_interval(kal_uint32 restart_interval)
  226. {
  227. unsigned int u4Value;
  228. u4Value = REG_JPEG_ENC_CTRL;
  229. if (0 != restart_interval) {
  230. u4Value |= JPEG_ENC_CTRL_RESTART_EN_BIT;
  231. IMG_REG_WRITE((u4Value), REG_ADDR_JPEG_ENC_CTRL);
  232. } else {
  233. u4Value &= ~JPEG_ENC_CTRL_RESTART_EN_BIT;
  234. IMG_REG_WRITE((u4Value), REG_ADDR_JPEG_ENC_CTRL);
  235. }
  236. IMG_REG_WRITE((restart_interval), REG_ADDR_JPEG_ENC_RST_MCU_NUM);
  237. }
  238. kal_uint32 jpeg_drv_enc_set_offset_addr(kal_uint32 offset)
  239. {
  240. if (offset & 0x0F) {
  241. JPEG_MSG("JPEGENC:WARN set offset addr %x\n", offset);
  242. /* return 0; */
  243. }
  244. IMG_REG_WRITE((offset), REG_ADDR_JPEG_ENC_OFFSET_ADDR);
  245. return 1;
  246. }
  247. kal_uint32 jpeg_drv_enc_set_dst_buff(kal_uint32 dst_addr, kal_uint32 stall_size,
  248. kal_uint32 init_offset, kal_uint32 offset_mask)
  249. {
  250. if (stall_size < 624) {
  251. JPEG_MSG("JPEGENC:stall offset less than 624 to write header %d!!\n", stall_size);
  252. return 0;
  253. }
  254. if (offset_mask & 0x0F) {
  255. JPEG_MSG("JPEGENC: set offset addr %x\n", offset_mask);
  256. /* return 0; */
  257. }
  258. IMG_REG_WRITE((init_offset & (~0xF)), REG_ADDR_JPEG_ENC_OFFSET_ADDR);
  259. IMG_REG_WRITE((offset_mask & 0xF), REG_ADDR_JPEG_ENC_BYTE_OFFSET_MASK);
  260. IMG_REG_WRITE((dst_addr & (~0xF)), REG_ADDR_JPEG_ENC_DST_ADDR0);
  261. IMG_REG_WRITE(((dst_addr + stall_size) & (~0xF)), REG_ADDR_JPEG_ENC_STALL_ADDR0);
  262. return 1;
  263. }
  264. /* 0:JPG mode, 1:JFIF/EXIF mode */
  265. void jpeg_drv_enc_set_EncodeMode(kal_uint32 exif_en)
  266. {
  267. unsigned int u4Value;
  268. u4Value = REG_JPEG_ENC_CTRL;
  269. u4Value &= ~(JPEG_ENC_CTRL_FILE_FORMAT_BIT);
  270. IMG_REG_WRITE((u4Value), REG_ADDR_JPEG_ENC_CTRL);
  271. if (exif_en) {
  272. u4Value = REG_JPEG_ENC_CTRL;
  273. u4Value |= JPEG_ENC_EN_JFIF_EXIF;
  274. IMG_REG_WRITE((u4Value), REG_ADDR_JPEG_ENC_CTRL);
  275. }
  276. }
  277. void jpeg_drv_enc_set_gmc_disable_bit(void)
  278. {
  279. unsigned int u4Value;
  280. u4Value = REG_JPEG_ENC_CTRL;
  281. u4Value |= JPEG_ENC_EN_DIS_GMC;
  282. IMG_REG_WRITE((u4Value), REG_ADDR_JPEG_ENC_CTRL);
  283. }
  284. void jpeg_drv_enc_set_burst_type(kal_uint32 burst_type)
  285. {
  286. unsigned int u4Value;
  287. u4Value = REG_JPEG_ENC_CTRL;
  288. u4Value &= ~JPEG_ENC_CTRL_BURST_TYPE_MASK;
  289. u4Value |= (burst_type << JPEG_ENC_CTRL_BURST_TYPE_SHIFT_COUNT);
  290. IMG_REG_WRITE((u4Value), REG_ADDR_JPEG_ENC_CTRL);
  291. }
  292. kal_uint32 jpeg_drv_enc_get_cycle_count(void)
  293. {
  294. return REG_JPEG_ENC_TOTAL_CYCLE;
  295. }
  296. kal_uint32 jpeg_drv_enc_get_file_size(void)
  297. {
  298. return REG_JPEG_ENC_DMA_ADDR0 - REG_JPEG_ENC_DST_ADDR0;
  299. /* return REG_JPEG_ENC_CURR_DMA_ADDR - REG_JPEG_ENC_DST_ADDR0; */
  300. }
  301. #ifdef FPGA_VERSION
  302. kal_uint32 jpeg_drv_enc_get_result(void)
  303. {
  304. kal_uint32 file_size;
  305. file_size = jpeg_drv_enc_get_file_size();
  306. return file_size;
  307. }
  308. #else
  309. kal_uint32 jpeg_drv_enc_get_result(kal_uint32 *fileSize)
  310. {
  311. *fileSize = jpeg_drv_enc_get_file_size();
  312. if (_jpeg_enc_int_status & JPEG_DRV_ENC_INT_STATUS_DONE)
  313. return 0;
  314. else if (_jpeg_enc_int_status & JPEG_DRV_ENC_INT_STATUS_STALL)
  315. return 1;
  316. else if (_jpeg_enc_int_status & JPEG_DRV_ENC_INT_STATUS_VCODEC_IRQ)
  317. return 2;
  318. JPEG_MSG("JPEGENC: int_st %x!!\n", _jpeg_enc_int_status);
  319. return 3;
  320. }
  321. #endif