blob: 7b1f79bfc56bb7fca0aa388c6b217c9edf015b3b [file] [log] [blame]
Adriana Kobylake8606da2020-07-15 09:16:56 -05001#!/bin/sh
2
Isaac Kurth514a0942021-10-19 21:17:44 +00003bios_reset_if_needed() {
4 resetval=$(fw_printenv -n rwreset 2>/dev/nell)
5 if [ "$resetval" = "0" ] || [ "$resetval" = "1" ]; then
6 varstore="/media/hostfw/reset-gpio-val"
7 if [ -f "$varstore" ]; then
8 if [ "$resetval" != "$(cat $varstore)" ]; then
9 if busctl call org.open_power.Software.Host.Updater /xyz/openbmc_project/software xyz.openbmc_project.Common.FactoryReset Reset; then
10 echo "$resetval" > "$varstore"
11 fi
12 fi
13 else
14 echo "$resetval" > "$varstore"
15 fi
16 fi
17}
18
Adriana Kobylake8606da2020-07-15 09:16:56 -050019mmc_init() {
20 base_dir="/media/hostfw"
Adriana Kobylak98f22322020-07-20 10:39:41 -050021 ro_dir="${base_dir}/running-ro"
Adriana Kobylake8606da2020-07-15 09:16:56 -050022 running_dir="${base_dir}/running"
23 prsv_dir="${base_dir}/prsv"
Adriana Kobylak87372ae2020-09-01 11:30:59 -050024 staging_dir="${base_dir}/staging"
Adriana Kobylak8652eb92022-05-20 14:35:35 +000025 nvram_dir="${base_dir}/nvram"
Adriana Kobylake8606da2020-07-15 09:16:56 -050026
Adriana Kobylak98f22322020-07-20 10:39:41 -050027 if [ ! -d "${ro_dir}" ]; then
28 mkdir -p "${ro_dir}"
29 fi
Adriana Kobylake8606da2020-07-15 09:16:56 -050030 if [ ! -d "${running_dir}" ]; then
31 mkdir -p ${running_dir}
32 fi
33 if [ ! -d "${prsv_dir}" ]; then
34 mkdir -p "${prsv_dir}"
35 fi
Adriana Kobylak87372ae2020-09-01 11:30:59 -050036 if [ ! -d "${staging_dir}" ]; then
37 mkdir -p "${staging_dir}"
38 fi
Adriana Kobylak8652eb92022-05-20 14:35:35 +000039 if [ ! -d "${nvram_dir}" ]; then
40 mkdir -p "${nvram_dir}"
41 fi
Adriana Kobylake8606da2020-07-15 09:16:56 -050042
Adriana Kobylak98f22322020-07-20 10:39:41 -050043 # Mount the image that corresponds to the boot label as read-only to be used
44 # to populate the running directory.
Adriana Kobylake8606da2020-07-15 09:16:56 -050045 boot_label="$(fw_printenv -n bootside)"
Isaac Kurth0ddd4fa2021-07-14 17:35:37 -050046 if ! grep -q "${ro_dir}" /proc/mounts; then
47 mount ${base_dir}/hostfw-"${boot_label}" ${ro_dir} -o ro
48 fi
Adriana Kobylak98f22322020-07-20 10:39:41 -050049
50 # Determine if the running dir contains the running version
Adriana Kobylake8606da2020-07-15 09:16:56 -050051 running_label=""
52 running_label_file="${running_dir}/partlabel"
53 if [ -f "${running_label_file}" ]; then
54 running_label=$(cat ${running_label_file})
55 fi
56 if [ "${running_label}" != "${boot_label}" ]; then
57 # Copy off the preserved partitions
Adriana Kobylak4e82bc82021-09-28 19:25:39 +000058 # A line in the pnor.toc (81e00994.lid) looks like this:
Adriana Kobylake8606da2020-07-15 09:16:56 -050059 # partition05=SECBOOT,0x00381000,0x003a5000,00,ECC,PRESERVED
60 rm -f ${prsv_dir}/*
Adriana Kobylak4e82bc82021-09-28 19:25:39 +000061 if [ -f "${ro_dir}/81e00994.lid" ]; then
62 prsvs=$(grep PRESERVED "${ro_dir}/81e00994.lid")
Adriana Kobylake8606da2020-07-15 09:16:56 -050063 for prsv in ${prsvs}; do
64 prsv=${prsv##partition*=}
Adriana Kobylakf6d4d762021-04-21 10:46:14 -050065 prsv=$(echo "${prsv}" | cut -d "," -f 1)
Adriana Kobylakff675db2021-09-07 18:00:57 +000066 if [ -L "${running_dir}/${prsv}" ]; then
67 # Preserve the symlink target file
68 prsv="$(readlink "${running_dir}/${prsv}")"
69 cp -p ${running_dir}/"${prsv}" ${prsv_dir}
70 fi
Adriana Kobylake8606da2020-07-15 09:16:56 -050071 done
72 fi
73
Adriana Kobylakff675db2021-09-07 18:00:57 +000074 # Copy lid contents of running image to running dir
Adriana Kobylake8606da2020-07-15 09:16:56 -050075 rm -f ${running_dir}/*
Adriana Kobylakff675db2021-09-07 18:00:57 +000076 cp -p ${ro_dir}/*.lid ${running_dir}/
Adriana Kobylake8606da2020-07-15 09:16:56 -050077
Adriana Kobylak98f22322020-07-20 10:39:41 -050078 # Restore the preserved partitions. Ignore error, there may be none.
79 cp -p ${prsv_dir}/* ${running_dir}/ 2>/dev/null || true
Adriana Kobylakf6d4d762021-04-21 10:46:14 -050080 rm -f "${prsv_dir:?}/"*
Adriana Kobylake8606da2020-07-15 09:16:56 -050081
Adriana Kobylak87372ae2020-09-01 11:30:59 -050082 # Clean up the staging dir in case of a failed update
Adriana Kobylakf6d4d762021-04-21 10:46:14 -050083 rm -rf "${staging_dir:?}/"*
Adriana Kobylak87372ae2020-09-01 11:30:59 -050084
Adriana Kobylake8606da2020-07-15 09:16:56 -050085 # Save the label
86 echo "${boot_label}" > "${running_label_file}"
87
Adriana Kobylake8606da2020-07-15 09:16:56 -050088 fi
89
90 # Mount alternate dir
91 if [ "${boot_label}" = "a" ]; then
92 alternate_label="b"
93 else
94 alternate_label="a"
95 fi
96 alternate_dir="${base_dir}/alternate"
97 if [ ! -d "${alternate_dir}" ]; then
98 mkdir -p ${alternate_dir}
99 fi
Isaac Kurth0ddd4fa2021-07-14 17:35:37 -0500100 if ! grep -q "${alternate_dir}" /proc/mounts; then
101 mount ${base_dir}/hostfw-${alternate_label} ${alternate_dir} -o ro
102 fi
Adriana Kobylake8606da2020-07-15 09:16:56 -0500103}
104
105mmc_patch() {
106 # Patching is disabled if field mode is set
Adriana Kobylakf6d4d762021-04-21 10:46:14 -0500107 if [ "$(fw_printenv fieldmode 2>/dev/null)" = "fieldmode=true" ]; then
Adriana Kobylake8606da2020-07-15 09:16:56 -0500108 return 0
109 fi
110
Adriana Kobylakf6608a82020-08-25 14:16:23 -0500111 boot_label="$(fw_printenv -n bootside)"
112 if [ "${boot_label}" = "a" ]; then
113 alternate_label="b"
114 else
115 alternate_label="a"
Adriana Kobylake8606da2020-07-15 09:16:56 -0500116 fi
117
Adriana Kobylakf6608a82020-08-25 14:16:23 -0500118 # Create patch directories
119 patch_dir="/media/hostfw/patch-"
120 running_patch_dir="${patch_dir}${boot_label}"
121 if [ ! -d "${running_patch_dir}" ]; then
122 mkdir -p "${running_patch_dir}"
123 fi
124 alternate_patch_dir="${patch_dir}${alternate_label}"
125 if [ ! -d "${alternate_patch_dir}" ]; then
126 mkdir -p "${alternate_patch_dir}"
Adriana Kobylake8606da2020-07-15 09:16:56 -0500127 fi
128
Adriana Kobylakf6608a82020-08-25 14:16:23 -0500129 # Create patch symlinks
130 symlink_base="/usr/local/share"
131 if [ ! -d "${symlink_base}" ]; then
132 mkdir -p "${symlink_base}"
133 fi
134 hostfw_symlink_base="${symlink_base}/hostfw"
135 if [ ! -d "${hostfw_symlink_base}" ]; then
136 mkdir -p "${hostfw_symlink_base}"
137 fi
138
Isaac Kurth0ddd4fa2021-07-14 17:35:37 -0500139 if [ "$(readlink -f "${symlink_base}/pnor")" != "${running_patch_dir}" ]; then
140 ln -s "${running_patch_dir}" "${symlink_base}/pnor"
141 fi
142 if [ "$(readlink -f "${hostfw_symlink_base}/running")" != "${running_patch_dir}" ]; then
143 ln -s "${running_patch_dir}" "${hostfw_symlink_base}/running"
144 fi
145 if [ "$(readlink -f "${hostfw_symlink_base}/alternate")" != "${alternate_patch_dir}" ]; then
146 ln -s "${alternate_patch_dir}" "${hostfw_symlink_base}/alternate"
147 fi
Adriana Kobylake8606da2020-07-15 09:16:56 -0500148}
149
150case "$1" in
Isaac Kurth514a0942021-10-19 21:17:44 +0000151 bios-reset-if-needed)
152 bios_reset_if_needed
153 ;;
Adriana Kobylake8606da2020-07-15 09:16:56 -0500154 mmc-init)
155 mmc_init
156 ;;
157 mmc-patch)
158 mmc_patch
159 ;;
160 *)
Isaac Kurth514a0942021-10-19 21:17:44 +0000161 echo "Invalid argument: $1" >&2
Adriana Kobylake8606da2020-07-15 09:16:56 -0500162 exit 1
163 ;;
164esac