blob: ee941c7770621a4e4fd115c7af023344ad48f5a0 [file] [log] [blame]
Tom Rini83d290c2018-05-06 17:58:06 -04001// SPDX-License-Identifier: GPL-2.0
maxims@google.com4697abe2017-01-18 13:44:55 -08002/*
3 * (C) Copyright 2016 Google, Inc
maxims@google.com4697abe2017-01-18 13:44:55 -08004 */
5
6#include <common.h>
7#include <dm.h>
8#include <errno.h>
Simon Glassf7ae49f2020-05-10 11:40:05 -06009#include <log.h>
maxims@google.com4697abe2017-01-18 13:44:55 -080010#include <sysreset.h>
maxims@google.com99f8ad72017-04-17 12:00:26 -070011#include <wdt.h>
maxims@google.com4697abe2017-01-18 13:44:55 -080012#include <asm/io.h>
13#include <asm/arch/wdt.h>
14#include <linux/err.h>
15
maxims@google.com4697abe2017-01-18 13:44:55 -080016static int ast_sysreset_request(struct udevice *dev, enum sysreset_t type)
17{
maxims@google.com99f8ad72017-04-17 12:00:26 -070018 struct udevice *wdt;
19 u32 reset_mode;
20 int ret = uclass_first_device(UCLASS_WDT, &wdt);
maxims@google.com4697abe2017-01-18 13:44:55 -080021
maxims@google.com99f8ad72017-04-17 12:00:26 -070022 if (ret)
23 return ret;
maxims@google.com4697abe2017-01-18 13:44:55 -080024
25 switch (type) {
26 case SYSRESET_WARM:
27 reset_mode = WDT_CTRL_RESET_CPU;
28 break;
29 case SYSRESET_COLD:
30 reset_mode = WDT_CTRL_RESET_CHIP;
31 break;
32 default:
33 return -EPROTONOSUPPORT;
34 }
35
maxims@google.com99f8ad72017-04-17 12:00:26 -070036 ret = wdt_expire_now(wdt, reset_mode);
37 if (ret) {
38 debug("Sysreset failed: %d", ret);
39 return ret;
40 }
maxims@google.com4697abe2017-01-18 13:44:55 -080041
42 return -EINPROGRESS;
43}
44
45static struct sysreset_ops ast_sysreset = {
46 .request = ast_sysreset_request,
47};
48
49U_BOOT_DRIVER(sysreset_ast) = {
50 .name = "ast_sysreset",
51 .id = UCLASS_SYSRESET,
52 .ops = &ast_sysreset,
53};