Lines Matching full:hal
9 #include "hal/wdt_types.h"
10 #include "hal/wdt_hal.h"
14 void wdt_hal_init(wdt_hal_context_t *hal, wdt_inst_t wdt_inst, uint32_t prescaler, bool enable_intr) in wdt_hal_init() argument
16 //Initialize HAL context in wdt_hal_init()
17 memset(hal, 0, sizeof(wdt_hal_context_t)); in wdt_hal_init()
19 hal->mwdt_dev = &TIMERG0; in wdt_hal_init()
23 hal->mwdt_dev = &TIMERG1; in wdt_hal_init()
27 hal->rwdt_dev = RWDT_DEV_GET(); in wdt_hal_init()
29 hal->inst = wdt_inst; in wdt_hal_init()
31 if (hal->inst == WDT_RWDT) { in wdt_hal_init()
33 rwdt_ll_write_protect_disable(hal->rwdt_dev); in wdt_hal_init()
35 rwdt_ll_disable(hal->rwdt_dev); in wdt_hal_init()
36 rwdt_ll_disable_stage(hal->rwdt_dev, WDT_STAGE0); in wdt_hal_init()
37 rwdt_ll_disable_stage(hal->rwdt_dev, WDT_STAGE1); in wdt_hal_init()
38 rwdt_ll_disable_stage(hal->rwdt_dev, WDT_STAGE2); in wdt_hal_init()
39 rwdt_ll_disable_stage(hal->rwdt_dev, WDT_STAGE3); in wdt_hal_init()
42 rwdt_ll_set_edge_intr(hal->rwdt_dev, false); in wdt_hal_init()
43 rwdt_ll_set_level_intr(hal->rwdt_dev, enable_intr); in wdt_hal_init()
46 rwdt_ll_set_chip_reset_width(hal->rwdt_dev, 0); in wdt_hal_init()
47 rwdt_ll_set_chip_reset_en(hal->rwdt_dev, false); in wdt_hal_init()
49 rwdt_ll_clear_intr_status(hal->rwdt_dev); in wdt_hal_init()
50 rwdt_ll_set_intr_enable(hal->rwdt_dev, enable_intr); in wdt_hal_init()
53 rwdt_ll_set_appcpu_reset_en(hal->rwdt_dev, true); in wdt_hal_init()
55 rwdt_ll_set_procpu_reset_en(hal->rwdt_dev, true); in wdt_hal_init()
56 rwdt_ll_set_pause_in_sleep_en(hal->rwdt_dev, true); in wdt_hal_init()
57 rwdt_ll_set_cpu_reset_length(hal->rwdt_dev, WDT_RESET_SIG_LENGTH_3_2us); in wdt_hal_init()
58 rwdt_ll_set_sys_reset_length(hal->rwdt_dev, WDT_RESET_SIG_LENGTH_3_2us); in wdt_hal_init()
60 rwdt_ll_write_protect_enable(hal->rwdt_dev); in wdt_hal_init()
63 mwdt_ll_write_protect_disable(hal->mwdt_dev); in wdt_hal_init()
65 mwdt_ll_disable(hal->mwdt_dev); in wdt_hal_init()
66 mwdt_ll_disable_stage(hal->mwdt_dev, 0); in wdt_hal_init()
67 mwdt_ll_disable_stage(hal->mwdt_dev, 1); in wdt_hal_init()
68 mwdt_ll_disable_stage(hal->mwdt_dev, 2); in wdt_hal_init()
69 mwdt_ll_disable_stage(hal->mwdt_dev, 3); in wdt_hal_init()
72 mwdt_ll_set_edge_intr(hal->mwdt_dev, false); in wdt_hal_init()
73 mwdt_ll_set_level_intr(hal->mwdt_dev, enable_intr); in wdt_hal_init()
75 mwdt_ll_clear_intr_status(hal->mwdt_dev); in wdt_hal_init()
76 mwdt_ll_set_intr_enable(hal->mwdt_dev, enable_intr); in wdt_hal_init()
78 mwdt_ll_set_cpu_reset_length(hal->mwdt_dev, WDT_RESET_SIG_LENGTH_3_2us); in wdt_hal_init()
79 mwdt_ll_set_sys_reset_length(hal->mwdt_dev, WDT_RESET_SIG_LENGTH_3_2us); in wdt_hal_init()
80 mwdt_ll_set_clock_source(hal->mwdt_dev, MWDT_CLK_SRC_DEFAULT); in wdt_hal_init()
81 mwdt_ll_enable_clock(hal->mwdt_dev, true); in wdt_hal_init()
83 mwdt_ll_set_prescaler(hal->mwdt_dev, prescaler); in wdt_hal_init()
85 mwdt_ll_write_protect_enable(hal->mwdt_dev); in wdt_hal_init()
89 void wdt_hal_deinit(wdt_hal_context_t *hal) in wdt_hal_deinit() argument
91 if (hal->inst == WDT_RWDT) { in wdt_hal_deinit()
93 rwdt_ll_write_protect_disable(hal->rwdt_dev); in wdt_hal_deinit()
95 rwdt_ll_feed(hal->rwdt_dev); in wdt_hal_deinit()
96 rwdt_ll_disable(hal->rwdt_dev); in wdt_hal_deinit()
97 rwdt_ll_clear_intr_status(hal->rwdt_dev); in wdt_hal_deinit()
98 rwdt_ll_set_intr_enable(hal->rwdt_dev, false); in wdt_hal_deinit()
100 rwdt_ll_write_protect_enable(hal->rwdt_dev); in wdt_hal_deinit()
103 mwdt_ll_write_protect_disable(hal->mwdt_dev); in wdt_hal_deinit()
105 mwdt_ll_feed(hal->mwdt_dev); in wdt_hal_deinit()
106 mwdt_ll_disable(hal->mwdt_dev); in wdt_hal_deinit()
107 mwdt_ll_clear_intr_status(hal->mwdt_dev); in wdt_hal_deinit()
108 mwdt_ll_set_intr_enable(hal->mwdt_dev, false); in wdt_hal_deinit()
109 mwdt_ll_enable_clock(hal->mwdt_dev, false); in wdt_hal_deinit()
111 mwdt_ll_write_protect_enable(hal->mwdt_dev); in wdt_hal_deinit()
113 //Deinit HAL context in wdt_hal_deinit()
114 hal->mwdt_dev = NULL; in wdt_hal_deinit()
117 void wdt_hal_config_stage(wdt_hal_context_t *hal, wdt_stage_t stage, uint32_t timeout_ticks, wdt_st… in wdt_hal_config_stage() argument
119 if (hal->inst == WDT_RWDT) { in wdt_hal_config_stage()
120 rwdt_ll_config_stage(hal->rwdt_dev, stage, timeout_ticks, behavior); in wdt_hal_config_stage()
122 mwdt_ll_config_stage(hal->mwdt_dev, stage, timeout_ticks, behavior); in wdt_hal_config_stage()
128 void wdt_hal_write_protect_disable(wdt_hal_context_t *hal) in wdt_hal_write_protect_disable() argument
130 if (hal->inst == WDT_RWDT) { in wdt_hal_write_protect_disable()
131 rwdt_ll_write_protect_disable(hal->rwdt_dev); in wdt_hal_write_protect_disable()
133 mwdt_ll_write_protect_disable(hal->mwdt_dev); in wdt_hal_write_protect_disable()
137 void wdt_hal_write_protect_enable(wdt_hal_context_t *hal) in wdt_hal_write_protect_enable() argument
139 if (hal->inst == WDT_RWDT) { in wdt_hal_write_protect_enable()
140 rwdt_ll_write_protect_enable(hal->rwdt_dev); in wdt_hal_write_protect_enable()
142 mwdt_ll_write_protect_enable(hal->mwdt_dev); in wdt_hal_write_protect_enable()
146 void wdt_hal_enable(wdt_hal_context_t *hal) in wdt_hal_enable() argument
148 if (hal->inst == WDT_RWDT) { in wdt_hal_enable()
149 rwdt_ll_feed(hal->rwdt_dev); in wdt_hal_enable()
150 rwdt_ll_enable(hal->rwdt_dev); in wdt_hal_enable()
152 mwdt_ll_feed(hal->mwdt_dev); in wdt_hal_enable()
153 mwdt_ll_enable(hal->mwdt_dev); in wdt_hal_enable()
157 void wdt_hal_disable(wdt_hal_context_t *hal) in wdt_hal_disable() argument
159 if (hal->inst == WDT_RWDT) { in wdt_hal_disable()
160 rwdt_ll_disable(hal->rwdt_dev); in wdt_hal_disable()
162 mwdt_ll_disable(hal->mwdt_dev); in wdt_hal_disable()
166 void wdt_hal_handle_intr(wdt_hal_context_t *hal) in wdt_hal_handle_intr() argument
168 if (hal->inst == WDT_RWDT) { in wdt_hal_handle_intr()
169 rwdt_ll_feed(hal->rwdt_dev); in wdt_hal_handle_intr()
170 rwdt_ll_clear_intr_status(hal->rwdt_dev); in wdt_hal_handle_intr()
172 mwdt_ll_feed(hal->mwdt_dev); in wdt_hal_handle_intr()
173 mwdt_ll_clear_intr_status(hal->mwdt_dev); in wdt_hal_handle_intr()
177 void wdt_hal_feed(wdt_hal_context_t *hal) in wdt_hal_feed() argument
179 if (hal->inst == WDT_RWDT) { in wdt_hal_feed()
180 rwdt_ll_feed(hal->rwdt_dev); in wdt_hal_feed()
182 mwdt_ll_feed(hal->mwdt_dev); in wdt_hal_feed()
186 void wdt_hal_set_flashboot_en(wdt_hal_context_t *hal, bool enable) in wdt_hal_set_flashboot_en() argument
188 if (hal->inst == WDT_RWDT) { in wdt_hal_set_flashboot_en()
189 rwdt_ll_set_flashboot_en(hal->rwdt_dev, enable); in wdt_hal_set_flashboot_en()
191 mwdt_ll_set_flashboot_en(hal->mwdt_dev, enable); in wdt_hal_set_flashboot_en()
195 bool wdt_hal_is_enabled(wdt_hal_context_t *hal) in wdt_hal_is_enabled() argument
197 if (hal->inst == WDT_RWDT) { in wdt_hal_is_enabled()
198 return rwdt_ll_check_if_enabled(hal->rwdt_dev); in wdt_hal_is_enabled()
200 return mwdt_ll_check_if_enabled(hal->mwdt_dev); in wdt_hal_is_enabled()