forked from Mirrors/opensbi

To support different handlers for different types of resets, we are adding a sbi_list of restart handlers. Instead of sbi_system_reset_set_device we use sbi_system_reset_add_device to reflect the actual meaning. Signed-off-by: Nikita Shubin <n.shubin@yadro.com> Reviewed-by: Anup Patel <anup.patel@wdc.com>
47 lines
1.1 KiB
C
47 lines
1.1 KiB
C
/*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*
|
|
* Copyright (c) 2019 Western Digital Corporation or its affiliates.
|
|
*
|
|
* Authors:
|
|
* Anup Patel <anup.patel@wdc.com>
|
|
*/
|
|
|
|
#ifndef __SBI_SYSTEM_H__
|
|
#define __SBI_SYSTEM_H__
|
|
|
|
#include <sbi/sbi_types.h>
|
|
#include <sbi/sbi_list.h>
|
|
|
|
/** System reset hardware device */
|
|
struct sbi_system_reset_device {
|
|
/** Name of the system reset device */
|
|
char name[32];
|
|
|
|
/* Check whether reset type and reason supported by the device */
|
|
int (*system_reset_check)(u32 reset_type, u32 reset_reason);
|
|
|
|
/** Reset the system */
|
|
void (*system_reset)(u32 reset_type, u32 reset_reason);
|
|
|
|
/** List */
|
|
struct sbi_dlist node;
|
|
};
|
|
|
|
static inline struct sbi_system_reset_device *to_system_reset_device(
|
|
struct sbi_dlist *node)
|
|
{
|
|
return container_of(node, struct sbi_system_reset_device, node);
|
|
}
|
|
|
|
const struct sbi_system_reset_device *sbi_system_reset_get_device(
|
|
u32 reset_type, u32 reset_reason);
|
|
|
|
void sbi_system_reset_add_device(struct sbi_system_reset_device *dev);
|
|
|
|
bool sbi_system_reset_supported(u32 reset_type, u32 reset_reason);
|
|
|
|
void __noreturn sbi_system_reset(u32 reset_type, u32 reset_reason);
|
|
|
|
#endif
|