183 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			183 lines
		
	
	
		
			5.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/**********************************************************************
 | 
						||
* $Id$		lpc43xx_wwdt.h		2011-06-02
 | 
						||
*//**
 | 
						||
* @file		lpc43xx_wwdt.h
 | 
						||
* @brief	Contains all macro definitions and function prototypes
 | 
						||
* 			support for WWDT firmware library on lpc43xx
 | 
						||
* @version	1.0
 | 
						||
* @date		02. June. 2011
 | 
						||
* @author	NXP MCU SW Application Team
 | 
						||
*
 | 
						||
* Copyright(C) 2011, NXP Semiconductor
 | 
						||
* All rights reserved.
 | 
						||
*
 | 
						||
***********************************************************************
 | 
						||
* Software that is described herein is for illustrative purposes only
 | 
						||
* which provides customers with programming information regarding the
 | 
						||
* products. This software is supplied "AS IS" without any warranties.
 | 
						||
* NXP Semiconductors assumes no responsibility or liability for the
 | 
						||
* use of the software, conveys no license or title under any patent,
 | 
						||
* copyright, or mask work right to the product. NXP Semiconductors
 | 
						||
* reserves the right to make changes in the software without
 | 
						||
* notification. NXP Semiconductors also make no representation or
 | 
						||
* warranty that such application will be suitable for the specified
 | 
						||
* use without further testing or modification.
 | 
						||
* Permission to use, copy, modify, and distribute this software and its
 | 
						||
* documentation is hereby granted, under NXP Semiconductors<72>
 | 
						||
* relevant copyright in the software, without fee, provided that it
 | 
						||
* is used in conjunction with NXP Semiconductors microcontrollers.  This
 | 
						||
* copyright, permission, and disclaimer notice must appear in all copies of
 | 
						||
* this code.
 | 
						||
**********************************************************************/
 | 
						||
 | 
						||
/* Peripheral group ----------------------------------------------------------- */
 | 
						||
/** @defgroup WWDT	WWDT (Windowed WatchDog Timer)
 | 
						||
 * @ingroup LPC4300CMSIS_FwLib_Drivers
 | 
						||
 * @{
 | 
						||
 */
 | 
						||
 | 
						||
 | 
						||
#ifndef lpc43xx_WWDT_H_
 | 
						||
#define lpc43xx_WWDT_H_
 | 
						||
 | 
						||
/* Includes ------------------------------------------------------------------- */
 | 
						||
#include "LPC43xx.h"
 | 
						||
#include "lpc_types.h"
 | 
						||
 | 
						||
 | 
						||
#ifdef __cplusplus
 | 
						||
