mirror of
https://review.coreboot.org/flashrom.git
synced 2025-04-26 22:52:34 +02:00

The full verification step was not accounting for sparse layouts. Instead of the old contents, combine_image_by_layout() implicitly assumed the new contents for unspecified regions. Change-Id: I44e0cea621f2a3d4dc70fa7e93c52ed95e54014a Signed-off-by: Nico Huber <nico.h@gmx.de> Reviewed-on: https://review.coreboot.org/c/30372 Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
66 lines
2.2 KiB
C
66 lines
2.2 KiB
C
/*
|
|
* This file is part of the flashrom project.
|
|
*
|
|
* Copyright (C) 2005-2008 coresystems GmbH
|
|
* (Written by Stefan Reinauer <stepan@coresystems.de> for coresystems GmbH)
|
|
* Copyright (C) 2011-2013 Stefan Tauner
|
|
* Copyright (C) 2016 secunet Security Networks AG
|
|
* (Written by Nico Huber <nico.huber@secunet.com> for secunet)
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License as published by
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
*/
|
|
|
|
#ifndef __LAYOUT_H__
|
|
#define __LAYOUT_H__ 1
|
|
|
|
#include <stddef.h>
|
|
#include <stdint.h>
|
|
|
|
/* Types and macros regarding the maximum flash space size supported by generic code. */
|
|
typedef uint32_t chipoff_t; /* Able to store any addressable offset within a supported flash memory. */
|
|
typedef uint32_t chipsize_t; /* Able to store the number of bytes of any supported flash memory. */
|
|
#define FL_MAX_CHIPOFF_BITS (24)
|
|
#define FL_MAX_CHIPOFF ((chipoff_t)(1ULL<<FL_MAX_CHIPOFF_BITS)-1)
|
|
#define PRIxCHIPOFF "06"PRIx32
|
|
#define PRIuCHIPSIZE PRIu32
|
|
|
|
#define MAX_ROMLAYOUT 32
|
|
|
|
struct romentry {
|
|
chipoff_t start;
|
|
chipoff_t end;
|
|
bool included;
|
|
char name[256];
|
|
};
|
|
|
|
struct flashrom_layout {
|
|
/* entries store the entries specified in a layout file and associated run-time data */
|
|
struct romentry *entries;
|
|
/* the number of successfully parsed entries */
|
|
size_t num_entries;
|
|
};
|
|
|
|
struct single_layout {
|
|
struct flashrom_layout base;
|
|
struct romentry entry;
|
|
};
|
|
|
|
struct flashrom_layout *get_global_layout(void);
|
|
|
|
int process_include_args(struct flashrom_layout *);
|
|
const struct romentry *layout_next_included_region(const struct flashrom_layout *, chipoff_t);
|
|
|
|
#endif /* !__LAYOUT_H__ */
|