blob: a63c3e61c326d7ef5891327383605b6174515aee [file] [log] [blame]
Lancelot Kao4357d532021-02-22 15:20:35 -06001#!/bin/bash
2
3devpath="/sys/bus/i2c/devices/13-0077/driver"
4
Lancelot Kao96a7ee32021-02-22 18:50:48 -06005source /usr/sbin/kudo-lib.sh
Lancelot Kao4357d532021-02-22 15:20:35 -06006
7function fwbios() {
8 KERNEL_FIU_ID="c0000000.spi"
9 KERNEL_SYSFS_FIU="/sys/bus/platform/drivers/NPCM-FIU"
10
11 # switch the SPI mux from Host to BMC
12 i2cset -y -f -a 13 0x76 0x10 0x01
13
14 # rescan the spi bus
15 if [ -d "${KERNEL_SYSFS_FIU}/${KERNEL_FIU_ID}" ]; then
16 echo "${KERNEL_FIU_ID}" > "${KERNEL_SYSFS_FIU}"/unbind
17 sleep 1
18 fi
19 echo "${KERNEL_FIU_ID}" > "${KERNEL_SYSFS_FIU}"/bind
20
21 # write to the mtd device
22 BIOS_MTD=$(cat /proc/mtd | grep "bios" | sed -n 's/^\(.*\):.*/\1/p')
23
24 if [ ! -f $1 ]; then
25 echo " Cannot find the" $1 "image file"
26 exit 1
Lancelot Kao4357d532021-02-22 15:20:35 -060027
Lancelot Kao96a7ee32021-02-22 18:50:48 -060028 fi
Lancelot Kao4357d532021-02-22 15:20:35 -060029 echo "Flashing BIOS @/dev/$BIOS_MTD"
30 flashcp -v $1 /dev/$BIOS_MTD
XP Chenc4dc5d32021-07-27 11:33:13 -050031 if [ $? -ne 0 ]; then
32 echo "Flashing the bios failed " >&2
33 exit 1
34 fi
Lancelot Kao4357d532021-02-22 15:20:35 -060035 wait
36
37 # switch the SPI mux from BMC to Host
38 if [ -d "${KERNEL_SYSFS_FIU}/${KERNEL_FIU_ID}" ]; then
39 echo "${KERNEL_FIU_ID}" > "${KERNEL_SYSFS_FIU}"/unbind
40 fi
41 i2cset -y -f -a 13 0x76 0x10 0x00
42
XP Chenc4dc5d32021-07-27 11:33:13 -050043 # Disable LPI mode NV_SI_CPU_LPI_FREQ_DISABLE.
44 # Moved to before SCP as fwscp function returns 0 on success
45 nvparm -s 0x1 -o 0x114090
46 # TODO: Disabled toggling of SMPro heartbeat (require CPLD v 1.12.0.0+)
47 # nvparm -s 0x1 -o 0x5F0638
48 if [ $? -ne 0 ]; then
49 echo "Setting default nvparms failed " >&2
50 exit 1
51 fi
52
Lancelot Kao4357d532021-02-22 15:20:35 -060053 if [[ $(find ${1} -type f -size +17156k 2>/dev/null) ]]; then
54 echo "Extracting the SCP from the image"
55 dd if=$1 bs=1024 skip=17156 count=256 of=/run/initramfs/myscp.img
56 fwscp /run/initramfs/myscp.img
57 fi
XP Chenc4dc5d32021-07-27 11:33:13 -050058
Lancelot Kao4357d532021-02-22 15:20:35 -060059 rm -f $1
XP Chenc4dc5d32021-07-27 11:33:13 -050060 exit 0
Lancelot Kao4357d532021-02-22 15:20:35 -060061}
62
Lancelot Kao4357d532021-02-22 15:20:35 -060063function fwbmccpld() {
64 # BMC_JTAG_MUX_1 #218 0:BMC 1:MB
65 set_gpio_ctrl 218 out 0
66 loadsvf -d /dev/jtag0 -s $1 -m 0
XP Chenc4dc5d32021-07-27 11:33:13 -050067 if [ $? -ne 0 ]; then
68 echo "BMC CPLD update failed" >&2
69 exit 1
70 fi
Lancelot Kao4357d532021-02-22 15:20:35 -060071 wait
72 set_gpio_ctrl 218 out 1
73 rm -f $1
XP Chenc4dc5d32021-07-27 11:33:13 -050074 exit 0
Lancelot Kao4357d532021-02-22 15:20:35 -060075}
76
77function fwmbcpld() {
78 # BMC_JTAG_MUX_1 #218 0:BMC 1:MB
79 # BMC_JTAG_SEL #164 0:BMC 1:CPU
80 set_gpio_ctrl 218 out 1
81 set_gpio_ctrl 164 out 1
82 loadsvf -d /dev/jtag0 -s $1 -m 0
XP Chenc4dc5d32021-07-27 11:33:13 -050083 if [ $? -ne 0 ]; then
84 echo "Mobo CPLD update failed" >&2
85 exit 1
86 fi
Lancelot Kao4357d532021-02-22 15:20:35 -060087 wait
88 rm -f $1
XP Chenc4dc5d32021-07-27 11:33:13 -050089 exit 0
Lancelot Kao4357d532021-02-22 15:20:35 -060090}
91
92function fwscp() {
93 # BMC_I2C_BACKUP_SEL #168 0:failover, 1:main
94 # BMC_CPU_EEPROM_I2C_SEL #85 0:BMC, 1:CPU
95 set_gpio_ctrl 168 out 1
96 set_gpio_ctrl 85 out 0
97 I2C_BUS_DEV=$(ls -l $devpath/"13-0077/" | grep channel-0 | awk '{ print $11}' | cut -c 8-)
98 ampere_eeprom_prog -b $I2C_BUS_DEV -s 0x50 -p -f $1
XP Chenc4dc5d32021-07-27 11:33:13 -050099 if [ $? -ne 0 ]; then
100 echo "SCP eeprom update failed" >&2
101 exit 1
102 fi
Lancelot Kao4357d532021-02-22 15:20:35 -0600103 wait
104 set_gpio_ctrl 85 out 1
105 set_gpio_ctrl 168 out 1
106 rm -f $1
XP Chenc4dc5d32021-07-27 11:33:13 -0500107 exit 0
Lancelot Kao4357d532021-02-22 15:20:35 -0600108}
109
110function fwscpback() {
111 # BMC_I2C_BACKUP_SEL #168 0:failover, 1:main
112 # BMC_CPU_EEPROM_I2C_SEL #85 0:BMC, 1:CPU
113 set_gpio_ctrl 168 out 0
114 set_gpio_ctrl 85 out 0
115 I2C_BUS_DEV=$(ls -l $devpath/"13-0077/" | grep channel-0 | awk '{ print $11}' | cut -c 8-)
116 ampere_eeprom_prog -b $I2C_BUS_DEV -s 0x50 -p -f $1
XP Chenc4dc5d32021-07-27 11:33:13 -0500117 if [ $? -ne 0 ]; then
118 echo "SCP BACKUP eeprom update failed" >&2
119 exit 1
120 fi
Lancelot Kao4357d532021-02-22 15:20:35 -0600121 wait
122 set_gpio_ctrl 85 out 1
123 set_gpio_ctrl 168 out 1
124 rm -f $1
XP Chenc4dc5d32021-07-27 11:33:13 -0500125 exit 0
Lancelot Kao4357d532021-02-22 15:20:35 -0600126}
127
Mohaimen Alsamaraia17ba542021-06-18 11:47:41 -0500128function fwmb_pwr_seq(){
129 #$1 0x40 seq config file
130 #$2 0x41 seq config file
131 if [[ ! -e $1 ]]; then
132 echo "$1 file does not exist"
133 exit 1
134 fi
135 if [[ ! -e $2 ]]; then
136 echo "$2 file does not exist"
137 exit 1
138 fi
139 echo 32-0040 > /sys/bus/i2c/drivers/adm1266/unbind
140 echo 32-0041 > /sys/bus/i2c/drivers/adm1266/unbind
141 adm1266_fw_fx $1 $2
142 if [ $? -ne 0 ]; then
143 echo "The power seq flash failed" >&2
144 exit 1
145 fi
146 echo 32-0040 > /sys/bus/i2c/drivers/adm1266/bind
147 echo 32-0041 > /sys/bus/i2c/drivers/adm1266/bind
148 rm -f $1
149 rm -f $2
150 exit 0
151}
Lancelot Kao4357d532021-02-22 15:20:35 -0600152
XP Chenc4dc5d32021-07-27 11:33:13 -0500153if [[ ! $(which flashcp) ]]; then
154 echo "flashcp utility not installed"
155 exit 1
156fi
157if [[ ! $(which ampere_eeprom_prog) ]]; then
158 echo "ampere_eeprom_prog utility not installed"
159 exit 1
160fi
161if [[ ! $(which loadsvf) ]]; then
162 echo "loadsvf utility not installed"
163 exit 1
164fi
165if [[ ! -e /dev/jtag0 ]]; then
166 echo "Jtag device driver not functional"
167 exit 1
168fi
169
Lancelot Kao4357d532021-02-22 15:20:35 -0600170case $1 in
171 bios)
172 fwbios $2
173 ;;
174 bmccpld)
175 fwbmccpld $2
176 ;;
177 mbcpld)
178 fwmbcpld $2
179 ;;
180 scp)
181 fwscp $2
182 ;;
183 scpback)
184 fwscpback $2
185 ;;
Mohaimen Alsamaraia17ba542021-06-18 11:47:41 -0500186 mbseq)
187 fwmb_pwr_seq $2 $3
188 ;;
Lancelot Kao4357d532021-02-22 15:20:35 -0600189 *)
190 ;;
191esac