soc_sleep.h 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. /*
  2. * Copyright (c) 2018 Actions Semiconductor Co., Ltd
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. /**
  7. * @file sleep for Actions SoC
  8. */
  9. #ifndef _ACTIONS_SOC_SLEEP_H_
  10. #define _ACTIONS_SOC_SLEEP_H_
  11. enum S_WK_SRC_TYPE {
  12. SLEEP_WK_SRC_BT = 0x00,
  13. SLEEP_WK_SRC_GPIO,
  14. SLEEP_WK_SRC_PMU,
  15. SLEEP_WK_SRC_T0,
  16. SLEEP_WK_SRC_T1,
  17. SLEEP_WK_SRC_T2,
  18. SLEEP_WK_SRC_T3,
  19. SLEEP_WK_SRC_TWS,
  20. SLEEP_WK_SRC_SPI0MT,
  21. SLEEP_WK_SRC_SPI1MT,
  22. SLEEP_WK_SRC_IIC0MT,
  23. SLEEP_WK_SRC_IIC1MT,
  24. };
  25. enum WK_RUN_TYPE {
  26. WK_RUN_IN_SRAM = 0x00, /*only sram can use*/
  27. WK_RUN_IN_NOR, /*only sram & nor can use */
  28. WK_RUN_IN_SYTEM, /*only sram nor psram can use */
  29. WK_RUN_MAX,
  30. };
  31. enum WK_CB_RC{
  32. WK_CB_SLEEP_AGAIN = 0x00,
  33. WK_CB_RUN_SYSTEM,
  34. };
  35. typedef enum WK_CB_RC (*sleep_wk_callback_t)(enum S_WK_SRC_TYPE wk_src);
  36. typedef enum WK_RUN_TYPE (*sleep_wk_prepare_t)(enum S_WK_SRC_TYPE wk_src);
  37. struct sleep_wk_fun_data {
  38. sleep_wk_callback_t wk_cb;
  39. sleep_wk_prepare_t wk_prep;
  40. struct sleep_wk_fun_data *next;
  41. };
  42. enum S_WK_SRC_TYPE sys_s3_wksrc_get(void);
  43. void sys_s3_wksrc_set(enum S_WK_SRC_TYPE src);
  44. int sleep_register_wk_callback(enum S_WK_SRC_TYPE wk_src, struct sleep_wk_fun_data *fn_data);
  45. int sleep_sensor_code_set(void *code_addr, uint32_t code_len);
  46. #endif /* _ACTIONS_SOC_SLEEP_H_ */