// SPDX-License-Identifier: Apache-2.0 /* Copyright 2013-2017 IBM Corp. */ #ifndef __SECUREBOOT_H #define __SECUREBOOT_H #include #include #include "container.h" #include "cvc.h" enum secureboot_version { IBM_SECUREBOOT_V1, IBM_SECUREBOOT_SOFTROM, IBM_SECUREBOOT_V2, }; bool secureboot_is_compatible(struct dt_node *node, int *version, const char **compat); void secureboot_init(void); /** * secureboot_verify - verify a PNOR partition content * @id : PNOR partition id * @buf : PNOR partition content to be verified * @len : @buf length * * This verifies the integrity and authenticity of @buf downloaded from PNOR if * secure mode is on. The verification is done by the Container Verification * Code (CVC) flashed in ROM. * * For more information refer to 'doc/stb.rst' * * returns: 0 otherwise the boot process is aborted */ int secureboot_verify(enum resource_id id, void *buf, size_t len); #endif /* __SECUREBOOT_H */