S5P: support generic watchdog timer
[kernel/u-boot.git] / arch / arm / include / asm / arch-exynos / watchdog.h
1 /*
2  * Copyright (C) 2011 Samsung Electronics
3  * Heungjun Kim <riverful.kim@samsung.com>
4  *
5  * See file CREDITS for list of people who contributed to this
6  * project.
7  *
8  * This program is free software; you can redistribute it and/or
9  * modify it under the terms of the GNU General Public License as
10  * published by the Free Software Foundation; either version 2 of
11  * the License, or (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program; if not, write to the Free Software
20  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
21  * MA 02111-1307 USA
22  */
23
24 #ifndef __ASM_ARM_ARCH_WATCHDOG_H_
25 #define __ASM_ARM_ARCH_WATCHDOG_H_
26
27 #define WTCON_RESET_OFFSET      0
28 #define WTCON_INTEN_OFFSET      2
29 #define WTCON_CLKSEL_OFFSET     3
30 #define WTCON_EN_OFFSET         5
31 #define WTCON_PRE_OFFSET        8
32
33 #define WTCON_CLK_16            0x0
34 #define WTCON_CLK_32            0x1
35 #define WTCON_CLK_64            0x2
36 #define WTCON_CLK_128           0x3
37
38 #define WTCON_CLK(x)            ((x & 0x3) << WTCON_CLKSEL_OFFSET)
39 #define WTCON_PRESCALER(x)      ((x) << WTCON_PRE_OFFSET)
40 #define WTCON_EN                (0x1 << WTCON_EN_OFFSET)
41 #define WTCON_RESET             (0x1 << WTCON_RESET_OFFSET)
42 #define WTCON_INT               (0x1 << WTCON_INTEN_OFFSET)
43
44 #ifndef __ASSEMBLY__
45 struct s5p_watchdog {
46         unsigned int wtcon;
47         unsigned int wtdat;
48         unsigned int wtcnt;
49         unsigned int wtclrint;
50 };
51
52 /* functions */
53 void wdt_stop(void);
54 void wdt_start(unsigned int timeout);
55 #endif  /* __ASSEMBLY__ */
56
57 #endif