xref: /linux/drivers/watchdog/at91sam9_wdt.h (revision 0883c2c06fb5bcf5b9e008270827e63c09a88c1e)
1 /*
2  * drivers/watchdog/at91sam9_wdt.h
3  *
4  * Copyright (C) 2007 Andrew Victor
5  * Copyright (C) 2007 Atmel Corporation.
6  *
7  * Watchdog Timer (WDT) - System peripherals regsters.
8  * Based on AT91SAM9261 datasheet revision D.
9  *
10  * This program is free software; you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License as published by
12  * the Free Software Foundation; either version 2 of the License, or
13  * (at your option) any later version.
14  */
15 
16 #ifndef AT91_WDT_H
17 #define AT91_WDT_H
18 
19 #define AT91_WDT_CR		0x00			/* Watchdog Control Register */
20 #define		AT91_WDT_WDRSTT		(1    << 0)		/* Restart */
21 #define		AT91_WDT_KEY		(0xa5 << 24)		/* KEY Password */
22 
23 #define AT91_WDT_MR		0x04			/* Watchdog Mode Register */
24 #define		AT91_WDT_WDV		(0xfff << 0)		/* Counter Value */
25 #define			AT91_WDT_SET_WDV(x)	((x) & AT91_WDT_WDV)
26 #define		AT91_WDT_WDFIEN		(1     << 12)		/* Fault Interrupt Enable */
27 #define		AT91_WDT_WDRSTEN	(1     << 13)		/* Reset Processor */
28 #define		AT91_WDT_WDRPROC	(1     << 14)		/* Timer Restart */
29 #define		AT91_WDT_WDDIS		(1     << 15)		/* Watchdog Disable */
30 #define		AT91_WDT_WDD		(0xfff << 16)		/* Delta Value */
31 #define			AT91_WDT_SET_WDD(x)	(((x) << 16) & AT91_WDT_WDD)
32 #define		AT91_WDT_WDDBGHLT	(1     << 28)		/* Debug Halt */
33 #define		AT91_WDT_WDIDLEHLT	(1     << 29)		/* Idle Halt */
34 
35 #define AT91_WDT_SR		0x08			/* Watchdog Status Register */
36 #define		AT91_WDT_WDUNF		(1 << 0)		/* Watchdog Underflow */
37 #define		AT91_WDT_WDERR		(1 << 1)		/* Watchdog Error */
38 
39 #endif
40