mirror of
https://github.com/linuxboot/heads.git
synced 2024-12-20 21:43:11 +00:00
78 lines
3.7 KiB
Bash
Executable File
78 lines
3.7 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
BLOBDIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
|
|
ROMPARSER="94a615302f89b94e70446270197e0f5138d678f3"
|
|
UEFIEXTRACT="UEFIExtract_NE_A58_linux_x86_64.zip"
|
|
VBIOSFINDER="c2d764975115de466fdb4963d7773b5bc8468a06"
|
|
BIOSUPDATE="g4uj41us.exe"
|
|
ROM_PARSER_SHA256SUM="f3db9e9b32c82fea00b839120e4f1c30b40902856ddc61a84bd3743996bed894 94a615302f89b94e70446270197e0f5138d678f3.zip"
|
|
UEFI_EXTRACT_SHA256SUM="c9cf4066327bdf6976b0bd71f03c9e049ae39ed19ea3b3592bae3da8615d26d7 UEFIExtract_NE_A58_linux_x86_64.zip"
|
|
VBIOS_FINDER_SHA256SUM="bd07f47fb53a844a69c609ff268249ffe7bf086519f3d20474087224a23d70c5 c2d764975115de466fdb4963d7773b5bc8468a06.zip"
|
|
BIOS_UPDATE_SHA256SUM="6fc652b5fa10e5ea1ddc0e8477a2f1cfe56e00df76a94629f9b736faaee6199c g4uj41us.exe"
|
|
DGPU_ROM_SHA256SUM="3efe4886530086c0b612d1e669fbb4459ec93ec949b25a909e7ad273f4f01015 vbios_10de_0def_1.rom"
|
|
IGPU_ROM_SHA256SUM="10b292c19322e7bb7db53350d2775d37b72a784292ea5686cd0f92af929f4916 vbios_8086_0106_1.rom"
|
|
|
|
echo "### Creating temp dir"
|
|
extractdir=$(mktemp -d)
|
|
cd "$extractdir"
|
|
|
|
echo "### Installing basic dependencies"
|
|
sudo apt update && sudo apt install -y wget ruby ruby-dev bundler ruby-bundler p7zip-full upx-ucl
|
|
sudo gem install bundler:1.17.3
|
|
|
|
echo "### Downloading rom-parser dependency"
|
|
wget https://github.com/awilliam/rom-parser/archive/"$ROMPARSER".zip || { echo "Failed to download $ROMPARSER" && exit 1; }
|
|
|
|
echo "### Verifying expected hash of rom-parser"
|
|
echo "$ROM_PARSER_SHA256SUM" | sha256sum --check || { echo "Failed sha256sum verification..." && exit 1; }
|
|
|
|
echo "### Installing rom-parser dependency"
|
|
unzip "$ROMPARSER".zip
|
|
cd rom-parser-"$ROMPARSER" && make
|
|
sudo cp rom-parser /usr/sbin/
|
|
|
|
echo "### Downloading UEFIExtract dependency"
|
|
wget https://github.com/LongSoft/UEFITool/releases/download/A58/"$UEFIEXTRACT" || { echo "Failed to download $UEFIEXTRACT" && exit 1; }
|
|
|
|
echo "### Verifying expected hash of UEFIExtract"
|
|
echo "$UEFI_EXTRACT_SHA256SUM" | sha256sum --check || { echo "Failed sha256sum verification..." && exit 1; }
|
|
|
|
echo "### Installing UEFIExtract"
|
|
unzip "$UEFIEXTRACT"
|
|
sudo mv UEFIExtract /usr/sbin/
|
|
|
|
echo "### Downloading VBiosFinder"
|
|
wget https://github.com/coderobe/VBiosFinder/archive/"$VBIOSFINDER".zip || { echo "Failed to download $VBIOSFINDER" && exit 1; }
|
|
|
|
echo "### Verifying expected hash of VBiosFinder"
|
|
echo "$VBIOS_FINDER_SHA256SUM" | sha256sum --check || { echo "Failed sha256sum verification..." && exit 1; }
|
|
|
|
echo "### Installing VBiosFinder"
|
|
unzip "$VBIOSFINDER".zip
|
|
cd VBiosFinder-"$VBIOSFINDER" && bundle install --path=vendor/bundle
|
|
|
|
echo "### Downloading latest Lenovo bios update for t530"
|
|
wget https://download.lenovo.com/pccbbs/mobiles/"$BIOSUPDATE" || { echo "Failed to download $BIOSUPDATE" && exit 1; }
|
|
|
|
echo "### Verifying expected hash of bios update"
|
|
echo "$BIOS_UPDATE_SHA256SUM" | sha256sum --check || { echo "Failed sha256sum verification..." && exit 1; }
|
|
|
|
echo "### Extracting bios update"
|
|
innoextract "$extractdir"/rom-parser-"$ROMPARSER"/VBiosFinder-"$VBIOSFINDER"/"$BIOSUPDATE" || { echo "Failed to extract $BIOSUPDATE" && exit 1; }
|
|
|
|
echo "### Finding, extracting and saving vbios"
|
|
sudo ./vbiosfinder extract "$extractdir"/rom-parser-"$ROMPARSER"/VBiosFinder-"$VBIOSFINDER"/"app/G4ETB7WW/\$01D5100.FL1" || { echo "Failed to extract FL1" && exit 1; }
|
|
|
|
echo "Verifying expected hash of extracted roms"
|
|
cd output
|
|
echo "$DGPU_ROM_SHA256SUM" | sha256sum --check || { echo "dGPU rom failed sha256sum verification..." && exit 1; }
|
|
echo "$IGPU_ROM_SHA256SUM" | sha256sum --check || { echo "iGPU rom Failed sha256sum verification..." && exit 1; }
|
|
|
|
echo "### Moving extracted roms to blobs directory"
|
|
sudo mv vbios_10de_0def_1.rom $BLOBDIR/10de,0def.rom
|
|
sudo mv vbios_8086_0106_1.rom $BLOBDIR/8086,0106.rom
|
|
|
|
echo "### Cleaning Up"
|
|
cd "$BLOBDIR"
|
|
sudo rm -rf "$extractdir"
|