summaryrefslogtreecommitdiff
path: root/common/bl_common.c
diff options
context:
space:
mode:
authorRyan Harkin <ryan.harkin@linaro.org>2014-02-04 11:43:57 +0000
committerDan Handley <dan.handley@arm.com>2014-03-05 16:21:14 +0000
commitee9ad7856c21835c0ad080d1e04d90e8c3535a4c (patch)
tree377402375729e41e710bb94203bb90afce01f6b9 /common/bl_common.c
parent48e2ca7967b8569cd8028b2ed7d1897a396c7b4a (diff)
bl_common: add image_size()
Fixes ARM-software/tf-issues#42 Some callers of load_image() may need to get the size of the image before/after loading it. Change-Id: I8dc067b69fc711433651a560ba5a8c3519445857 Signed-off-by: Ryan Harkin <ryan.harkin@linaro.org>
Diffstat (limited to 'common/bl_common.c')
-rw-r--r--common/bl_common.c44
1 files changed, 44 insertions, 0 deletions
diff --git a/common/bl_common.c b/common/bl_common.c
index 9afae95a..da027b66 100644
--- a/common/bl_common.c
+++ b/common/bl_common.c
@@ -251,6 +251,50 @@ static void dump_load_info(unsigned long image_load_addr,
#endif
}
+/* Generic function to return the size of an image */
+unsigned long image_size(const char *image_name)
+{
+ io_dev_handle dev_handle;
+ io_handle image_handle;
+ void *image_spec;
+ size_t image_size = 0;
+ int io_result = IO_FAIL;
+
+ assert(image_name != NULL);
+
+ /* Obtain a reference to the image by querying the platform layer */
+ io_result = plat_get_image_source(image_name, &dev_handle, &image_spec);
+ if (io_result != IO_SUCCESS) {
+ WARN("Failed to obtain reference to image '%s' (%i)\n",
+ image_name, io_result);
+ return 0;
+ }
+
+ /* Attempt to access the image */
+ io_result = io_open(dev_handle, image_spec, &image_handle);
+ if (io_result != IO_SUCCESS) {
+ WARN("Failed to access image '%s' (%i)\n",
+ image_name, io_result);
+ return 0;
+ }
+
+ /* Find the size of the image */
+ io_result = io_size(image_handle, &image_size);
+ if ((io_result != IO_SUCCESS) || (image_size == 0)) {
+ WARN("Failed to determine the size of the image '%s' file (%i)\n",
+ image_name, io_result);
+ }
+ io_result = io_close(image_handle);
+ /* Ignore improbable/unrecoverable error in 'close' */
+
+ /* TODO: Consider maintaining open device connection from this
+ * bootloader stage
+ */
+ io_result = io_dev_close(dev_handle);
+ /* Ignore improbable/unrecoverable error in 'dev_close' */
+
+ return image_size;
+}
/*******************************************************************************
* Generic function to load an image into the trusted RAM,
* given a name, extents of free memory & whether the image should be loaded at