1 // SPDX-License-Identifier: GPL-2.0
2 /*
3 * Copyright (C) 2020 Stefan Roese <sr@denx.de>
4 */
5
6 #include <dm.h>
7 #include <errno.h>
8 #include <sysreset.h>
9 #include <asm/io.h>
10
11 #define RST_SOFT_RST 0x0080
12
13 struct octeon_sysreset_data {
14 void __iomem *base;
15 };
16
octeon_sysreset_request(struct udevice * dev,enum sysreset_t type)17 static int octeon_sysreset_request(struct udevice *dev, enum sysreset_t type)
18 {
19 struct octeon_sysreset_data *data = dev_get_priv(dev);
20
21 writeq(1, data->base + RST_SOFT_RST);
22
23 return -EINPROGRESS;
24 }
25
octeon_sysreset_probe(struct udevice * dev)26 static int octeon_sysreset_probe(struct udevice *dev)
27 {
28 struct octeon_sysreset_data *data = dev_get_priv(dev);
29
30 data->base = dev_remap_addr(dev);
31
32 return 0;
33 }
34
35 static struct sysreset_ops octeon_sysreset = {
36 .request = octeon_sysreset_request,
37 };
38
39 static const struct udevice_id octeon_sysreset_ids[] = {
40 { .compatible = "mrvl,cn7xxx-rst" },
41 { }
42 };
43
44 U_BOOT_DRIVER(sysreset_octeon) = {
45 .id = UCLASS_SYSRESET,
46 .name = "octeon_sysreset",
47 .priv_auto = sizeof(struct octeon_sysreset_data),
48 .ops = &octeon_sysreset,
49 .probe = octeon_sysreset_probe,
50 .of_match = octeon_sysreset_ids,
51 };
52