Blame view
drivers/watchdog/s5p_wdt.c
880 Bytes
851db35e2 S5P: support gene... |
1 2 3 4 |
/* * Copyright (C) 2012 Samsung Electronics * Minkyu Kang <mk7.kang@samsung.com> * |
3765b3e7b Coding Style clea... |
5 |
* SPDX-License-Identifier: GPL-2.0+ |
851db35e2 S5P: support gene... |
6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 |
*/ #include <common.h> #include <asm/io.h> #include <asm/arch/watchdog.h> #define PRESCALER_VAL 255 void wdt_stop(void) { struct s5p_watchdog *wdt = (struct s5p_watchdog *)samsung_get_base_watchdog(); unsigned int wtcon; wtcon = readl(&wdt->wtcon); wtcon &= ~(WTCON_EN | WTCON_INT | WTCON_RESET); writel(wtcon, &wdt->wtcon); } void wdt_start(unsigned int timeout) { struct s5p_watchdog *wdt = (struct s5p_watchdog *)samsung_get_base_watchdog(); unsigned int wtcon; wdt_stop(); wtcon = readl(&wdt->wtcon); wtcon |= (WTCON_EN | WTCON_CLK(WTCON_CLK_128)); wtcon &= ~WTCON_INT; wtcon |= WTCON_RESET; wtcon |= WTCON_PRESCALER(PRESCALER_VAL); writel(timeout, &wdt->wtdat); writel(timeout, &wdt->wtcnt); writel(wtcon, &wdt->wtcon); } |