audk/Vlv2TbltDevicePkg
Michael D Kinney 62fdb9bbc5 Vlv2TbltDevicePkg: Update Readme.md
Cc: Zailiang Sun <zailiang.sun@intel.com>
Cc: Yi Qian <yi.qian@intel.com>
Signed-off-by: Michael D Kinney <michael.d.kinney@intel.com>
Reviewed-by: Zailiang Sun <zailiang.sun@intel.com>
2019-05-09 19:58:06 -07:00
..
AcpiPlatform Vlv2TbltDevicePkg/AcpiPlatform: Add variable protocols to depex 2019-05-09 19:58:05 -07:00
Application/FirmwareUpdate Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
BootScriptSaveDxe Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
Feature/Capsule Vlv2TbltDevicePkg/Capsule: Add Linux/LVFS generation scripts 2019-05-09 19:58:06 -07:00
FspAzaliaConfigData Upload BSD-licensed Vlv2TbltDevicePkg and Vlv2DeviceRefCodePkg to 2015-01-12 09:37:20 +00:00
FspSupport Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
FvInfoPei Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
FvbRuntimeDxe Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
Include Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
IntelGopDepex Upload BSD-licensed Vlv2TbltDevicePkg and Vlv2DeviceRefCodePkg to 2015-01-12 09:37:20 +00:00
Library Vlv2TbltDevicePkg: Always enable QuietBoot to produce BGRT 2019-05-09 19:58:05 -07:00
Logo Upload BSD-licensed Vlv2TbltDevicePkg and Vlv2DeviceRefCodePkg to 2015-01-12 09:37:20 +00:00
Metronome Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
MonoStatusCode Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
Override/IntelFrameworkModulePkg/Library/GenericBdsLib Vlv2TbltDevicePkg: Find UEFI Shell using gUefiShellFileGuid 2019-05-09 19:58:05 -07:00
PciPlatform Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
PlatformCpuInfoDxe Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
PlatformDxe Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
PlatformGopPolicy Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
PlatformInfoDxe Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
PlatformInitPei Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
PlatformPei Vlv2TbltDevicePkg: Remove ResetSystem declaration 2019-04-18 12:23:15 +08:00
PlatformSetupDxe Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
PlatformSmm Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
PpmPolicy Vlv2TbltDevicePkg/PpmPolicy: Fix call to MP Services Protocol 2019-05-09 19:58:05 -07:00
SaveMemoryConfig Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
SmBiosMiscDxe Vlv2TbltDevicePkg/SmBiosMiscDxe: Fix GCC build issue 2019-05-09 19:58:05 -07:00
SmmSwDispatch2OnSmmSwDispatchThunk Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
SmramSaveInfoHandlerSmm Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
Stitch Vlv2TbltDevicePkg: Remove directory assumptions from build scripts 2019-05-09 19:58:06 -07:00
UiApp Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
VlvPlatformInitDxe Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
Wpce791 Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
.gitignore Vlv2TbltDevicePkg: Remove directory assumptions from build scripts 2019-05-09 19:58:06 -07:00
BfmLib.exe Upload BSD-licensed Vlv2TbltDevicePkg and Vlv2DeviceRefCodePkg to 2015-01-12 09:37:20 +00:00
BiosIdD.env Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
BiosIdR.env Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
BiosIdx64D.env Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
BiosIdx64R.env Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
Build_IFWI.bat Vlv2TbltDevicePkg: Remove directory assumptions from build scripts 2019-05-09 19:58:06 -07:00
Build_IFWI.sh Vlv2TbltDevicePkg: Sync the branch changes to Trunk, 2015-11-12 08:33:12 +00:00
FCE.exe Sync the branch changes to trunk. 2015-06-11 02:50:20 +00:00
FmpBlueSampleDevice.dsc Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
FmpCertificate.dsc Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
FmpGreenSampleDevice.dsc Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
FmpMinnowMaxSystem.dsc Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
FmpRedSampleDevice.dsc Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
GenBiosId Clean up GCC build. 2015-02-26 06:49:31 +00:00
GenBiosId.exe Upload BSD-licensed Vlv2TbltDevicePkg and Vlv2DeviceRefCodePkg to 2015-01-12 09:37:20 +00:00
PlatformCapsule.dsc Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
PlatformCapsule.fdf Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
PlatformCapsuleGcc.dsc Vlv2TbltDevicePkg/Capsule: Add Linux/LVFS generation scripts 2019-05-09 19:58:06 -07:00
PlatformCapsuleGcc.fdf Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
PlatformPkg.dec Vlv2TbltDevicePkg: Replace BSD License with BSD+Patent License 2019-04-09 10:58:31 -07:00
PlatformPkg.fdf Vlv2TbltDevicePkg: Add PchInitSmm module 2019-05-09 19:58:05 -07:00
PlatformPkgConfig.dsc Vlv2TbltDevicePkg: Retire 8254 timer and 8259 module 2019-04-18 12:23:24 +08:00
PlatformPkgGcc.fdf Vlv2TbltDevicePkg/Stitch/Gcc: Update default setting binary 2019-05-09 19:58:05 -07:00
PlatformPkgGccX64.dsc Vlv2TbltDevicePkg: Add PchInitSmm module 2019-05-09 19:58:05 -07:00
PlatformPkgIA32.dsc Vlv2TbltDevicePkg: Add PchInitSmm module 2019-05-09 19:58:05 -07:00
PlatformPkgX64.dsc Vlv2TbltDevicePkg: Add PchInitSmm module 2019-05-09 19:58:05 -07:00
Readme.md Vlv2TbltDevicePkg: Update Readme.md 2019-05-09 19:58:06 -07:00
bld_vlv.bat Vlv2TbltDevicePkg: Remove directory assumptions from build scripts 2019-05-09 19:58:06 -07:00
bld_vlv.sh Vlv2TbltDevicePkg: Remove directory assumptions from build scripts 2019-05-09 19:58:06 -07:00
cln.sh Clean up GCC build. 2015-02-26 06:49:31 +00:00

