diff options
-rwxr-xr-x | include/mrc.sh | 28 |
1 files changed, 8 insertions, 20 deletions
diff --git a/include/mrc.sh b/include/mrc.sh index 9cb64e69..11b1abb2 100755 --- a/include/mrc.sh +++ b/include/mrc.sh @@ -4,7 +4,7 @@ # Modifications in this version are Copyright 2021 and 2023 Leah Rowe. # Original copyright detailed in repo: https://review.coreboot.org/coreboot/ -eval "$(setvars "" MRC_url MRC_url_bkup MRC_hash MRC_board ROOTFS SHELLBALL)" +eval "$(setvars "" MRC_url MRC_url_bkup MRC_hash MRC_board SHELLBALL)" extract_mrc() { @@ -12,13 +12,13 @@ extract_mrc() [ -z "${CONFIG_MRC_FILE}" ] && \ err "extract_mrc $MRC_hash: CONFIG_MRC_FILE not set" - ROOTFS="root-a.ext2" SHELLBALL="chromeos-firmwareupdate-${MRC_board}" ( x_ cd "${appdir}" - extract_partition - extract_shellball + extract_partition "${MRC_url##*/}" + printf "cd /usr/sbin\ndump chromeos-firmwareupdate ${SHELLBALL}\nquit" \ + | debugfs "root-a.ext2" || err "extract_mrc: can't extract shellball" extract_archive "${SHELLBALL}" . ) || err "mrc download/extract failure" @@ -28,26 +28,14 @@ extract_mrc() extract_partition() { - NAME="ROOT-A" - FILE="${MRC_url##*/}" - FILE="${FILE%.zip}" - _bs=1024 - printf "Extracting ROOT-A partition\n" ROOTP=$( printf "unit\nB\nprint\nquit\n" | \ - parted "${FILE}" 2>/dev/null | grep "${NAME}" ) + parted "${1%.zip}" 2>/dev/null | grep "ROOT-A" ) START=$(( $( echo ${ROOTP} | cut -f2 -d\ | tr -d "B" ) )) SIZE=$(( $( echo ${ROOTP} | cut -f4 -d\ | tr -d "B" ) )) - dd if="${FILE}" of="${ROOTFS}" bs=${_bs} \ - skip=$(( ${START} / ${_bs} )) count=$(( ${SIZE} / ${_bs} )) || \ - err "extract_partition, dd ${FILE}, ${ROOTFS}" -} - -extract_shellball() -{ - printf "Extracting chromeos-firmwareupdate\n" - printf "cd /usr/sbin\ndump chromeos-firmwareupdate ${SHELLBALL}\nquit" \ - | debugfs "${ROOTFS}" || err "extract_shellball: debugfs" + dd if="${1%.zip}" of="root-a.ext2" bs=1024 \ + skip=$(( ${START} / 1024 )) count=$(( ${SIZE} / 1024 )) || \ + err "extract_partition, dd ${1%.zip}, root-a.ext2" } |