Lines Matching +full:watchdog +full:- +full:enable
1 // SPDX-License-Identifier: GPL-2.0+
3 * Watchdog driver for the SA11x0/PXA2xx
10 * "AS-IS" and at no charge.
27 #include <linux/watchdog.h>
40 #define REG_OWER 0x0018 /* OS timer Watch-dog Enable Reg. */
41 #define REG_OIER 0x001C /* OS timer Interrupt Enable Reg. */
48 #define OWER_WME (1 << 0) /* Watchdog Match Enable */
50 #define OIER_E3 (1 << 3) /* Interrupt enable channel 3 */
51 #define OIER_E2 (1 << 2) /* Interrupt enable channel 2 */
52 #define OIER_E1 (1 << 1) /* Interrupt enable channel 1 */
53 #define OIER_E0 (1 << 0) /* Interrupt enable channel 0 */
77 return -EBUSY; in sa1100dog_open()
79 /* Activate SA1100 Watchdog timer */ in sa1100dog_open()
88 * The watchdog cannot be disabled.
91 * clearing REG_OIER[E3] would prevent the watchdog timing out but this
96 pr_crit("Device closed - timer will not stop\n"); in sa1100dog_release()
113 .identity = "SA1100/PXA255 Watchdog",
120 int ret = -ENOTTY; in sa1100dog_ioctl()
128 sizeof(ident)) ? -EFAULT : 0; in sa1100dog_ioctl()
150 ret = -EINVAL; in sa1100dog_ioctl()
177 .name = "watchdog",
192 return -ENXIO; in sa1100dog_probe()
193 reg_base = devm_ioremap(&pdev->dev, res->start, resource_size(res)); in sa1100dog_probe()
200 pr_err("SA1100/PXA2xx Watchdog Timer: clock not found: %d\n", in sa1100dog_probe()
207 pr_err("SA1100/PXA2xx Watchdog Timer: clock failed to prepare+enable: %d\n", in sa1100dog_probe()
214 platform_data = pdev->dev.platform_data; in sa1100dog_probe()
221 pr_info("SA1100/PXA2xx Watchdog Timer: timer margin %d sec\n", in sa1100dog_probe()
247 MODULE_DESCRIPTION("SA1100/PXA2xx Watchdog");
250 MODULE_PARM_DESC(margin, "Watchdog margin in seconds (default 60s)");