cbfstool: Properly handle EOF in update_fit step
During the update_fit step, 'file_length' is used to determine how many bytes are left in the CBFS file. It was decremented in a loop from an array 'mcus[num_mcus].size', but 'num_mcus' was incremented right before. Since 'mcus' is memset(0) externally, 'file_length' was never decremented. The loop exited when it reached a dummy terminator, usually 48 bytes of 0 which are internationally added to microcode blobs in coreboot. However, if that terminator is removed, the loop doesn't stop and continues until it segfaults. Change-Id: I840727add69379ffef75b694d90402ed89769e3b Signed-off-by: Alexandru Gagniuc <mr.nuke.me@gmail.com> Reviewed-on: http://review.coreboot.org/4508 Tested-by: build bot (Jenkins) Reviewed-by: Aaron Durbin <adurbin@google.com>
This commit is contained in:
		| @@ -216,8 +216,8 @@ static int parse_microcode_blob(struct cbfs_image *image, | ||||
|  | ||||
| 		/* Proceed to next payload. */ | ||||
| 		current_offset += mcus[num_mcus].size; | ||||
| 		num_mcus++; | ||||
| 		file_length -= mcus[num_mcus].size; | ||||
| 		num_mcus++; | ||||
|  | ||||
| 		/* Reached limit of FIT entries. */ | ||||
| 		if (num_mcus == *total_mcus) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user