Readme.md

EDK II firmware for Minnowboard Max/Turbot which is based on Intel Valleyview2 SoC (Byatrail platform)


Windows Pre-requisites

  • GIT client: Available from https://git-scm.com/downloads

  • Microsoft Visual Studio.

    • Visual Studio 2015 recommended and is used in the examples below. Visual Studio 2013 is also supported.
  • WINDDK

    • Download Microsoft Windows Driver Development Kit 3790.1830 and install it to C:\WINDDK\3790.1830.
  • Python 3

  • Install iASL

    • Install the iasl compiler by downloading iasl-win-20160527.zip from the following location: "https://acpica.org/downloads/" and place the unzipped content ("iasl.exe") into the directory "C:\ASL" on your local hard drive (create the folder "C:\ASL" if it does not exist).
  • Install the NASM* assembly language compiler

  • Install Openssl

    • Download a pre-compiled Openssl Windows binary from https://wiki.openssl.org/index.php/Binaries. Search for a Windows binary in the list of "Third Party OpenSSL Related Binary Distributions". Go to the third party site to download the latest version. Download and extract to C:\Openssl, add the path of openssl.exe ("C:\openssl") to system environment variable OPENSSL_PATH.

Download and Build MinnowMax using Windows/Visual Studio

Run the script below from an empty directory. The script clones the EDK II repository from GitHub and downloads and unzips the binary support files for the MinnowBoard MAX. It then sets up the environment for EDK II builds and builds the MinnowBoard MAX firmware and generates UEFI Capsules that can be used to update the MinnowBoard MAX firmware and three sample devices.

git clone --recurse-submodules https://github.com/tianocore/edk2.git

powershell "& {[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; Invoke-WebRequest -Uri "https://indy.fulgan.com/SSL/openssl-1.0.2r-x64_86-win64.zip -OutFile openssl-1.0.2r-x64_86-win64.zip"}"
powershell Expand-Archive openssl-1.0.2r-x64_86-win64.zip

powershell "& {[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; Invoke-WebRequest -Uri "https://firmware.intel.com/sites/default/files/MinnowBoardMax-Development190216.zip -OutFile MinnowBoardMax-Development190216.zip"}"
powershell Expand-Archive MinnowBoardMax-Development190216.zip
sleep 1
rename MinnowBoardMax-Development190216 Vlv2Binaries
cd Vlv2Binaries
powershell Expand-Archive Vlv2SocBinPkg.zip .
sleep 1
cd ..

powershell "& {[Net.ServicePointManager]::SecurityProtocol = [Net.SecurityProtocolType]::Tls12; Invoke-WebRequest -Uri "https://www.nasm.us/pub/nasm/releasebuilds/2.13.03/win64/nasm-2.13.03-win64.zip -OutFile nasm-2.13.03-win64.zip"}"
powershell Expand-Archive nasm-2.13.03-win64.zip .

mkdir Conf

set WORKSPACE=%CD%
set EDK_TOOLS_PATH=%WORKSPACE%\edk2\BaseTools
set EDK_TOOLS_BIN=%EDK_TOOLS_PATH%\BinWrappers\WindowsLike
set PACKAGES_PATH=%WORKSPACE%\edk2;%WORKSPACE%\Vlv2Binaries
path=%path%;%EDK_TOOLS_PATH%\Bin\Win32;%WORKSPACE%\openssl-1.0.2r-x64_86-win64
set NASM_PREFIX=%WORKSPACE%\nasm-2.13.03\

cd %WORKSPACE%\edk2

call edkSetup.bat Rebuild

cd Vlv2TbltDevicePkg

Build_IFWI.bat /m /y MNW2 Debug

Once all the code and tools are downloaded and installed, only the following commands are required to setup the environment. Run these from the same directory used to install the source and binaries.

