diff options
author | Vijay Khemka <vijaykhemka@fb.com> | 2020-02-19 01:05:24 +0300 |
---|---|---|
committer | Andrew Geissler <geissonator@yahoo.com> | 2020-03-04 16:44:36 +0300 |
commit | 2d9fe0fe0e5abedea284c20ede2b50dc43ef3c40 (patch) | |
tree | 6b8796dd2aa366c55c8df04dc66755d51f930ea9 | |
parent | 814ff6059fb9e2138feb1326742e0860fe97cd86 (diff) | |
download | openbmc-2d9fe0fe0e5abedea284c20ede2b50dc43ef3c40.tar.xz |
meta-facebook: tiogapass: Enable bios upgrade
Enabled flash_bios package and aslo added bios-update.sh script.
Tested this in tiogapass platform.
(From meta-facebook rev: 61aca58a232fb0d71c3535a08b8e000dca7831bc)
Change-Id: I7f03c58e2aef5fe157f83d960034b47c47d13b47
Signed-off-by: Vijay Khemka <vijaykhemka@fb.com>
Signed-off-by: Andrew Geissler <geissonator@yahoo.com>
3 files changed, 159 insertions, 0 deletions
diff --git a/meta-facebook/meta-facebook/meta-tiogapass/recipes-phosphor/flash/phosphor-software-manager/bios-update.sh b/meta-facebook/meta-facebook/meta-tiogapass/recipes-phosphor/flash/phosphor-software-manager/bios-update.sh new file mode 100755 index 000000000..fd1c52b2a --- /dev/null +++ b/meta-facebook/meta-facebook/meta-tiogapass/recipes-phosphor/flash/phosphor-software-manager/bios-update.sh @@ -0,0 +1,142 @@ +#!/bin/bash + +set -e + +POWER_CMD="/usr/sbin/power-util mb" +IMAGE_FILE=$1/bios.bin +GPIO=389 + +IPMB_OBJ="xyz.openbmc_project.Ipmi.Channel.Ipmb" +IPMB_PATH="/xyz/openbmc_project/Ipmi/Channel/Ipmb" +IPMB_INTF="org.openbmc.Ipmb" +IPMB_CALL="sendRequest yyyyay" +ME_CMD_RECOVER="1 0x2e 0 0xdf 4 0x57 0x01 0x00 0x01" +ME_CMD_RESET="1 6 0 0x2 0" +SPI_DEV="1e630000.spi" +SPI_PATH="/sys/bus/platform/drivers/aspeed-smc" + +set_gpio_to_bmc() +{ + echo "switch bios GPIO to bmc" + if [ ! -d /sys/class/gpio/gpio$GPIO ]; then + cd /sys/class/gpio + echo $GPIO > export + cd gpio$GPIO + else + cd /sys/class/gpio/gpio$GPIO + fi + direc=`cat direction` + if [ $direc == "in" ]; then + echo "out" > direction + fi + data=`cat value` + if [ "$data" == "0" ]; then + echo 1 > value + fi + return 0 +} + +set_gpio_to_pch() +{ + echo "switch bios GPIO to pch" + if [ ! -d /sys/class/gpio/gpio$GPIO ]; then + cd /sys/class/gpio + echo $GPIO > export + cd gpio$GPIO + else + cd /sys/class/gpio/gpio$GPIO + fi + direc=`cat direction` + if [ $direc == "in" ]; then + echo "out" > direction + fi + data=`cat value` + if [ "$data" == "1" ]; then + echo 0 > value + fi + echo "in" > direction + echo $GPIO > /sys/class/gpio/unexport + return 0 +} + +echo "Bios upgrade started at $(date)" + +#Power off host server. +echo "Power off host server" +$POWER_CMD off +sleep 15 +if [ $($POWER_CMD status) != "off" ]; +then + echo "Host server didn't power off" + echo "Bios upgrade failed" + exit -1 +fi +echo "Host server powered off" + +#Set ME to recovery mode +echo "Set ME to recovery mode" +busctl call $IPMB_OBJ $IPMB_PATH $IPMB_INTF $IPMB_CALL $ME_CMD_RECOVER +sleep 5 + +#Flip GPIO to access SPI flash used by host. +echo "Set GPIO $GPIO to access SPI flash from BMC used by host" +set_gpio_to_bmc + +#Bind spi driver to access flash +echo "bind aspeed-smc spi driver" +echo -n $SPI_DEV > $SPI_PATH/bind +sleep 1 + +#Flashcp image to device. +if [ -e "$IMAGE_FILE" ]; +then + echo "Bios image is $IMAGE_FILE" + for d in mtd6 mtd7 ; do + if [ -e "/dev/$d" ]; then + mtd=`cat /sys/class/mtd/$d/name` + if [ $mtd == "pnor" ]; then + echo "Flashing bios image to $d..." + flashcp -v $IMAGE_FILE /dev/$d + if [ $? -eq 0 ]; then + echo "bios updated successfully..." + else + echo "bios update failed..." + fi + break + fi + echo "$d is not a pnor device" + fi + echo "$d not available" + done +else + echo "Bios image $IMAGE_FILE doesn't exist" +fi + +#Unbind spi driver +sleep 1 +echo "Unbind aspeed-smc spi driver" +echo -n $SPI_DEV > $SPI_PATH/unbind +sleep 10 + +#Flip GPIO back for host to access SPI flash +echo "Set GPIO $GPIO back for host to access SPI flash" +set_gpio_to_pch +sleep 5 + +#Reset ME to boot from new bios +echo "Reset ME to boot from new bios" +busctl call $IPMB_OBJ $IPMB_PATH $IPMB_INTF $IPMB_CALL $ME_CMD_RESET +sleep 10 + +#Power on server +echo "Power on server" +$POWER_CMD on +sleep 5 + +# Retry to power on once again if server didn't powered on +if [ $($POWER_CMD status) != "on" ]; +then + sleep 5 + echo "Powering on server again" + $POWER_CMD on +fi diff --git a/meta-facebook/meta-facebook/meta-tiogapass/recipes-phosphor/flash/phosphor-software-manager/obmc-flash-host-bios@.service b/meta-facebook/meta-facebook/meta-tiogapass/recipes-phosphor/flash/phosphor-software-manager/obmc-flash-host-bios@.service new file mode 100644 index 000000000..7e098908e --- /dev/null +++ b/meta-facebook/meta-facebook/meta-tiogapass/recipes-phosphor/flash/phosphor-software-manager/obmc-flash-host-bios@.service @@ -0,0 +1,7 @@ +[Unit] +Description=Flash Host Bios image %I to Host + +[Service] +Type=oneshot +RemainAfterExit=no +ExecStart=/usr/sbin/bios-update.sh /tmp/images/%i diff --git a/meta-facebook/meta-facebook/meta-tiogapass/recipes-phosphor/flash/phosphor-software-manager_%.bbappend b/meta-facebook/meta-facebook/meta-tiogapass/recipes-phosphor/flash/phosphor-software-manager_%.bbappend new file mode 100644 index 000000000..b2160acde --- /dev/null +++ b/meta-facebook/meta-facebook/meta-tiogapass/recipes-phosphor/flash/phosphor-software-manager_%.bbappend @@ -0,0 +1,10 @@ +FILESEXTRAPATHS_prepend_tiogapass := "${THISDIR}/${PN}:" +SRC_URI += "file://bios-update.sh" + +PACKAGECONFIG_append = " flash_bios" +RDEPENDS_${PN} += "bash" + +do_install_append_tiogapass() { + install -d ${D}/${sbindir} + install -m 0755 ${WORKDIR}/bios-update.sh ${D}/${sbindir}/ +} |