mt_gpufreq.h 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. #ifndef _MT_GPUFREQ_H
  2. #define _MT_GPUFREQ_H
  3. #include <linux/module.h>
  4. /*
  5. * CONFIG
  6. */
  7. /**************************************************
  8. * Define low battery voltage support
  9. ***************************************************/
  10. #define MT_GPUFREQ_LOW_BATT_VOLT_PROTECT
  11. /**************************************************
  12. * Define low battery volume support
  13. ***************************************************/
  14. #define MT_GPUFREQ_LOW_BATT_VOLUME_PROTECT
  15. /**************************************************
  16. * Define oc support
  17. ***************************************************/
  18. /* #define MT_GPUFREQ_OC_PROTECT */
  19. /**************************************************
  20. * VCORE DVFS option
  21. ***************************************************/
  22. #define MT_GPUFREQ_VCOREFS_ENABLED
  23. /**************************************************
  24. * GPU DVFS input boost feature
  25. ***************************************************/
  26. #define MT_GPUFREQ_INPUT_BOOST
  27. /***************************
  28. * Define for dynamic power table update
  29. ****************************/
  30. #define MT_GPUFREQ_DYNAMIC_POWER_TABLE_UPDATE
  31. /***************************
  32. * Define for random test
  33. ****************************/
  34. /* #define MT_GPU_DVFS_RANDOM_TEST */
  35. /***************************
  36. * Define for performance test
  37. ****************************/
  38. /* #define MT_GPUFREQ_PERFORMANCE_TEST */
  39. /***************************
  40. * Define for SRAM debugging
  41. ****************************/
  42. #ifdef CONFIG_MTK_RAM_CONSOLE
  43. #define MT_GPUFREQ_AEE_RR_REC
  44. #endif
  45. /**********************************
  46. * Power table struct for thermal
  47. **********************************/
  48. struct mt_gpufreq_power_table_info {
  49. unsigned int gpufreq_khz;
  50. unsigned int gpufreq_volt;
  51. unsigned int gpufreq_power;
  52. };
  53. /******************************
  54. * Forward ref
  55. *******************************/
  56. extern u32 get_devinfo_with_index(u32 index);
  57. #ifdef MT_GPUFREQ_AEE_RR_REC
  58. extern void aee_rr_rec_gpu_dvfs_vgpu(u8 val);
  59. extern void aee_rr_rec_gpu_dvfs_oppidx(u8 val);
  60. extern void aee_rr_rec_gpu_dvfs_status(u8 val);
  61. extern u8 aee_rr_curr_gpu_dvfs_status(void);
  62. #endif
  63. /*****************
  64. * extern function
  65. ******************/
  66. /* extern int mt_gpufreq_state_set(int enabled); */
  67. extern unsigned int mt_gpufreq_get_cur_freq_index(void);
  68. extern unsigned int mt_gpufreq_get_cur_freq(void);
  69. extern unsigned int mt_gpufreq_get_cur_volt(void);
  70. extern unsigned int mt_gpufreq_get_dvfs_table_num(void);
  71. extern int mt_gpufreq_target(unsigned int idx);
  72. extern int mt_gpufreq_voltage_enable_set(unsigned int enable);
  73. extern unsigned int mt_gpufreq_get_freq_by_idx(unsigned int idx);
  74. extern void mt_gpufreq_thermal_protect(unsigned int limited_power);
  75. extern unsigned int mt_gpufreq_get_max_power(void);
  76. extern unsigned int mt_gpufreq_get_min_power(void);
  77. extern unsigned int mt_gpufreq_get_thermal_limit_index(void);
  78. extern unsigned int mt_gpufreq_get_thermal_limit_freq(void);
  79. extern void mt_gpufreq_set_power_limit_by_pbm(unsigned int limited_power);
  80. extern unsigned int mt_gpufreq_get_leakage_mw(void);
  81. /*****************
  82. * power limit notification
  83. ******************/
  84. typedef void (*gpufreq_power_limit_notify) (unsigned int);
  85. extern void mt_gpufreq_power_limit_notify_registerCB(gpufreq_power_limit_notify pCB);
  86. /*****************
  87. * input boost notification
  88. ******************/
  89. typedef void (*gpufreq_input_boost_notify) (unsigned int);
  90. extern void mt_gpufreq_input_boost_notify_registerCB(gpufreq_input_boost_notify pCB);
  91. /*****************
  92. * profiling purpose
  93. ******************/
  94. typedef void (*sampler_func) (unsigned int);
  95. extern void mt_gpufreq_setfreq_registerCB(sampler_func pCB);
  96. extern void mt_gpufreq_setvolt_registerCB(sampler_func pCB);
  97. #endif