Files
system76-coreboot/src/lib/boot_device.c
Rizwan Qureshi 6d4c1f5f43 lib/boot_device: Add API for write protect a region
Add API that should be implemented by the boot media drivers
for write-protecting a subregion.

Change-Id: I4c9376e2c2c7a4852f13c65824c6cd64a1c6ac0a
Signed-off-by: Rizwan Qureshi <rizwan.qureshi@intel.com>
Reviewed-on: https://review.coreboot.org/c/28724
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Patrick Rudolph <siro@das-labor.org>
2019-01-21 13:25:46 +00:00

57 lines
1.5 KiB
C

/*
* This file is part of the coreboot project.
*
* Copyright 2015 Google Inc.
*
* 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; version 2 of the License.
*
* 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.
*/
#include <boot_device.h>
void __weak boot_device_init(void)
{
/* Provide weak do-nothing init. */
}
int __weak boot_device_wp_region(struct region_device *rd,
const enum bootdev_prot_type type)
{
/* return a failure, make aware WP is not implemented */
return -1;
}
static int boot_device_subregion(const struct region *sub,
struct region_device *subrd,
const struct region_device *parent)
{
if (parent == NULL)
return -1;
return rdev_chain(subrd, parent, region_offset(sub), region_sz(sub));
}
int boot_device_ro_subregion(const struct region *sub,
struct region_device *subrd)
{
/* Ensure boot device has been initialized at least once. */
boot_device_init();
return boot_device_subregion(sub, subrd, boot_device_ro());
}
int boot_device_rw_subregion(const struct region *sub,
struct region_device *subrd)
{
/* Ensure boot device has been initialized at least once. */
boot_device_init();
return boot_device_subregion(sub, subrd, boot_device_rw());
}