cmdq_device.c 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. #include "cmdq_device.h"
  2. #include "cmdq_core.h"
  3. #include "cmdq_mdp.h"
  4. /* #include <mach/mt_irq.h> */
  5. /* device tree */
  6. #include <linux/of.h>
  7. #include <linux/of_irq.h>
  8. #include <linux/of_address.h>
  9. #include <linux/io.h>
  10. typedef struct CmdqDeviceStruct {
  11. struct device *pDev;
  12. long regBaseVA; /* considering 64 bit kernel, use long */
  13. long regBasePA;
  14. uint32_t irqId;
  15. uint32_t irqSecId;
  16. } CmdqDeviceStruct;
  17. static CmdqDeviceStruct gCmdqDev;
  18. static long gMMSYS_CONFIG_Base_VA;
  19. struct device *cmdq_dev_get(void)
  20. {
  21. return gCmdqDev.pDev;
  22. }
  23. const uint32_t cmdq_dev_get_irq_id(void)
  24. {
  25. return gCmdqDev.irqId;
  26. }
  27. const uint32_t cmdq_dev_get_irq_secure_id(void)
  28. {
  29. return gCmdqDev.irqSecId;
  30. }
  31. const long cmdq_dev_get_module_base_VA_GCE(void)
  32. {
  33. return gCmdqDev.regBaseVA;
  34. }
  35. const long cmdq_dev_get_module_base_PA_GCE(void)
  36. {
  37. return gCmdqDev.regBasePA;
  38. }
  39. const long cmdq_dev_get_module_base_VA_MMSYS_CONFIG(void)
  40. {
  41. return gMMSYS_CONFIG_Base_VA;
  42. }
  43. const long cmdq_dev_alloc_module_base_VA_by_name(const char *name)
  44. {
  45. unsigned long VA;
  46. struct device_node *node = NULL;
  47. node = of_find_compatible_node(NULL, NULL, name);
  48. VA = (unsigned long)of_iomap(node, 0);
  49. CMDQ_LOG("DEV: VA(%s): 0x%lx\n", name, VA);
  50. return VA;
  51. }
  52. void cmdq_dev_free_module_base_VA(const long VA)
  53. {
  54. iounmap((void *)VA);
  55. }
  56. void cmdq_dev_init_module_base_VA(void)
  57. {
  58. #ifdef CMDQ_OF_SUPPORT
  59. gMMSYS_CONFIG_Base_VA = 0;
  60. gMMSYS_CONFIG_Base_VA =
  61. cmdq_dev_alloc_module_base_VA_by_name("mediatek,mt8173-mmsys");
  62. if (0 == gMMSYS_CONFIG_Base_VA) {
  63. gMMSYS_CONFIG_Base_VA =
  64. cmdq_dev_alloc_module_base_VA_by_name("mediatek,mt8163-mmsys");
  65. }
  66. #endif
  67. cmdq_mdp_init_module_base_VA();
  68. }
  69. void cmdq_dev_deinit_module_base_VA(void)
  70. {
  71. #ifdef CMDQ_OF_SUPPORT
  72. cmdq_dev_free_module_base_VA(cmdq_dev_get_module_base_VA_MMSYS_CONFIG());
  73. #endif
  74. cmdq_mdp_deinit_module_base_VA();
  75. }
  76. const long of_getPA(struct device_node *dev, int index)
  77. {
  78. struct resource res;
  79. if (of_address_to_resource(dev, index, &res))
  80. return 0;
  81. return res.start;
  82. }
  83. void cmdq_dev_init(struct platform_device *pDevice)
  84. {
  85. #ifdef CMDQ_OF_SUPPORT
  86. struct device_node *node = pDevice->dev.of_node;
  87. #endif
  88. /* init cmdq device dependent data */
  89. do {
  90. memset(&gCmdqDev, 0x0, sizeof(struct CmdqDeviceStruct));
  91. gCmdqDev.pDev = &pDevice->dev;
  92. #ifdef CMDQ_OF_SUPPORT
  93. gCmdqDev.regBaseVA = (unsigned long)of_iomap(node, 0);
  94. /* gCmdqDev.regBasePA = GCE_BASE_PA; */
  95. gCmdqDev.regBasePA = of_getPA(node, 0);
  96. if (0 == gCmdqDev.regBasePA)
  97. CMDQ_ERR("ERROR!!! get GCE PA from device tree error. PA:%ld",
  98. gCmdqDev.regBasePA);
  99. gCmdqDev.irqId = irq_of_parse_and_map(node, 0);
  100. gCmdqDev.irqSecId = irq_of_parse_and_map(node, 1);
  101. #else
  102. gCmdqDev.regBaseVA = (long)ioremap(GCE_BASE_PA, 0x1000);
  103. gCmdqDev.regBasePA = GCE_BASE_PA;
  104. gCmdqDev.irqId = CQ_DMA_IRQ_BIT_ID;
  105. gCmdqDev.irqSecId = CQ_DMA_SEC_IRQ_BIT_ID;
  106. #endif
  107. CMDQ_LOG
  108. ("[CMDQ] platform_dev: dev: %p, PA: %lx, VA: %lx, irqId: %d, irqSecId:%d\n",
  109. gCmdqDev.pDev, gCmdqDev.regBasePA, gCmdqDev.regBaseVA, gCmdqDev.irqId,
  110. gCmdqDev.irqSecId);
  111. } while (0);
  112. /* init module VA */
  113. cmdq_dev_init_module_base_VA();
  114. }
  115. void cmdq_dev_deinit(void)
  116. {
  117. cmdq_dev_deinit_module_base_VA();
  118. /* deinit cmdq device dependent data */
  119. do {
  120. #ifdef CMDQ_OF_SUPPORT
  121. cmdq_dev_free_module_base_VA(cmdq_dev_get_module_base_VA_GCE());
  122. gCmdqDev.regBaseVA = 0;
  123. #else
  124. /* do nothing */
  125. #endif
  126. } while (0);
  127. }