modem_lpcon_struct.h 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. /**
  2. * SPDX-FileCopyrightText: 2023 Espressif Systems (Shanghai) CO LTD
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. #pragma once
  7. #include <stdint.h>
  8. #ifdef __cplusplus
  9. extern "C" {
  10. #endif
  11. typedef union {
  12. struct {
  13. uint32_t clk_en:1;
  14. uint32_t reserved_1:31;
  15. };
  16. uint32_t val;
  17. } modem_lpcon_test_conf_reg_t;
  18. typedef union {
  19. struct {
  20. uint32_t clk_coex_lp_sel_osc_slow:1;
  21. uint32_t clk_coex_lp_sel_osc_fast:1;
  22. uint32_t clk_coex_lp_sel_xtal:1;
  23. uint32_t clk_coex_lp_sel_xtal32k:1;
  24. uint32_t clk_coex_lp_div_num:12;
  25. uint32_t reserved_16:16;
  26. };
  27. uint32_t val;
  28. } modem_lpcon_coex_lp_clk_conf_reg_t;
  29. typedef union {
  30. struct {
  31. uint32_t reserved_0:1;
  32. uint32_t clk_coex_en:1;
  33. uint32_t clk_i2c_mst_en:1;
  34. uint32_t reserved_3:2;
  35. uint32_t clk_fe_mem_en:1;
  36. uint32_t reserved_6:26;
  37. };
  38. uint32_t val;
  39. } modem_lpcon_clk_conf_reg_t;
  40. typedef union {
  41. struct {
  42. uint32_t reserved_0:1;
  43. uint32_t clk_coex_fo:1;
  44. uint32_t clk_i2c_mst_fo:1;
  45. uint32_t reserved_3:2;
  46. uint32_t clk_fe_mem_fo:1;
  47. uint32_t reserved_6:26;
  48. };
  49. uint32_t val;
  50. } modem_lpcon_clk_conf_force_on_reg_t;
  51. typedef union {
  52. struct {
  53. uint32_t pwr_tick_target:6;
  54. uint32_t reserved_6:26;
  55. };
  56. uint32_t val;
  57. } modem_lpcon_tick_conf_reg_t;
  58. typedef union {
  59. struct {
  60. uint32_t reserved_0:1;
  61. uint32_t rst_coex:1;
  62. uint32_t rst_i2c_mst:1;
  63. uint32_t reserved_3:29;
  64. };
  65. uint32_t val;
  66. } modem_lpcon_rst_conf_reg_t;
  67. typedef union {
  68. struct {
  69. uint32_t reserved_0:2;
  70. uint32_t agc_mem_force_pu:1;
  71. uint32_t agc_mem_force_pd:1;
  72. uint32_t pbus_mem_force_pu:1;
  73. uint32_t pbus_mem_force_pd:1;
  74. uint32_t reserved_6:2;
  75. uint32_t i2c_mst_mem_force_pu:1;
  76. uint32_t i2c_mst_mem_force_pd:1;
  77. uint32_t chan_freq_mem_force_pu:1;
  78. uint32_t chan_freq_mem_force_pd:1;
  79. uint32_t modem_pwr_mem_wp:3;
  80. uint32_t modem_pwr_mem_wa:3;
  81. uint32_t modem_pwr_mem_ra:2;
  82. uint32_t modem_pwr_mem_rm:4;
  83. uint32_t reserved_24:8;
  84. };
  85. uint32_t val;
  86. } modem_lpcon_mem_conf_reg_t;
  87. typedef union {
  88. struct {
  89. uint32_t date:28;
  90. uint32_t reserved_28:4;
  91. };
  92. uint32_t val;
  93. } modem_lpcon_date_reg_t;
  94. typedef struct {
  95. volatile modem_lpcon_test_conf_reg_t test_conf;
  96. volatile modem_lpcon_coex_lp_clk_conf_reg_t coex_lp_clk_conf;
  97. volatile modem_lpcon_clk_conf_reg_t clk_conf;
  98. volatile modem_lpcon_clk_conf_force_on_reg_t clk_conf_force_on;
  99. volatile modem_lpcon_tick_conf_reg_t tick_conf;
  100. volatile modem_lpcon_rst_conf_reg_t rst_conf;
  101. volatile modem_lpcon_mem_conf_reg_t mem_conf;
  102. volatile modem_lpcon_date_reg_t date;
  103. } modem_lpcon_dev_t;
  104. extern modem_lpcon_dev_t MODEM_LPCON;
  105. #ifndef __cplusplus
  106. _Static_assert(sizeof(modem_lpcon_dev_t) == 0x20, "Invalid size of modem_lpcon_dev_t structure");
  107. #endif
  108. #ifdef __cplusplus
  109. }
  110. #endif