blob: dc3f70052b0f6a0e071bade5eb0e48f989671d21 [file] [log] [blame]
/* SPDX-License-Identifier: GPL-2.0 */
/*
* Verified Boot for Embedded (VBE) vbe-simple common file
*
* Copyright 2022 Google LLC
* Written by Simon Glass <sjg@chromium.org>
*/
#ifndef __VBE_SIMPLE_H
#define __VBE_SIMPLE_H
#include <linux/types.h>
#include "vbe_common.h"
/** struct simple_priv - information read from the device tree */
struct simple_priv {
u32 area_start;
u32 area_size;
u32 skip_offset;
u32 state_offset;
u32 state_size;
u32 version_offset;
u32 version_size;
const char *storage;
};
/** struct simple_state - state information read from media
*
* @fw_version: Firmware version string
* @fw_vernum: Firmware version number
*/
struct simple_state {
char fw_version[MAX_VERSION_LEN];
u32 fw_vernum;
};
/**
* vbe_simple_read_fw_bootflow() - Read a bootflow for firmware
*
* Locates and loads the firmware image (FIT) needed for the next phase. The FIT
* should ideally use external data, to reduce the amount of it that needs to be
* read.
*
* @bdev: bootdev device containing the firmwre
* @blow: Place to put the created bootflow, on success
* @return 0 if OK, -ve on error
*/
int vbe_simple_read_bootflow_fw(struct udevice *dev, struct bootflow *bflow);
/**
* vbe_simple_read_state() - Read the VBE simple state information
*
* @dev: VBE bootmeth
* @state: Place to put the state
* @return 0 if OK, -ve on error
*/
int vbe_simple_read_state(struct udevice *dev, struct simple_state *state);
#endif /* __VBE_SIMPLE_H */