mirror of
https://github.com/u-boot/u-boot.git
synced 2025-04-19 11:24:42 +00:00

When bringing in the series 'arm: dts: am62-beagleplay: Fix Beagleplay Ethernet"' I failed to notice that b4 noticed it was based on next and so took that as the base commit and merged that part of next to master. This reverts commitc8ffd1356d
, reversing changes made to2ee6f3a5f7
. Reported-by: Jonas Karlman <jonas@kwiboo.se> Signed-off-by: Tom Rini <trini@konsulko.com>
44 lines
893 B
C
44 lines
893 B
C
// SPDX-License-Identifier: GPL-2.0+
|
|
/*
|
|
* Copyright (C) 2017 Masahiro Yamada <yamada.masahiro@socionext.com>
|
|
*/
|
|
|
|
#include <common.h>
|
|
#include <dm.h>
|
|
#include <sysreset.h>
|
|
#include <linux/errno.h>
|
|
#include <linux/psci.h>
|
|
|
|
__weak int psci_sysreset_get_status(struct udevice *dev, char *buf, int size)
|
|
{
|
|
return -EOPNOTSUPP;
|
|
}
|
|
|
|
static int psci_sysreset_request(struct udevice *dev, enum sysreset_t type)
|
|
{
|
|
switch (type) {
|
|
case SYSRESET_WARM:
|
|
case SYSRESET_COLD:
|
|
psci_sys_reset(type);
|
|
break;
|
|
case SYSRESET_POWER_OFF:
|
|
psci_sys_poweroff();
|
|
break;
|
|
default:
|
|
return -EPROTONOSUPPORT;
|
|
}
|
|
|
|
return -EINPROGRESS;
|
|
}
|
|
|
|
static struct sysreset_ops psci_sysreset_ops = {
|
|
.request = psci_sysreset_request,
|
|
.get_status = psci_sysreset_get_status,
|
|
};
|
|
|
|
U_BOOT_DRIVER(psci_sysreset) = {
|
|
.name = "psci-sysreset",
|
|
.id = UCLASS_SYSRESET,
|
|
.ops = &psci_sysreset_ops,
|
|
.flags = DM_FLAG_PRE_RELOC,
|
|
};
|