set WORKSPACE=%CD%
set EDK_TOOLS_PATH=%WORKSPACE%\edk2\BaseTools
set EDK_TOOLS_BIN=%EDK_TOOLS_PATH%\BinWrappers\WindowsLike
set PACKAGES_PATH=%WORKSPACE%\edk2;%WORKSPACE%\Vlv2Binaries
path=%path%;%EDK_TOOLS_PATH%\Bin\Win32;%WORKSPACE%\openssl-1.0.2r-x64_86-win64
set NASM_PREFIX=%WORKSPACE%\nasm-2.13.03\

cd %WORKSPACE%\edk2

call edkSetup.bat Rebuild

Once the environment is setup, the MinnowBoard MAX firmware and capsules can be rebuilt using the following commands.

  • Build Debug Image
cd Vlv2TbltDevicePkg
Build_IFWI.bat /m /y MNW2 Debug
  • Build Release Image
cd Vlv2TbltDevicePkg
Build_IFWI.bat /m /y MNW2 Release

The generated firmware image is the newest .bin file in edk2/Vlv2TbltDevicePkg/Stitch. The file is in the form MNW2MAX1.X64.0084.D01.<DATE>.bin.

The CapsuleApp and generated UEFI Capsules are in Build/Vlv2TbltDevicePkg/Capsules

Linux Pre-requisites

  • The tool GenBiosId has a dependency on libc.so.6. Make sure it is installed. Here are a few example installation commands:

    sudo dnf install libc.so.6

    apt-get install libc:i386

Download and Build MinnowMax using Linux/GCC

Run the script below from an empty directory. The script clones the EDK II repository from GitHub and downloads and unzips the binary support files for the MinnowBoard MAX. It then sets up the environment for EDK II builds and builds the MinnowBoard MAX firmware and generates UEFI Capsules that can be used to update the MinnowBoard MAX firmware and three sample devices.

git clone --recurse-submodules https://github.com/tianocore/edk2.git

mkdir Vlv2Binaries
cd Vlv2Binaries
wget https://firmware.intel.com/sites/default/files/MinnowBoardMax-Development190216.zip
unzip MinnowBoardMax-Development190216.zip
unzip Vlv2SocBinPkg.zip

cd ..
mkdir Conf

export WORKSPACE=$PWD/edk2
export PACKAGES_PATH=$PWD/Vlv2Binaries
export EDK_TOOLS_PATH=$WORKSPACE/BaseTools

cd edk2
cd Vlv2TbltDevicePkg
. Build_IFWI.sh MNW2 Debug

Once all the code is downloaded and installed, only the following commands are required to setup the environment. Run these from the same directory used to install the source and binaries.

export WORKSPACE=$PWD/edk2
export PACKAGES_PATH=$PWD/Vlv2Binaries
export EDK_TOOLS_PATH=$WORKSPACE/BaseTools

cd edk2
cd Vlv2TbltDevicePkg

Once the environment is setup, the MinnowBoard MAX firmware and capsules can be rebuilt using the following commands.

  • Build Debug Image
cd Vlv2TbltDevicePkg
./Build_IFWI.sh MNW2 Debug
  • Build Release Image
cd Vlv2TbltDevicePkg
./Build_IFWI.sh MNW2 Release

The generated firmware image is the MNW2MAX_X64_D_0084_01_GCC.bin file in edk2\Vlv2TbltDevicePkg\Stitch

The CapsuleApp and generated UEFI Capsules are in Build\Vlv2TbltDevicePkg\Capsules

Use DediProg to update FLASH image on a MinnowBoard MAX Target

Update MinnowBoard MAX Firmware from UEFI Capsules

  • Copy the Build/Vlv2TbltDevicePkg/Capsules directory to a USB FLASH drive
  • Connect USB FLASH Drive to MinnowBoard MAX
  • Boot MinnowBoard MAX to the Boot Manager
  • Boot the EFI Internal Shell boot option
  • Mount the USB FLASH Drive (usually FS1)
  • Use cd command to go to Capsules/TestCert directory
  • Run the following command to apply all four capsules
CapsuleApp.efi Red.cap Green.cap Blue.cap MinnowMax.cap
  • The MinnowBoard MAX should reboot and the four capsules are applied in the order listed. The progress bar matches the color name of the capsule. MinnowMax.cap uses the color purple. Once all capsules are processed, the MinnowBoard MAX should reboot again using the new firmware images.

Generate and Test a UX BitMap Capsule

  • Use bitmap editor to generate a BMP file. Recommend resolution of 600 wide by 100 tell and either 24 or 32 bits per pixel.
  • Save BMP file to USB FLASH drive
  • Use CapsuleApp.efi to convert BMP file to a UX Capsule
CapsuleApp.efi -G MyImage.bmp -O MyImage.cap
  • When updating firmware using capsules, add UX capsule to the list of capsules passed into CapsuleApp.efi.
CapsuleApp.efi MyImage.cap Red.cap Green.cap Blue.cap MinnowMax.cap
  • When the capsules are processed the UX bitmap image should be displayed at the bottom of the screen.