mirror of
https://github.com/u-boot/u-boot.git
synced 2024-12-24 20:23:30 +08:00
1163625898
The current reset API implements a method to reset the entire system. In the near future, I'd like to introduce code that implements the device tree reset bindings; i.e. the equivalent of the Linux kernel's reset API. This controls resets to individual HW blocks or external chips with reset signals. It doesn't make sense to merge the two APIs into one since they have different semantic purposes. Resolve the naming conflict by renaming the existing reset API to sysreset instead, so the new reset API can be called just reset. Signed-off-by: Stephen Warren <swarren@nvidia.com> Acked-by: Simon Glass <sjg@chromium.org>
72 lines
1.9 KiB
C
72 lines
1.9 KiB
C
/*
|
|
* Copyright (c) 2015 Google, Inc
|
|
* Written by Simon Glass <sjg@chromium.org>
|
|
*
|
|
* SPDX-License-Identifier: GPL-2.0+
|
|
*/
|
|
|
|
#ifndef __SYSRESET_H
|
|
#define __SYSRESET_H
|
|
|
|
enum sysreset_t {
|
|
SYSRESET_WARM, /* Reset CPU, keep GPIOs active */
|
|
SYSRESET_COLD, /* Reset CPU and GPIOs */
|
|
SYSRESET_POWER, /* Reset PMIC (remove and restore power) */
|
|
|
|
SYSRESET_COUNT,
|
|
};
|
|
|
|
struct sysreset_ops {
|
|
/**
|
|
* request() - request a sysreset of the given type
|
|
*
|
|
* Note that this function may return before the reset takes effect.
|
|
*
|
|
* @type: Reset type to request
|
|
* @return -EINPROGRESS if the reset has been started and
|
|
* will complete soon, -EPROTONOSUPPORT if not supported
|
|
* by this device, 0 if the reset has already happened
|
|
* (in which case this method will not actually return)
|
|
*/
|
|
int (*request)(struct udevice *dev, enum sysreset_t type);
|
|
};
|
|
|
|
#define sysreset_get_ops(dev) ((struct sysreset_ops *)(dev)->driver->ops)
|
|
|
|
/**
|
|
* sysreset_request() - request a sysreset
|
|
*
|
|
* @type: Reset type to request
|
|
* @return 0 if OK, -EPROTONOSUPPORT if not supported by this device
|
|
*/
|
|
int sysreset_request(struct udevice *dev, enum sysreset_t type);
|
|
|
|
/**
|
|
* sysreset_walk() - cause a system reset
|
|
*
|
|
* This works through the available sysreset devices until it finds one that can
|
|
* perform a reset. If the provided sysreset type is not available, the next one
|
|
* will be tried.
|
|
*
|
|
* If this function fails to reset, it will display a message and halt
|
|
*
|
|
* @type: Reset type to request
|
|
* @return -EINPROGRESS if a reset is in progress, -ENOSYS if not available
|
|
*/
|
|
int sysreset_walk(enum sysreset_t type);
|
|
|
|
/**
|
|
* sysreset_walk_halt() - try to reset, otherwise halt
|
|
*
|
|
* This calls sysreset_walk(). If it returns, indicating that reset is not
|
|
* supported, it prints a message and halts.
|
|
*/
|
|
void sysreset_walk_halt(enum sysreset_t type);
|
|
|
|
/**
|
|
* reset_cpu() - calls sysreset_walk(SYSRESET_WARM)
|
|
*/
|
|
void reset_cpu(ulong addr);
|
|
|
|
#endif
|