18#ifndef __VSF_TEMPLATE_WDT_H__
19#define __VSF_TEMPLATE_WDT_H__
39#ifndef VSF_WDT_CFG_MULTI_CLASS
40# define VSF_WDT_CFG_MULTI_CLASS ENABLED
43#if defined(VSF_HW_WDT_COUNT) && !defined(VSF_HW_WDT_MASK)
51# define VSF_HW_WDT_MASK VSF_HAL_COUNT_TO_MASK(VSF_HW_WDT_COUNT)
54#if defined(VSF_HW_WDT_MASK) && !defined(VSF_HW_WDT_COUNT)
62# define VSF_HW_WDT_COUNT VSF_HAL_MASK_TO_COUNT(VSF_HW_WDT_MASK)
86#ifndef VSF_WDT_CFG_PREFIX
87# if (VSF_WDT_CFG_MULTI_CLASS == DISABLED) && defined(VSF_HW_WDT_COUNT) && (VSF_HW_WDT_COUNT != 0)
88# define VSF_WDT_CFG_PREFIX vsf_hw
90# define VSF_WDT_CFG_PREFIX vsf
104#ifndef VSF_WDT_CFG_FUNCTION_RENAME
105# define VSF_WDT_CFG_FUNCTION_RENAME ENABLED
117#ifndef VSF_WDT_CFG_REIMPLEMENT_TYPE_MODE
118# define VSF_WDT_CFG_REIMPLEMENT_TYPE_MODE DISABLED
133#ifndef VSF_WDT_CFG_REIMPLEMENT_TYPE_CFG
134# define VSF_WDT_CFG_REIMPLEMENT_TYPE_CFG DISABLED
149#ifndef VSF_WDT_CFG_REIMPLEMENT_TYPE_CAPABILITY
150# define VSF_WDT_CFG_REIMPLEMENT_TYPE_CAPABILITY DISABLED
163#ifndef VSF_WDT_CFG_INHERIT_HAL_CAPABILITY
164# define VSF_WDT_CFG_INHERIT_HAL_CAPABILITY ENABLED
176#ifndef VSF_WDT_CFG_REIMPLEMENT_TYPE_CTRL
177# define VSF_WDT_CFG_REIMPLEMENT_TYPE_CTRL DISABLED
191#define VSF_WDT_APIS(__prefix_name) \
192 __VSF_HAL_TEMPLATE_API(__prefix_name, vsf_err_t, wdt, init, VSF_MCONNECT(__prefix_name, _t) *wdt_ptr, vsf_wdt_cfg_t *cfg_ptr) \
193 __VSF_HAL_TEMPLATE_API(__prefix_name, void, wdt, fini, VSF_MCONNECT(__prefix_name, _t) *wdt_ptr) \
194 __VSF_HAL_TEMPLATE_API(__prefix_name, vsf_err_t, wdt, get_configuration, VSF_MCONNECT(__prefix_name, _t) *wdt_ptr, vsf_wdt_cfg_t *cfg_ptr) \
195 __VSF_HAL_TEMPLATE_API(__prefix_name, fsm_rt_t, wdt, enable, VSF_MCONNECT(__prefix_name, _t) *wdt_ptr) \
196 __VSF_HAL_TEMPLATE_API(__prefix_name, fsm_rt_t, wdt, disable, VSF_MCONNECT(__prefix_name, _t) *wdt_ptr) \
197 __VSF_HAL_TEMPLATE_API(__prefix_name, vsf_wdt_capability_t, wdt, capability, VSF_MCONNECT(__prefix_name, _t) *wdt_ptr) \
198 __VSF_HAL_TEMPLATE_API(__prefix_name, void, wdt, feed, VSF_MCONNECT(__prefix_name, _t) *wdt_ptr) \
199 __VSF_HAL_TEMPLATE_API(__prefix_name, vsf_err_t, wdt, ctrl, VSF_MCONNECT(__prefix_name, _t) *wdt_ptr, vsf_wdt_ctrl_t ctrl, void* param)
203#if VSF_WDT_CFG_REIMPLEMENT_TYPE_MODE == DISABLED
250 VSF_WDT_MODE_PRESCALER_1 = (0 << 2),
251 VSF_WDT_MODE_PRESCALER_2 = (1 << 2),
252 VSF_WDT_MODE_PRESCALER_4 = (2 << 2),
253 #define VSF_WDT_MODE_PRESCALER_8 VSF_WDT_MODE_PRESCALER_8
254 #define VSF_WDT_MODE_PRESCALER_1 VSF_WDT_MODE_PRESCALER_1
255 #define VSF_WDT_MODE_PRESCALER_2 VSF_WDT_MODE_PRESCALER_2
256 #define VSF_WDT_MODE_PRESCALER_4 VSF_WDT_MODE_PRESCALER_4
257 #define VSF_WDT_MODE_PRESCALER_MASK (0x03 << 2)
274#ifndef VSF_WDT_MODE_RESET_MASK
282#ifndef VSF_WDT_MODE_ALL_BITS_MASK
285#ifdef VSF_WDT_MODE_PRESCALER_MASK
286 | VSF_WDT_MODE_PRESCALER_MASK
291#if VSF_WDT_CFG_REIMPLEMENT_TYPE_CFG == DISABLED
333#if VSF_WDT_CFG_REIMPLEMENT_TYPE_CTRL == DISABLED
384#if VSF_WDT_CFG_REIMPLEMENT_TYPE_CAPABILITY == DISABLED
396#if VSF_WDT_CFG_INHERIT_HAL_CAPABILITY == ENABLED
416#undef __VSF_HAL_TEMPLATE_API
417#define __VSF_HAL_TEMPLATE_API VSF_HAL_TEMPLATE_API_FP
423#if VSF_WDT_CFG_MULTI_CLASS == ENABLED
545#if VSF_WDT_CFG_FUNCTION_RENAME == ENABLED
546# define __vsf_wdt_t VSF_MCONNECT(VSF_WDT_CFG_PREFIX, _wdt_t)
547# define vsf_wdt_init(__WDT, ...) VSF_MCONNECT(VSF_WDT_CFG_PREFIX, _wdt_init) ((__vsf_wdt_t *)(__WDT), ##__VA_ARGS__)
548# define vsf_wdt_fini(__WDT) VSF_MCONNECT(VSF_WDT_CFG_PREFIX, _wdt_fini) ((__vsf_wdt_t *)(__WDT))
549# define vsf_wdt_enable(__WDT) VSF_MCONNECT(VSF_WDT_CFG_PREFIX, _wdt_enable) ((__vsf_wdt_t *)(__WDT))
550# define vsf_wdt_disable(__WDT) VSF_MCONNECT(VSF_WDT_CFG_PREFIX, _wdt_disable) ((__vsf_wdt_t *)(__WDT))
551# define vsf_wdt_capability(__WDT) VSF_MCONNECT(VSF_WDT_CFG_PREFIX, _wdt_capability) ((__vsf_wdt_t *)(__WDT))
552# define vsf_wdt_get_configuration(__WDT, ...) VSF_MCONNECT(VSF_WDT_CFG_PREFIX, _wdt_get_configuration) ((__vsf_wdt_t *)(__WDT), ##__VA_ARGS__)
553# define vsf_wdt_feed(__WDT, ...) VSF_MCONNECT(VSF_WDT_CFG_PREFIX, _wdt_feed) ((__vsf_wdt_t *)(__WDT))
554# define vsf_wdt_ctrl(__WDT, ...) VSF_MCONNECT(VSF_WDT_CFG_PREFIX, _wdt_ctrl) ((__vsf_wdt_t *)(__WDT), ##__VA_ARGS__)
vsf_err_t
Definition __type.h:42
vsf_wdt_mode_t
Definition wdt.h:31
vsf_arch_prio_t
Definition cortex_a_generic.h:88
unsigned uint32_t
Definition stdint.h:9
unsigned char uint8_t
Definition stdint.h:5
Definition vsf_template_hal_driver.h:204
Predefined VSF WDT capability that can be reimplemented in specific hal drivers. The vsf_wdt_capabili...
Definition vsf_template_wdt.h:395
uint8_t support_reset_soc
Indicates if SoC reset mode is supported.
Definition vsf_template_wdt.h:403
uint8_t support_disable
Indicates if WDT can be disabled after startup.
Definition vsf_template_wdt.h:404
uint8_t support_early_wakeup
Definition wdt.h:140
uint8_t support_reset_cpu
Indicates if core reset mode is supported.
Definition vsf_template_wdt.h:402
uint32_t max_timeout_ms
Maximum timeout in milliseconds.
Definition vsf_template_wdt.h:406
inherit(vsf_peripheral_capability_t) uint8_t support_early_wakeup uint8_t support_reset_none
< Indicates if early wakeup is supported
Definition vsf_template_wdt.h:397
uint8_t support_min_timeout
Indicates if minimum timeout is supported.
Definition vsf_template_wdt.h:405
WDT configuration structure.
Definition vsf_template_wdt.h:325
vsf_wdt_mode_t mode
WDT mode, refer to vsf_wdt_mode_t.
Definition vsf_template_wdt.h:326
uint32_t min_ms
Minimum timeout in milliseconds.
Definition vsf_template_wdt.h:328
uint32_t max_ms
Maximum timeout in milliseconds.
Definition vsf_template_wdt.h:327
vsf_wdt_isr_t isr
WDT interrupt configuration, refer to vsf_wdt_isr_t.
Definition vsf_template_wdt.h:329
WDT interrupt configuration structure.
Definition vsf_template_wdt.h:312
vsf_wdt_isr_handler_t * handler_fn
Interrupt handler function pointer.
Definition vsf_template_wdt.h:313
void * target_ptr
User-defined target pointer.
Definition vsf_template_wdt.h:314
vsf_arch_prio_t prio
Interrupt priority.
Definition vsf_template_wdt.h:315
WDT operation function pointer type, used for WDT Multi Class support.
Definition vsf_template_wdt.h:414
WDT instance structure, used for WDT Multi Class support, not needed in non Multi Class mode.
Definition vsf_template_wdt.h:428
const vsf_wdt_op_t * op
Definition vsf_template_wdt.h:429
vsf_wdt_mode_t
Definition wdt.h:111
void vsf_wdt_isr_handler_t(void *target_ptr, vsf_wdt_t *wdt_ptr)
Definition wdt.h:124
fsm_rt_t
Definition vsf_fsm.h:315
vsf_err_t vsf_wdt_init(vsf_wdt_t *wdt_ptr, vsf_wdt_cfg_t *cfg_ptr)
Initialize a WDT instance.
Definition wdt_common.c:38
#define VSF_WDT_APIS(__prefix_name)
WDT API template, used to generate WDT type, specific prefix function declarations,...
Definition vsf_template_wdt.h:191
fsm_rt_t vsf_wdt_enable(vsf_wdt_t *wdt_ptr)
Enable a WDT instance.
Definition wdt_common.c:66
@ VSF_WDT_MODE_RESET_MASK
Definition vsf_template_wdt.h:277
@ VSF_WDT_MODE_EARLY_WAKEUP_MASK
Definition vsf_template_wdt.h:271
@ VSF_WDT_MODE_ALL_BITS_MASK
Definition vsf_template_wdt.h:283
vsf_wdt_mode_t
Predefined VSF WDT modes that can be reimplemented in specific HAL drivers.The following modes must b...
Definition vsf_template_wdt.h:239
@ VSF_WDT_MODE_RESET_SOC
Reset SOC when timeout.
Definition vsf_template_wdt.h:245
@ VSF_WDT_MODE_NO_EARLY_WAKEUP
No early wakeup.
Definition vsf_template_wdt.h:240
@ VSF_WDT_MODE_RESET_CPU
Reset CPU when timeout.
Definition vsf_template_wdt.h:244
@ VSF_WDT_MODE_RESET_NONE
No reset when timeout.
Definition vsf_template_wdt.h:243
@ VSF_WDT_MODE_EARLY_WAKEUP
Early wakeup.
Definition vsf_template_wdt.h:241
void vsf_wdt_isr_handler_t(void *target_ptr, vsf_wdt_t *wdt_ptr)
WDT interrupt handler type declaration.
Definition vsf_template_wdt.h:306
struct vsf_wdt_capability_t vsf_wdt_capability_t
Predefined VSF WDT capability that can be reimplemented in specific hal drivers. The vsf_wdt_capabili...
void vsf_wdt_feed(vsf_wdt_t *wdt_ptr)
WDT feed operation.
Definition wdt_common.c:93
struct vsf_wdt_isr_t vsf_wdt_isr_t
WDT interrupt configuration structure.
vsf_wdt_ctrl_t
Predefined VSF WDT control commands that can be reimplemented in specific HAL drivers.
Definition vsf_template_wdt.h:362
@ __VSF_WDT_CTRL_DUMMY
Dummy value for compilation, required when no actual control commands are defined.
Definition vsf_template_wdt.h:380
vsf_err_t vsf_wdt_get_configuration(vsf_wdt_t *wdt_ptr, vsf_wdt_cfg_t *cfg_ptr)
Get the current configuration of a WDT instance.
Definition wdt_common.c:56
fsm_rt_t vsf_wdt_disable(vsf_wdt_t *wdt_ptr)
Disable a WDT instance.
Definition wdt_common.c:75
void vsf_wdt_fini(vsf_wdt_t *wdt_ptr)
Finalize a WDT instance.
Definition wdt_common.c:47
vsf_wdt_capability_t vsf_wdt_capability(vsf_wdt_t *wdt_ptr)
Get the capability of WDT instance.
Definition wdt_common.c:84
vsf_err_t vsf_wdt_ctrl(vsf_wdt_t *wdt_ptr, vsf_wdt_ctrl_t ctrl, void *param)
Definition wdt_common.c:102
struct vsf_wdt_cfg_t vsf_wdt_cfg_t
WDT configuration structure.