]> git.kernelconcepts.de Git - karo-tx-uboot.git/blob - include/reset.h
d29e108eecbbfd118278d01a51b68dd4eea608ad
[karo-tx-uboot.git] / include / reset.h
1 /*
2  * Copyright (c) 2015 Google, Inc
3  * Written by Simon Glass <sjg@chromium.org>
4  *
5  * SPDX-License-Identifier:     GPL-2.0+
6  */
7
8 #ifndef __RESET_H
9 #define __RESET_H
10
11 enum reset_t {
12         RESET_WARM,     /* Reset CPU, keep GPIOs active */
13         RESET_COLD,     /* Reset CPU and GPIOs */
14         RESET_POWER,    /* Reset PMIC (remove and restore power) */
15
16         RESET_COUNT,
17 };
18
19 struct reset_ops {
20         /**
21          * request() - request a reset of the given type
22          *
23          * Note that this function may return before the reset takes effect.
24          *
25          * @type:       Reset type to request
26          * @return -EINPROGRESS if the reset has been started and
27          *              will complete soon, -EPROTONOSUPPORT if not supported
28          *              by this device, 0 if the reset has already happened
29          *              (in which case this method will not actually return)
30          */
31         int (*request)(struct udevice *dev, enum reset_t type);
32 };
33
34 #define reset_get_ops(dev)        ((struct reset_ops *)(dev)->driver->ops)
35
36 /**
37  * reset_request() - request a reset
38  *
39  * @type:       Reset type to request
40  * @return 0 if OK, -EPROTONOSUPPORT if not supported by this device
41  */
42 int reset_request(struct udevice *dev, enum reset_t type);
43
44 /**
45  * reset_walk() - cause a reset
46  *
47  * This works through the available reset devices until it finds one that can
48  * perform a reset. If the provided reset type is not available, the next one
49  * will be tried.
50  *
51  * If this function fails to reset, it will display a message and halt
52  *
53  * @type:       Reset type to request
54  */
55 void reset_walk(enum reset_t type);
56
57 /**
58  * reset_cpu() - calls reset_walk(RESET_WARM)
59  */
60 void reset_cpu(ulong addr);
61
62 #endif