[Skiboot] [RFC PATCH 1/7] core/flash: NULL pointer dereference fixes
Nicholas Piggin
npiggin at gmail.com
Fri Sep 21 18:05:05 AEST 2018
These were caught with unmapped memory dereference page faults.
Signed-off-by: Nicholas Piggin <npiggin at gmail.com>
---
core/flash-subpartition.c | 15 +++++++++------
core/flash.c | 5 ++++-
2 files changed, 13 insertions(+), 7 deletions(-)
diff --git a/core/flash-subpartition.c b/core/flash-subpartition.c
index 641448d5..7931790c 100644
--- a/core/flash-subpartition.c
+++ b/core/flash-subpartition.c
@@ -32,17 +32,18 @@ struct flash_hostboot_header {
};
int flash_subpart_info(void *part_header, uint32_t header_len,
- uint32_t part_size, uint32_t *part_actual,
+ uint32_t part_size, uint32_t *part_actualp,
uint32_t subid, uint32_t *offset, uint32_t *size)
{
struct flash_hostboot_header *header;
char eyecatcher[5];
uint32_t i, ec, o, s;
+ uint32_t part_actual;
bool subpart_found;
- if (!part_header || ( !offset && !size && !part_actual)) {
+ if (!part_header || ( !offset && !size && !part_actualp)) {
prlog(PR_ERR, "FLASH: invalid parameters: ph %p of %p sz %p "
- "tsz %p\n", part_header, offset, size, part_actual);
+ "tsz %p\n", part_header, offset, size, part_actualp);
return OPAL_PARAMETER;
}
@@ -68,7 +69,7 @@ int flash_subpart_info(void *part_header, uint32_t header_len,
eyecatcher);
subpart_found = false;
- *part_actual = 0;
+ part_actual = 0;
for (i = 0; i < FLASH_HOSTBOOT_TOC_MAX_ENTRIES; i++) {
ec = be32_to_cpu(header->toc[i].ec);
@@ -97,8 +98,8 @@ int flash_subpart_info(void *part_header, uint32_t header_len,
* Subpartitions content are different, but multiple toc entries
* may point to the same subpartition.
*/
- if (ALIGN_UP(o + s, FLASH_SUBPART_HEADER_SIZE) > *part_actual)
- *part_actual = ALIGN_UP(o + s, FLASH_SUBPART_HEADER_SIZE);
+ if (ALIGN_UP(o + s, FLASH_SUBPART_HEADER_SIZE) > part_actual)
+ part_actual = ALIGN_UP(o + s, FLASH_SUBPART_HEADER_SIZE);
if (ec == subid) {
if (offset)
@@ -112,5 +113,7 @@ int flash_subpart_info(void *part_header, uint32_t header_len,
prerror("FLASH: flash subpartition not found.\n");
return OPAL_RESOURCE;
}
+ if (part_actualp)
+ *part_actualp = part_actual;
return OPAL_SUCCESS;
}
diff --git a/core/flash.c b/core/flash.c
index 8e7b90e6..a4ffc7a7 100644
--- a/core/flash.c
+++ b/core/flash.c
@@ -403,9 +403,12 @@ int flash_register(struct blocklevel_device *bl)
if (rc)
return rc;
+ if (!name)
+ name = "(unnamed)";
+
prlog(PR_INFO, "FLASH: registering flash device %s "
"(size 0x%llx, blocksize 0x%x)\n",
- name ?: "(unnamed)", size, block_size);
+ name, size, block_size);
lock(&flash_lock);
--
2.18.0
More information about the Skiboot
mailing list