Since the RW firmware may contain newer/additional blobs than the RO COREBOOT region, try using it first, then fall back to COREBOOT and eventually BOOT_STUB if necessary. TEST=extract blobs from dedede and brya firmware images Change-Id: Ia01b37f8c410685de8a17ea4105ca671931a47c5 Signed-off-by: Matt DeVillier <matt.devillier@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/68453 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Martin Roth <martin.roth@amd.corp-partner.google.com>
		
			
				
	
	
		
			122 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			122 lines
		
	
	
		
			2.9 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #!/usr/bin/env bash
 | |
| #
 | |
| # SPDX-License-Identifier: GPL-2.0-only
 | |
| 
 | |
| if [ ! -f "$1" ]; then
 | |
| 	echo "Error: You must provide a valid filename"
 | |
| 	exit 1
 | |
| fi
 | |
| 
 | |
| IMAGE=$1
 | |
| # create new dir '$IMAGE-blobs' (less file extension)
 | |
| DIR=$(basename $IMAGE)
 | |
| DIR="${DIR%.*}-blobs"
 | |
| mkdir -p $DIR
 | |
| 
 | |
| if [ -f ./cbfstool ]; then
 | |
| 	CBFSTOOL="./cbfstool"
 | |
| else
 | |
| 	CBFSTOOL=$(command -v cbfstool)
 | |
| fi
 | |
| if [[ "$CBFSTOOL" = "" ]]; then
 | |
| 	echo "Error: cbfstool must be in your path or exist locally"
 | |
| 	exit 1
 | |
| fi
 | |
| 
 | |
| if [ -f ./ifdtool ]; then
 | |
| 	IFDTOOL="./ifdtool"
 | |
| else
 | |
| 	IFDTOOL=$(which ifdtool)
 | |
| fi
 | |
| if [[ "$IFDTOOL" = "" ]]; then
 | |
| 	echo "Error: ifdtool must be in your path or exist locally"
 | |
| 	exit 1
 | |
| fi
 | |
| 
 | |
| # ensure valid coreboot image / get list of CBFS contents
 | |
| # try using RW_MAIN_A region first as it may contain newer
 | |
| # files / files not present in the COREBOOT region
 | |
| if $CBFSTOOL $IMAGE print -r FW_MAIN_A >$DIR/cbfs.txt 2>/dev/null; then
 | |
| 	REGION="FW_MAIN_A"
 | |
| elif $CBFSTOOL $IMAGE print -r COREBOOT >$DIR/cbfs.txt; then
 | |
| 	# use COREBOOT region
 | |
| 	REGION="COREBOOT"
 | |
| elif $CBFSTOOL $IMAGE print -r BOOT_STUB >$DIR/cbfs.txt; then
 | |
| 	# use BOOT_STUB region
 | |
| 	REGION="BOOT_STUB"
 | |
| else
 | |
| 	echo "Error reading CBFS: $IMAGE is not a valid coreboot image"
 | |
| 	exit 1
 | |
| fi
 | |
| 
 | |
| echo ""
 | |
| echo "Extracting blobs from region $REGION..."
 | |
| echo ""
 | |
| 
 | |
| # extract flash regions
 | |
| if ! $IFDTOOL -x $IMAGE >/dev/null; then
 | |
| 	echo "Error reading flash descriptor/extracting flash regions"
 | |
| 	exit 1
 | |
| fi
 | |
| # rename to normal convention; drop unused regions
 | |
| mv flashregion_0_flashdescriptor.bin $DIR/flashdescriptor.bin
 | |
| [ -f flashregion_2_intel_me.bin ] && mv flashregion_2_intel_me.bin $DIR/me.bin
 | |
| rm flashregion_*.bin
 | |
| 
 | |
| # extract microcode
 | |
| $CBFSTOOL $IMAGE extract -r $REGION -n cpu_microcode_blob.bin -f $DIR/cpu_microcode_blob.bin
 | |
| 
 | |
| # extract VGA BIOS
 | |
| VGA=$(grep pci $DIR/cbfs.txt | cut -f1 -d\ )
 | |
| if [ "$VGA" != "" ]; then
 | |
| 	$CBFSTOOL $IMAGE extract -r $REGION -n $VGA -f $DIR/vgabios.bin
 | |
| fi
 | |
| 
 | |
| # extract MRC.bin
 | |
| MRC=$(grep mrc.bin $DIR/cbfs.txt | cut -f1 -d\ )
 | |
| if [ "$MRC" != "" ]; then
 | |
| 	$CBFSTOOL $IMAGE extract -r $REGION -n "$MRC" -f "$DIR/$MRC"
 | |
| fi
 | |
| 
 | |
| # extract refcode
 | |
| REF=$(grep refcode $DIR/cbfs.txt | cut -f1 -d\ )
 | |
| if [ "$REF" != "" ]; then
 | |
| 	$CBFSTOOL $IMAGE extract -r $REGION -n fallback/refcode -f "$DIR/refcode.elf" -m x86
 | |
| fi
 | |
| 
 | |
| # extract FSP blobs
 | |
| for FSP in $(grep fsp $DIR/cbfs.txt | cut -f1 -d\ ); do
 | |
| 	$CBFSTOOL $IMAGE extract -r $REGION -n $FSP -f $DIR/$FSP
 | |
| done
 | |
| 
 | |
| # extract audio blobs
 | |
| for AUD in $(grep -e "-2ch-" -e "-4ch-" $DIR/cbfs.txt | cut -f1 -d\ ); do
 | |
| 	$CBFSTOOL $IMAGE extract -r $REGION -n $AUD -f $DIR/$AUD
 | |
| done
 | |
| 
 | |
| # extract VBTs
 | |
| for VBT in $(grep vbt $DIR/cbfs.txt | cut -f1 -d\ ); do
 | |
| 	$CBFSTOOL $IMAGE extract -r $REGION -n $VBT -f $DIR/$VBT
 | |
| done
 | |
| 
 | |
| # extract IFWI
 | |
| IFWI=$(cbfstool $IMAGE layout -w | grep IFWI)
 | |
| if [ "$IFWI" != "" ]; then
 | |
| 	$CBFSTOOL $IMAGE read -r IFWI -f $DIR/ifwi.bin
 | |
| fi
 | |
| 
 | |
| # generate hashes
 | |
| (
 | |
| 	cd $DIR
 | |
| 	: >hashes.txt
 | |
| 	for FILE in $(ls *.{bin,elf} 2>/dev/null); do
 | |
| 		sha256sum $FILE >>hashes.txt
 | |
| 	done
 | |
| )
 | |
| 
 | |
| # a little housekeeping
 | |
| rm $DIR/cbfs.txt
 | |
| 
 | |
| echo ""
 | |
| echo "All done"
 |