cmdq_device.h 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. #ifndef __CMDQ_DEVICE_H__
  2. #define __CMDQ_DEVICE_H__
  3. #include <linux/platform_device.h>
  4. #include <linux/device.h>
  5. #include "cmdq_def.h"
  6. #include "cmdq_mdp_common.h"
  7. #ifndef CMDQ_USE_CCF
  8. #include <mach/mt_clkmgr.h>
  9. #else
  10. #include <linux/clk.h>
  11. #endif /* !defined(CMDQ_USE_CCF) */
  12. #define DECLARE_ENABLE_HW_CLOCK(HW_NAME) uint32_t cmdq_dev_enable_clock_##HW_NAME(bool enable)
  13. DECLARE_ENABLE_HW_CLOCK(SMI_COMMON);
  14. DECLARE_ENABLE_HW_CLOCK(SMI_LARB0);
  15. #ifdef CMDQ_USE_LEGACY
  16. DECLARE_ENABLE_HW_CLOCK(MUTEX_32K);
  17. #endif
  18. #undef DECLARE_ENABLE_HW_CLOCK
  19. #ifndef CMDQ_USE_CCF
  20. typedef enum cg_clk_id cgCLKID;
  21. uint32_t cmdq_dev_enable_mtk_clock(bool enable, cgCLKID gateId, char *name);
  22. bool cmdq_dev_mtk_clock_is_enable(cgCLKID gateId);
  23. /* For test case used */
  24. void testcase_clkmgr_impl(cgCLKID gateId,
  25. char *name,
  26. const unsigned long testWriteReg,
  27. const uint32_t testWriteValue,
  28. const unsigned long testReadReg, const bool verifyWriteResult);
  29. #else
  30. void cmdq_dev_get_module_clock_by_name(const char *name, const char *clkName,
  31. struct clk **clk_module);
  32. uint32_t cmdq_dev_enable_device_clock(bool enable, struct clk *clk_module, const char *clkName);
  33. bool cmdq_dev_device_clock_is_enable(struct clk *clk_module);
  34. #endif /* !defined(CMDQ_USE_CCF) */
  35. struct device *cmdq_dev_get(void);
  36. /* interrupt index */
  37. uint32_t cmdq_dev_get_irq_id(void);
  38. uint32_t cmdq_dev_get_irq_secure_id(void);
  39. /* GCE clock */
  40. void cmdq_dev_enable_gce_clock(bool enable);
  41. bool cmdq_dev_gce_clock_is_enable(void);
  42. /* virtual address */
  43. long cmdq_dev_get_module_base_VA_GCE(void);
  44. long cmdq_dev_get_module_base_VA_MMSYS_CONFIG(void);
  45. long cmdq_dev_alloc_module_base_VA_by_name(const char *name);
  46. /* Other modules information */
  47. void cmdq_dev_free_module_base_VA(const long VA);
  48. long cmdq_dev_get_APXGPT2_count(void);
  49. /* physical address */
  50. void cmdq_dev_get_module_PA(const char *name, int index, long *startPA, long *endPA);
  51. long cmdq_dev_get_module_base_PA_GCE(void);
  52. /* GCE event */
  53. void cmdq_dev_init_event_table(struct device_node *node);
  54. void cmdq_dev_test_dts_correctness(void);
  55. /* device initialization / deinitialization */
  56. void cmdq_dev_init(struct platform_device *pDevice);
  57. void cmdq_dev_deinit(void);
  58. typedef struct cmdq_dts_setting {
  59. uint32_t prefetch_thread_count;
  60. uint32_t prefetch_size[CMDQ_MAX_THREAD_COUNT];
  61. } cmdq_dts_setting;
  62. /* callback when read resource from device tree */
  63. typedef void(*CMDQ_DEV_INIT_RESOURCE_CB) (uint32_t engineFlag, CMDQ_EVENT_ENUM resourceEvent);
  64. void cmdq_dev_get_dts_setting(cmdq_dts_setting *dts_setting);
  65. void cmdq_dev_init_resource(CMDQ_DEV_INIT_RESOURCE_CB init_cb);
  66. #endif /* __CMDQ_DEVICE_H__ */