summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--futility/updater_utils.c2
-rw-r--r--host/lib/flashrom_drv.c29
-rw-r--r--host/lib/include/flashrom.h3
3 files changed, 30 insertions, 4 deletions
diff --git a/futility/updater_utils.c b/futility/updater_utils.c
index a41c4038..978936fa 100644
--- a/futility/updater_utils.c
+++ b/futility/updater_utils.c
@@ -672,7 +672,7 @@ static int read_flash(struct flashrom_params *params,
if (get_config_quirk(QUIRK_EXTERNAL_FLASHROM, cfg))
return external_flashrom(FLASH_READ, params, &cfg->tempfiles);
- return flashrom_read_image(params->image, NULL, params->verbose);
+ return flashrom_read_image(params->image, params->verbose);
}
static int write_flash(struct flashrom_params *params,
diff --git a/host/lib/flashrom_drv.c b/host/lib/flashrom_drv.c
index a9479c29..56eeb8a7 100644
--- a/host/lib/flashrom_drv.c
+++ b/host/lib/flashrom_drv.c
@@ -46,8 +46,10 @@ static char *flashrom_extract_params(const char *str, char **prog, char **params
return tmp;
}
-int flashrom_read_image(struct firmware_image *image, const char *region,
- int verbosity)
+static int flashrom_read_image_impl(struct firmware_image *image,
+ const char *region,
+ unsigned int *region_start,
+ unsigned int *region_len, int verbosity)
{
int r = 0;
size_t len = 0;
@@ -106,6 +108,10 @@ int flashrom_read_image(struct firmware_image *image, const char *region,
r |= flashrom_image_read(flashctx, image->data, len);
+ if (r == 0 && region)
+ r |= flashrom_layout_get_region_range(layout, region,
+ region_start, region_len);
+
err_cleanup:
flashrom_layout_release(layout);
flashrom_flash_release(flashctx);
@@ -118,6 +124,25 @@ err_init:
return r;
}
+int flashrom_read_image(struct firmware_image *image, int verbosity)
+{
+ return flashrom_read_image_impl(image, NULL, NULL, NULL, verbosity);
+}
+
+int flashrom_read_region(struct firmware_image *image, const char *region,
+ int verbosity)
+{
+ unsigned int start, len;
+ int r = flashrom_read_image_impl(image, region, &start, &len,
+ verbosity);
+ if (r != 0)
+ return r;
+
+ memmove(image->data, image->data + start, len);
+ image->size = len;
+ return 0;
+}
+
int flashrom_write_image(const struct firmware_image *image,
const char * const regions[],
const struct firmware_image *diff_image,
diff --git a/host/lib/include/flashrom.h b/host/lib/include/flashrom.h
index e2d3fb38..81d6ba98 100644
--- a/host/lib/include/flashrom.h
+++ b/host/lib/include/flashrom.h
@@ -40,7 +40,8 @@ struct firmware_image {
* @return VB2_SUCCESS on success, or a relevant error.
*/
vb2_error_t flashrom_read(struct firmware_image *image, const char *region);
-int flashrom_read_image(struct firmware_image *image, const char *region,
+int flashrom_read_image(struct firmware_image *image, int verbosity);
+int flashrom_read_region(struct firmware_image *image, const char *region,
int verbosity);
/**