mtk_rtc.h 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. #ifndef MTK_RTC_H
  2. #define MTK_RTC_H
  3. #include <linux/ioctl.h>
  4. #include <linux/rtc.h>
  5. #include <linux/types.h>
  6. typedef enum {
  7. RTC_GPIO_USER_WIFI = 8,
  8. RTC_GPIO_USER_GPS = 9,
  9. RTC_GPIO_USER_BT = 10,
  10. RTC_GPIO_USER_FM = 11,
  11. RTC_GPIO_USER_PMIC = 12,
  12. } rtc_gpio_user_t;
  13. #ifdef CONFIG_MTK_RTC
  14. /*
  15. * NOTE:
  16. * 1. RTC_GPIO always exports 32K enabled by some user even if the phone is powered off
  17. */
  18. extern unsigned long rtc_read_hw_time(void);
  19. extern void rtc_gpio_enable_32k(rtc_gpio_user_t user);
  20. extern void rtc_gpio_disable_32k(rtc_gpio_user_t user);
  21. extern bool rtc_gpio_32k_status(void);
  22. /* for AUDIOPLL (deprecated) */
  23. extern void rtc_enable_abb_32k(void);
  24. extern void rtc_disable_abb_32k(void);
  25. /* NOTE: used in Sleep driver to workaround Vrtc-Vore level shifter issue */
  26. extern void rtc_enable_writeif(void);
  27. extern void rtc_disable_writeif(void);
  28. extern void rtc_mark_recovery(void);
  29. #if defined(CONFIG_MTK_KERNEL_POWER_OFF_CHARGING)
  30. extern void rtc_mark_kpoc(void);
  31. #endif/*if defined(CONFIG_MTK_KERNEL_POWER_OFF_CHARGING)*/
  32. extern void rtc_mark_fast(void);
  33. extern u16 rtc_rdwr_uart_bits(u16 *val);
  34. extern void rtc_bbpu_power_down(void);
  35. extern void rtc_read_pwron_alarm(struct rtc_wkalrm *alm);
  36. extern int get_rtc_spare_fg_value(void);
  37. extern int set_rtc_spare_fg_value(int val);
  38. extern void rtc_irq_handler(void);
  39. extern bool crystal_exist_status(void);
  40. extern void mt_power_off(void);
  41. #else/*ifdef CONFIG_MTK_RTC*/
  42. #define rtc_read_hw_time() ({ 0; })
  43. #define rtc_gpio_enable_32k(user) do {} while (0)
  44. #define rtc_gpio_disable_32k(user) do {} while (0)
  45. #define rtc_gpio_32k_status() do {} while (0)
  46. #define rtc_enable_abb_32k() do {} while (0)
  47. #define rtc_disable_abb_32k() do {} while (0)
  48. #define rtc_enable_writeif() do {} while (0)
  49. #define rtc_disable_writeif() do {} while (0)
  50. #define rtc_mark_recovery() do {} while (0)
  51. #if defined(CONFIG_MTK_KERNEL_POWER_OFF_CHARGING)
  52. #define rtc_mark_kpoc() do {} while (0)
  53. #endif/*if defined(CONFIG_MTK_KERNEL_POWER_OFF_CHARGING)*/
  54. #define rtc_mark_fast() do {} while (0)
  55. #define rtc_rdwr_uart_bits(val) ({ 0; })
  56. #define rtc_bbpu_power_down() do {} while (0)
  57. #define rtc_read_pwron_alarm(alm) do {} while (0)
  58. #define get_rtc_spare_fg_value() ({ 0; })
  59. #define set_rtc_spare_fg_value(val) ({ 0; })
  60. #define rtc_irq_handler() do {} while (0)
  61. #define crystal_exist_status() do {} while (0)
  62. __weak void mt_power_off(void);
  63. #endif/*ifdef CONFIG_MTK_RTC*/
  64. #endif