Bug #555
closedcreate_erase_layout Segmentation Fault
0%
Description
Hi,
Using flashrom 1.4 on OpenBSD. This is a Protectli FW4B which has a Macronix MX25U6435E/F. Previous versions of flashrom worked OK. A bit of digging looks like this has been refactored.
Still narrowing down the issue, but flashrom finishes "Reading old flash chip contents.... done." then crashes.
GDB Backtrace is essentially:
create_erase_layout
flashrom_image_write
do_write
main
Files
Updated by Grant Pannell 5 months ago
- Subject changed from create_erase_layout SegFault to create_erase_layout Segmentation Fault
Updated by Grant Pannell 5 months ago ยท Edited
Grant Pannell wrote:
Hi,
Using flashrom 1.4 on OpenBSD. This is a Protectli FW4B which has a Macronix MX25U6435E/F. Previous versions of flashrom worked OK. A bit of digging looks like this has been refactored.
Still narrowing down the issue, but flashrom finishes "Reading old flash chip contents.... done." then crashes.
GDB Backtrace is essentially:
create_erase_layout
flashrom_image_write
do_write
main
The segfault occurs in erasure_layout.c: init_eraseblock line 55. I am no expert on the internals of flashrom, or what's going on here...but I've narrowed it down to segfaulting at the last iteration of this while loop. Code in question looks like:
edata->first_sub_block_index = *sub_block_index;
struct eraseblock_data *subedata = &layout[idx - 1].layout_list[*sub_block_index];
while (subedata->start_addr >= start_addr && subedata->end_addr <= end_addr &&
*sub_block_index < layout[idx-1].block_count) {
(*sub_block_index)++;
subedata++;
}
In my case, it seems that the last iteration looks like:
layout[idx-1].block_count == 2048
*sub_block_index == 2047
subedata->end_addr == end_addr
What then happens is, the variable "subedata" is incremented and the while condition is checked, but subedata is now out of bounds and the application segfaults. I'm pretty sure the while loop shouldn't iterate again because the next iteration would fail the *sub_block_index < layout[idx-1].block_count check (2048 < 2028). I solved this by short circuiting the while condition and checking that condition first, so that subedata is not accessed and flashrom successfully flashes my coreboot image. Patch included below. Is this an appropriate fix?
Updated by Grant Pannell 5 months ago
- File patch-erasure_layout_c patch-erasure_layout_c added
Updated by Anastasia Klimchuk 5 months ago
- Target version changed from none to 1.5
Updated by Anastasia Klimchuk 4 months ago
- Status changed from New to Resolved
- Assignee set to Grant Pannell
Grant fixed the bug with the patch: https://review.coreboot.org/c/flashrom/+/84234
I am closing this ticket.
Also relevant thread on the mailing list:
https://mail.coreboot.org/hyperkitty/list/flashrom@flashrom.org/thread/BAQWGZQ5ASH2TCXQYFNFDWPYBUTSNNZV/