Lines Matching full:wdd
48 struct watchdog_device wdd; member
60 struct qcom_wdt *to_qcom_wdt(struct watchdog_device *wdd) in to_qcom_wdt() argument
62 return container_of(wdd, struct qcom_wdt, wdd); in to_qcom_wdt()
67 struct watchdog_device *wdd = arg; in qcom_wdt_isr() local
69 watchdog_notify_pretimeout(wdd); in qcom_wdt_isr()
74 static int qcom_wdt_start(struct watchdog_device *wdd) in qcom_wdt_start() argument
76 struct qcom_wdt *wdt = to_qcom_wdt(wdd); in qcom_wdt_start()
77 unsigned int bark = wdd->timeout - wdd->pretimeout; in qcom_wdt_start()
82 writel(wdd->timeout * wdt->rate, wdt_addr(wdt, WDT_BITE_TIME)); in qcom_wdt_start()
87 static int qcom_wdt_stop(struct watchdog_device *wdd) in qcom_wdt_stop() argument
89 struct qcom_wdt *wdt = to_qcom_wdt(wdd); in qcom_wdt_stop()
95 static int qcom_wdt_ping(struct watchdog_device *wdd) in qcom_wdt_ping() argument
97 struct qcom_wdt *wdt = to_qcom_wdt(wdd); in qcom_wdt_ping()
103 static int qcom_wdt_set_timeout(struct watchdog_device *wdd, in qcom_wdt_set_timeout() argument
106 wdd->timeout = timeout; in qcom_wdt_set_timeout()
107 return qcom_wdt_start(wdd); in qcom_wdt_set_timeout()
110 static int qcom_wdt_set_pretimeout(struct watchdog_device *wdd, in qcom_wdt_set_pretimeout() argument
113 wdd->pretimeout = timeout; in qcom_wdt_set_pretimeout()
114 return qcom_wdt_start(wdd); in qcom_wdt_set_pretimeout()
117 static int qcom_wdt_restart(struct watchdog_device *wdd, unsigned long action, in qcom_wdt_restart() argument
120 struct qcom_wdt *wdt = to_qcom_wdt(wdd); in qcom_wdt_restart()
144 static int qcom_wdt_is_running(struct watchdog_device *wdd) in qcom_wdt_is_running() argument
146 struct qcom_wdt *wdt = to_qcom_wdt(wdd); in qcom_wdt_is_running()
263 "wdt_bark", &wdt->wdd); in qcom_wdt_probe()
267 wdt->wdd.info = &qcom_wdt_pt_info; in qcom_wdt_probe()
268 wdt->wdd.pretimeout = 1; in qcom_wdt_probe()
273 wdt->wdd.info = &qcom_wdt_info; in qcom_wdt_probe()
276 wdt->wdd.ops = &qcom_wdt_ops; in qcom_wdt_probe()
277 wdt->wdd.min_timeout = 1; in qcom_wdt_probe()
278 wdt->wdd.max_timeout = 0x10000000U / wdt->rate; in qcom_wdt_probe()
279 wdt->wdd.parent = dev; in qcom_wdt_probe()
283 wdt->wdd.bootstatus = WDIOF_CARDRESET; in qcom_wdt_probe()
290 wdt->wdd.timeout = min(wdt->wdd.max_timeout, 30U); in qcom_wdt_probe()
291 watchdog_init_timeout(&wdt->wdd, 0, dev); in qcom_wdt_probe()
299 if (qcom_wdt_is_running(&wdt->wdd)) { in qcom_wdt_probe()
300 qcom_wdt_start(&wdt->wdd); in qcom_wdt_probe()
301 set_bit(WDOG_HW_RUNNING, &wdt->wdd.status); in qcom_wdt_probe()
304 ret = devm_watchdog_register_device(dev, &wdt->wdd); in qcom_wdt_probe()
316 if (watchdog_active(&wdt->wdd)) in qcom_wdt_suspend()
317 qcom_wdt_stop(&wdt->wdd); in qcom_wdt_suspend()
326 if (watchdog_active(&wdt->wdd)) in qcom_wdt_resume()
327 qcom_wdt_start(&wdt->wdd); in qcom_wdt_resume()