Lines Matching full:hal

12 #include "hal/wdt_types.h"
13 #include "hal/wdt_hal.h"
14 #include "hal/mwdt_ll.h"
19 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
21 //Initialize HAL context in wdt_hal_init()
22 memset(hal, 0, sizeof(wdt_hal_context_t)); in wdt_hal_init()
24 hal->mwdt_dev = &TIMERG0; in wdt_hal_init()
28 hal->mwdt_dev = &TIMERG1; in wdt_hal_init()
32 hal->rwdt_dev = RWDT_DEV_GET(); in wdt_hal_init()
34 hal->inst = wdt_inst; in wdt_hal_init()
36 if (hal->inst == WDT_RWDT) { in wdt_hal_init()
38 rwdt_ll_write_protect_disable(hal->rwdt_dev); in wdt_hal_init()
40 rwdt_ll_disable(hal->rwdt_dev); in wdt_hal_init()
41 rwdt_ll_disable_stage(hal->rwdt_dev, WDT_STAGE0); in wdt_hal_init()
42 rwdt_ll_disable_stage(hal->rwdt_dev, WDT_STAGE1); in wdt_hal_init()
43 rwdt_ll_disable_stage(hal->rwdt_dev, WDT_STAGE2); in wdt_hal_init()
44 rwdt_ll_disable_stage(hal->rwdt_dev, WDT_STAGE3); in wdt_hal_init()
47 rwdt_ll_set_edge_intr(hal->rwdt_dev, false); in wdt_hal_init()
48 rwdt_ll_set_level_intr(hal->rwdt_dev, enable_intr); in wdt_hal_init()
51 rwdt_ll_set_chip_reset_width(hal->rwdt_dev, 0); in wdt_hal_init()
52 rwdt_ll_set_chip_reset_en(hal->rwdt_dev, false); in wdt_hal_init()
54 rwdt_ll_clear_intr_status(hal->rwdt_dev); in wdt_hal_init()
55 rwdt_ll_set_intr_enable(hal->rwdt_dev, enable_intr); in wdt_hal_init()
58 rwdt_ll_set_appcpu_reset_en(hal->rwdt_dev, true); in wdt_hal_init()
60 rwdt_ll_set_procpu_reset_en(hal->rwdt_dev, true); in wdt_hal_init()
61 rwdt_ll_set_pause_in_sleep_en(hal->rwdt_dev, true); in wdt_hal_init()
62 rwdt_ll_set_cpu_reset_length(hal->rwdt_dev, WDT_RESET_SIG_LENGTH_3_2us); in wdt_hal_init()
63 rwdt_ll_set_sys_reset_length(hal->rwdt_dev, WDT_RESET_SIG_LENGTH_3_2us); in wdt_hal_init()
65 rwdt_ll_write_protect_enable(hal->rwdt_dev); in wdt_hal_init()
68 mwdt_ll_write_protect_disable(hal->mwdt_dev); in wdt_hal_init()
70 mwdt_ll_disable(hal->mwdt_dev); in wdt_hal_init()
71 mwdt_ll_disable_stage(hal->mwdt_dev, 0); in wdt_hal_init()
72 mwdt_ll_disable_stage(hal->mwdt_dev, 1); in wdt_hal_init()
73 mwdt_ll_disable_stage(hal->mwdt_dev, 2); in wdt_hal_init()
74 mwdt_ll_disable_stage(hal->mwdt_dev, 3); in wdt_hal_init()
77 mwdt_ll_set_edge_intr(hal->mwdt_dev, false); in wdt_hal_init()
78 mwdt_ll_set_level_intr(hal->mwdt_dev, enable_intr); in wdt_hal_init()
80 mwdt_ll_clear_intr_status(hal->mwdt_dev); in wdt_hal_init()
81 mwdt_ll_set_intr_enable(hal->mwdt_dev, enable_intr); in wdt_hal_init()
83 mwdt_ll_set_cpu_reset_length(hal->mwdt_dev, WDT_RESET_SIG_LENGTH_3_2us); in wdt_hal_init()
84 mwdt_ll_set_sys_reset_length(hal->mwdt_dev, WDT_RESET_SIG_LENGTH_3_2us); in wdt_hal_init()
85 mwdt_ll_set_clock_source(hal->mwdt_dev, MWDT_CLK_SRC_DEFAULT); in wdt_hal_init()
86 mwdt_ll_enable_clock(hal->mwdt_dev, true); in wdt_hal_init()
88 mwdt_ll_set_prescaler(hal->mwdt_dev, prescaler); in wdt_hal_init()
90 mwdt_ll_write_protect_enable(hal->mwdt_dev); in wdt_hal_init()
94 void wdt_hal_deinit(wdt_hal_context_t *hal) in wdt_hal_deinit() argument
96 if (hal->inst == WDT_RWDT) { in wdt_hal_deinit()
98 rwdt_ll_write_protect_disable(hal->rwdt_dev); in wdt_hal_deinit()
100 rwdt_ll_feed(hal->rwdt_dev); in wdt_hal_deinit()
101 rwdt_ll_disable(hal->rwdt_dev); in wdt_hal_deinit()
102 rwdt_ll_clear_intr_status(hal->rwdt_dev); in wdt_hal_deinit()
103 rwdt_ll_set_intr_enable(hal->rwdt_dev, false); in wdt_hal_deinit()
105 rwdt_ll_write_protect_enable(hal->rwdt_dev); in wdt_hal_deinit()
108 mwdt_ll_write_protect_disable(hal->mwdt_dev); in wdt_hal_deinit()
110 mwdt_ll_feed(hal->mwdt_dev); in wdt_hal_deinit()
111 mwdt_ll_disable(hal->mwdt_dev); in wdt_hal_deinit()
112 mwdt_ll_clear_intr_status(hal->mwdt_dev); in wdt_hal_deinit()
113 mwdt_ll_set_intr_enable(hal->mwdt_dev, false); in wdt_hal_deinit()
114 mwdt_ll_enable_clock(hal->mwdt_dev, false); in wdt_hal_deinit()
116 mwdt_ll_write_protect_enable(hal->mwdt_dev); in wdt_hal_deinit()
118 //Deinit HAL context in wdt_hal_deinit()
119 hal->mwdt_dev = NULL; in wdt_hal_deinit()