extern "C"
 | 
						||
{
 | 
						||
#endif
 | 
						||
 | 
						||
/* Public Macros -------------------------------------------------------------- */
 | 
						||
/** @defgroup WWDT_Public_Macros  WWDT Public Macros
 | 
						||
 * @{
 | 
						||
 */
 | 
						||
/** WDT oscillator frequency value */
 | 
						||
#define WDT_OSC		(12000000UL)		/* WWDT uses IRC clock */
 | 
						||
 | 
						||
/**
 | 
						||
 * @}
 | 
						||
 */
 | 
						||
 | 
						||
 | 
						||
/* Private Macros ------------------------------------------------------------- */
 | 
						||
/** @defgroup WWDT_Private_Macros WWDT Private Macros
 | 
						||
 * @{
 | 
						||
 */
 | 
						||
// time is calculated by usec
 | 
						||
#define WDT_GET_FROM_USEC(time)		((time*10)/((WWDT_US_INDEX *10 * 4)/WDT_OSC))
 | 
						||
#define WDT_GET_USEC(counter)		((counter * ((WWDT_US_INDEX *10 * 4)/WDT_OSC))/10)
 | 
						||
 | 
						||
 | 
						||
/* --------------------- BIT DEFINITIONS -------------------------------------- */
 | 
						||
/** WWDT interrupt enable bit */
 | 
						||
#define WWDT_WDMOD_WDEN			    ((uint32_t)(1<<0))
 | 
						||
/** WWDT interrupt enable bit */
 | 
						||
#define WWDT_WDMOD_WDRESET			((uint32_t)(1<<1))
 | 
						||
/** WWDT time out flag bit */
 | 
						||
#define WWDT_WDMOD_WDTOF			((uint32_t)(1<<2))
 | 
						||
/** WDT Time Out flag bit */
 | 
						||
#define WWDT_WDMOD_WDINT			((uint32_t)(1<<3))
 | 
						||
/** WWDT Protect flag bit */
 | 
						||
#define WWDT_WDMOD_WDPROTECT		((uint32_t)(1<<4))
 | 
						||
 | 
						||
/** Define divider index for microsecond ( us ) */
 | 
						||
#define WWDT_US_INDEX		((uint32_t)(1000000))
 | 
						||
 | 
						||
/** WWDT Time out minimum value */
 | 
						||
#define WWDT_TIMEOUT_MIN	((uint32_t)(0xFF))
 | 
						||
/** WWDT Time out maximum value */
 | 
						||
#define WWDT_TIMEOUT_MAX	((uint32_t)(0x00FFFFFF))
 | 
						||
 | 
						||
/** WWDT Warning minimum value */
 | 
						||
#define WWDT_WARNINT_MIN	((uint32_t)(0xFF))
 | 
						||
/** WWDT Warning maximum value */
 | 
						||
#define WWDT_WARNINT_MAX	((uint32_t)(0x000003FF))
 | 
						||
 | 
						||
/** WWDT Windowed minimum value */
 | 
						||
#define WWDT_WINDOW_MIN		((uint32_t)(0xFF))
 | 
						||
/** WWDT Windowed minimum value */
 | 
						||
#define WWDT_WINDOW_MAX		((uint32_t)(0x00FFFFFF))
 | 
						||
 | 
						||
/** WWDT timer constant register mask */
 | 
						||
#define WWDT_WDTC_MASK			((uint32_t)(0x00FFFFFF))
 | 
						||
/** WWDT warning value register mask */
 | 
						||
#define WWDT_WDWARNINT_MASK		((uint32_t)(0x000003FF))
 | 
						||
/** WWDT feed sequence register mask */
 | 
						||
#define WWDT_WDFEED_MASK 		((uint32_t)(0x000000FF))
 | 
						||
 | 
						||
/** WWDT flag */
 | 
						||
#define WWDT_WARNINT_FLAG		((uint8_t)(0))
 | 
						||
#define WWDT_TIMEOUT_FLAG		((uint8_t)(1))
 | 
						||
 | 
						||
/** WWDT mode definitions */
 | 
						||
#define WWDT_PROTECT_MODE		((uint8_t)(0))
 | 
						||
#define WWDT_RESET_MODE			((uint8_t)(1))
 | 
						||
 | 
						||
 | 
						||
/* WWDT Timer value definition (us) */
 | 
						||
#define WWDT_TIMEOUT_USEC_MIN			((uint32_t)(WDT_GET_USEC(WWDT_TIMEOUT_MIN)))//microseconds
 | 
						||
#define WWDT_TIMEOUT_USEC_MAX			((uint32_t)(WDT_GET_USEC(WWDT_TIMEOUT_MAX)))
 | 
						||
 | 
						||
#define WWDT_TIMEWARN_USEC_MIN			((uint32_t)(WDT_GET_USEC(WWDT_WARNINT_MIN)))
 | 
						||
#define WWDT_TIMEWARN_USEC_MAX			((uint32_t)(WDT_GET_USEC(WWDT_WARNINT_MAX)))
 | 
						||
 | 
						||
#define WWDT_TIMEWINDOWED_USEC_MIN		((uint32_t)(WDT_GET_USEC(WWDT_WINDOW_MIN)))
 | 
						||
#define WWDT_TIMEWINDOWED_USEC_MAX		((uint32_t)(WDT_GET_USEC(WWDT_WINDOW_MAX)))
 | 
						||
 | 
						||
 | 
						||
/**
 | 
						||
 * @}
 | 
						||
 */
 | 
						||
 | 
						||
/* Public Types --------------------------------------------------------------- */
 | 
						||
/** @defgroup WWDT_Public_Types WWDT Public Types
 | 
						||
 * @{
 | 
						||
 */
 | 
						||
/********************************************************************//**
 | 
						||
 * @brief WWDT structure definitions
 | 
						||
 **********************************************************************/
 | 
						||
typedef struct Wdt_Config
 | 
						||
{
 | 
						||
	uint8_t wdtReset;			/**< if ENABLE -> the Reset bit is enabled				*/
 | 
						||
	uint8_t wdtProtect;			/**< if ENABLE -> the Protect bit is enabled			*/
 | 
						||
	uint32_t wdtTmrConst;		/**< Set the constant value to timeout the WDT (us)		*/
 | 
						||
	uint32_t wdtWarningVal;		/**< Set the value to warn the WDT with interrupt (us)	*/
 | 
						||
	uint32_t wdtWindowVal;		/**< Set a window vaule for WDT (us)					*/
 | 
						||
}st_Wdt_Config;
 | 
						||
 | 
						||
/**
 | 
						||
 * @}
 | 
						||
 */
 | 
						||
 | 
						||
/* Public Functions ----------------------------------------------------------- */
 | 
						||
/** @defgroup WWDT_Public_Functions WWDT Public Functions
 | 
						||
 * @{
 | 
						||
 */
 | 
						||
 | 
						||
void WWDT_Init(void);
 | 
						||
void WWDT_UpdateTimeOut(uint32_t TimeOut);
 | 
						||
void WWDT_Feed (void);
 | 
						||
void WWDT_SetWarning(uint32_t WarnTime);
 | 
						||
void WWDT_SetWindow(uint32_t WindowedTime);
 | 
						||
void WWDT_Configure(st_Wdt_Config wdtCfg);
 | 
						||
void WWDT_Start(void);
 | 
						||
FlagStatus WWDT_GetStatus (uint8_t Status);
 | 
						||
void WWDT_ClearStatusFlag (uint8_t flag);
 | 
						||
uint32_t WWDT_GetCurrentCount(void);
 | 
						||
/**
 | 
						||
 * @}
 | 
						||
 */
 | 
						||
 | 
						||
#ifdef __cplusplus
 | 
						||
}
 | 
						||
#endif
 | 
						||
 | 
						||
#endif /* lpc43xx_WWDT_H_ */
 | 
						||
 | 
						||
/**
 | 
						||
 * @}
 | 
						||
 */
 |