blob: 72fbe049a7b203d69514ea064723f373acad6a00 [file] [log] [blame]
/*
* Copyright (c) 2016, Intel Corporation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef __VERSION_HEADER_H__
#define __VERSION_HEADER_H__
#include <stdint.h>
/**
* Define the content of a 48-bytes binary version header.
*
* The binary version header allows to uniquely identify the binary used. Note:
* - a device may include more than one binary, each having its own binary
* version header.
* - the position of this struct is usually defined in the linker script and
* its content is overwritten after the build (in a special post-build script).
* It therefore doesn't need to be initialized at compile-time (expected magic
* and version), yet can be used in the code at runtime.
*
* Major, Minor, Patch are the following the usual definition, e.g. 1.0.0
*/
struct version_header {
/** Always equal to $B!N */
uint8_t magic[4];
/** Header format version */
uint8_t version;
uint8_t major;
uint8_t minor;
uint8_t patch;
/**
* Human-friendly version string, free format (not NULL terminated)
* Advised format is: PPPPXXXXXX-YYWWTBBBB
* - PPPP : product code
* - XXXXXX: binary info. Usually contains information such as the
* binary type (bootloader, application), build variant (unit tests,
* debug, release), release/branch name
* - YY : year last 2 digits
* - WW : work week number
* - T : build type, e.g. [W]eekly, [L]atest, [R]elease, [P]roduction,
* [F]actory, [C]ustom
* - BBBB : build number, left padded with zeros
* Examples:
* - A101BOOT01-1503W0234
* - CCCKAPP123-1502R0013
*/
char version_string[20];
/**
* Micro-SHA1 (first 4 bytes of the SHA1) of the binary payload excluding
* this header. It allows to uniquely identify the exact binary used.
* In the case the header is located in the middle of the payload, the
* SHA1 has to be computed from two disjoint buffers.
*/
uint8_t hash[4];
/** Position of the payload start relative to the address of this structure */
int32_t offset;
/** Filled with zeros, can be eventually used for 64 bits support */
uint8_t reserved_1[4];
/** Size of the payload in bytes, including this header */
uint32_t size;
/** Filled with zeros, can be eventually used for 64 bits support */
uint8_t reserved_2[4];
} __packed;
/** The global version header struct */
extern struct version_header version_header;
#endif /* __VERSION_HEADER_H__ */