ddp_wdma.c 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. #define LOG_TAG "WDMA"
  2. #include "ddp_log.h"
  3. #include <linux/delay.h>
  4. #include "ddp_reg.h"
  5. #include "ddp_matrix_para.h"
  6. #include "ddp_info.h"
  7. #include "ddp_wdma.h"
  8. #include "ddp_wdma_ex.h"
  9. #include "primary_display.h"
  10. #include "m4u.h"
  11. #define ALIGN_TO(x, n) \
  12. (((x) + ((n) - 1)) & ~((n) - 1))
  13. unsigned int wdma_index(DISP_MODULE_ENUM module)
  14. {
  15. int idx = 0;
  16. switch (module) {
  17. case DISP_MODULE_WDMA0:
  18. idx = 0;
  19. break;
  20. case DISP_MODULE_WDMA1:
  21. idx = 1;
  22. break;
  23. default:
  24. DDPERR("[DDP] error: invalid wdma module=%d\n", module); /* invalid module */
  25. ASSERT(0);
  26. }
  27. return idx;
  28. }
  29. int wdma_stop(DISP_MODULE_ENUM module, void *handle)
  30. {
  31. unsigned int idx = wdma_index(module);
  32. DISP_REG_SET(handle, idx * DISP_WDMA_INDEX_OFFSET + DISP_REG_WDMA_INTEN, 0x00);
  33. DISP_REG_SET(handle, idx * DISP_WDMA_INDEX_OFFSET + DISP_REG_WDMA_EN, 0x00);
  34. DISP_REG_SET(handle, idx * DISP_WDMA_INDEX_OFFSET + DISP_REG_WDMA_INTSTA, 0x00);
  35. return 0;
  36. }
  37. int wdma_reset(DISP_MODULE_ENUM module, void *handle)
  38. {
  39. unsigned int delay_cnt = 0;
  40. unsigned int idx = wdma_index(module);
  41. DISP_REG_SET(handle, idx * DISP_WDMA_INDEX_OFFSET + DISP_REG_WDMA_RST, 0x01); /* trigger soft reset */
  42. if (!handle) {
  43. while ((DISP_REG_GET(idx * DISP_WDMA_INDEX_OFFSET + DISP_REG_WDMA_FLOW_CTRL_DBG) &
  44. 0x1) == 0) {
  45. delay_cnt++;
  46. udelay(10);
  47. if (delay_cnt > 2000) {
  48. DDPERR("wdma%d reset timeout!\n", idx);
  49. break;
  50. }
  51. }
  52. } else {
  53. /* add comdq polling */
  54. }
  55. DISP_REG_SET(handle, idx * DISP_WDMA_INDEX_OFFSET + DISP_REG_WDMA_RST, 0x0); /* trigger soft reset */
  56. return 0;
  57. }
  58. unsigned int ddp_wdma_get_cur_addr(void)
  59. {
  60. return INREG32(DISP_REG_WDMA_DST_ADDR0);
  61. }