blob: f7cd39a20f2efa9c125b7a2d0a78a44fb600a8cc [file] [log] [blame]
Ronald G. Minnich5d01ec02009-03-31 11:57:36 +00001/*
Patrick Georgib7b56dd82009-09-14 13:29:27 +00002 * Copyright (C) 2009 coresystems GmbH
3 * written by Patrick Georgi <patrick.georgi@coresystems.de>
Ronald G. Minnich5d01ec02009-03-31 11:57:36 +00004 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; version 2 of the License.
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA, 02110-1301 USA
17 */
18
Stefan Reinauer63217582012-10-29 16:52:36 -070019#ifndef __CBFS_H
20#define __CBFS_H
21
Patrick Georgib7b56dd82009-09-14 13:29:27 +000022#include <stdint.h>
Ronald G. Minnicha8a133d2013-12-30 13:16:18 -080023
24/* create a magic number in host-byte order.
25 * b3 is the high order byte.
26 * in the coreboot tools, we go with the 32-bit
27 * magic number convention.
28 * This was an inline func but that breaks anything
29 * that uses it in a case statement.
30 */
31
32#define makemagic(b3, b2, b1, b0)\
33 (((b3)<<24) | ((b2) << 16) | ((b1) << 8) | (b0))
Ronald G. Minnich5d01ec02009-03-31 11:57:36 +000034
David Hendricks90ca3b62012-11-16 14:48:22 -080035#define CBFS_HEADER_MAGIC 0x4F524243
36#define CBFS_HEADPTR_ADDR_X86 0xFFFFFFFC
Hung-Te Lin086842a2013-01-04 12:33:03 +080037#define CBFS_HEADER_VERSION1 0x31313131
38#define CBFS_HEADER_VERSION2 0x31313132
39#define CBFS_HEADER_VERSION CBFS_HEADER_VERSION2
David Hendricks90ca3b62012-11-16 14:48:22 -080040
Patrick Georgib7b56dd82009-09-14 13:29:27 +000041struct cbfs_header {
42 uint32_t magic;
43 uint32_t version;
44 uint32_t romsize;
45 uint32_t bootblocksize;
46 uint32_t align;
47 uint32_t offset;
David Hendricks90ca3b62012-11-16 14:48:22 -080048 uint32_t architecture; /* Version 2 */
49 uint32_t pad[1];
Patrick Georgib7b56dd82009-09-14 13:29:27 +000050} __attribute__ ((packed));
Ronald G. Minnich5d01ec02009-03-31 11:57:36 +000051
David Hendricks90ca3b62012-11-16 14:48:22 -080052#define CBFS_ARCHITECTURE_UNKNOWN 0xFFFFFFFF
53#define CBFS_ARCHITECTURE_X86 0x00000001
Gabe Black51edd542013-09-30 23:00:33 -070054#define CBFS_ARCHITECTURE_ARM 0x00000010
Ronald G. Minnich5f431842013-11-12 09:03:33 -080055#define CBFS_ARCHITECTURE_AARCH64 0x0000aa64
Paul Burton33186922014-06-13 23:56:45 +010056#define CBFS_ARCHITECTURE_MIPS 0x00000100
Ronald G. Minnich833bf202014-10-16 10:55:39 +000057#define CBFS_ARCHITECTURE_RISCV 0xc001d0de
David Hendricks90ca3b62012-11-16 14:48:22 -080058
Hung-Te Lineab2c812013-01-29 01:56:17 +080059#define CBFS_FILE_MAGIC "LARCHIVE"
60
Patrick Georgib7b56dd82009-09-14 13:29:27 +000061struct cbfs_file {
Stefan Reinauera1e48242011-10-21 14:24:57 -070062 uint8_t magic[8];
Patrick Georgib7b56dd82009-09-14 13:29:27 +000063 uint32_t len;
64 uint32_t type;
65 uint32_t checksum;
66 uint32_t offset;
67} __attribute__ ((packed));
68
69struct cbfs_stage {
Stefan Reinauera1e48242011-10-21 14:24:57 -070070 uint32_t compression;
71 uint64_t entry;
72 uint64_t load;
73 uint32_t len;
74 uint32_t memlen;
Patrick Georgib7b56dd82009-09-14 13:29:27 +000075} __attribute__ ((packed));
76
Ronald G. Minnicha8a133d2013-12-30 13:16:18 -080077#define PAYLOAD_SEGMENT_CODE makemagic('C', 'O', 'D', 'E')
78#define PAYLOAD_SEGMENT_DATA makemagic('D', 'A', 'T', 'A')
Wei Hu2ad6ee92014-04-16 22:52:59 -070079#define PAYLOAD_SEGMENT_BSS makemagic('B', 'S', 'S', ' ')
Ronald G. Minnicha8a133d2013-12-30 13:16:18 -080080#define PAYLOAD_SEGMENT_PARAMS makemagic('P', 'A', 'R', 'A')
81#define PAYLOAD_SEGMENT_ENTRY makemagic('E', 'N', 'T', 'R')
Patrick Georgib7b56dd82009-09-14 13:29:27 +000082
83struct cbfs_payload_segment {
Stefan Reinauera1e48242011-10-21 14:24:57 -070084 uint32_t type;
85 uint32_t compression;
86 uint32_t offset;
87 uint64_t load_addr;
88 uint32_t len;
89 uint32_t mem_len;
Patrick Georgib7b56dd82009-09-14 13:29:27 +000090} __attribute__ ((packed));
91
92struct cbfs_payload {
93 struct cbfs_payload_segment segments;
94} __attribute__ ((packed));
Ronald G. Minnich5d01ec02009-03-31 11:57:36 +000095
96/** These are standard component types for well known
97 components (i.e - those that coreboot needs to consume.
98 Users are welcome to use any other value for their
99 components */
100
Stefan Reinauer800379f2010-03-01 08:34:19 +0000101#define CBFS_COMPONENT_STAGE 0x10
102#define CBFS_COMPONENT_PAYLOAD 0x20
103#define CBFS_COMPONENT_OPTIONROM 0x30
104#define CBFS_COMPONENT_BOOTSPLASH 0x40
105#define CBFS_COMPONENT_RAW 0x50
106#define CBFS_COMPONENT_VSA 0x51
107#define CBFS_COMPONENT_MBI 0x52
108#define CBFS_COMPONENT_MICROCODE 0x53
Patrick Georgia865b172011-01-14 07:40:24 +0000109#define CBFS_COMPONENT_CMOS_DEFAULT 0xaa
Patrick Georgi24479372011-01-18 13:56:36 +0000110#define CBFS_COMPONENT_CMOS_LAYOUT 0x01aa
Ronald G. Minnich5d01ec02009-03-31 11:57:36 +0000111
Ronald G. Minnich83b8f0c2009-05-08 19:23:00 +0000112/* The deleted type is chosen to be a value
113 * that can be written in a FLASH from all other
Stefan Reinauer14e22772010-04-27 06:56:47 +0000114 * values.
Ronald G. Minnich83b8f0c2009-05-08 19:23:00 +0000115 */
116#define CBFS_COMPONENT_DELETED 0
117
Stefan Reinauer14e22772010-04-27 06:56:47 +0000118/* for all known FLASH, this value can be changed
119 * to all other values. This allows NULL files to be
Ronald G. Minnich83b8f0c2009-05-08 19:23:00 +0000120 * changed without a block erase
121 */
Peter Stuge1d862de2009-04-14 00:08:34 +0000122#define CBFS_COMPONENT_NULL 0xFFFFFFFF
Ronald G. Minnich5d01ec02009-03-31 11:57:36 +0000123
Hung-Te Lin3bb035b2013-01-29 02:15:49 +0800124#define CBFS_NAME(_c) (((char *) (_c)) + sizeof(struct cbfs_file))
Stefan Reinauerdb5b8932013-01-18 15:53:22 -0800125#define CBFS_SUBHEADER(_p) ( (void *) ((((uint8_t *) (_p)) + ntohl((_p)->offset))) )
Ronald G. Minnicha8a133d2013-12-30 13:16:18 -0800126/* cbfs_image.c */
127uint32_t get_cbfs_entry_type(const char *name, uint32_t default_value);
128const char *get_cbfs_entry_type_name(uint32_t type);
129uint32_t get_cbfs_compression(const char *name, uint32_t unknown);
Stefan Reinauerdb5b8932013-01-18 15:53:22 -0800130
Ronald G. Minnich3fcde222014-02-04 17:35:44 -0800131/* common.c */
132void cbfs_file_get_header(struct buffer *buf, struct cbfs_file *file);
133
Ronald G. Minnich818f3692014-02-04 08:29:35 -0800134/* cbfs-mkpayload.c */
135void xdr_segs(struct buffer *output,
136 struct cbfs_payload_segment *segs, int nseg);
Aaron Durbinca630272014-08-05 10:48:20 -0500137void xdr_get_seg(struct cbfs_payload_segment *out,
138 struct cbfs_payload_segment *in);
Ronald G. Minnich818f3692014-02-04 08:29:35 -0800139
Stefan Reinauer63217582012-10-29 16:52:36 -0700140#endif