1 # The U-Boot loader of the OpenMesh devices requires image sizes and
2 # checksums to be provided in the U-Boot environment.
3 # The OpenMesh devices come with 2 main partitions - while one is active
4 # sysupgrade will flash the other. The boot order is changed to boot the
5 # newly flashed partition. If the new partition can't be booted due to
6 # upgrade failures the previously used partition is loaded.
16 local section
=$2 our_section
=0
17 local param
=$3 our_param
=
21 [ "$cfg_opt" = "[$section]" ] && our_section
=1 && continue
22 [ "$our_section" = "1" ] ||
continue
24 our_param
=$
(echo ${cfg_opt%%=*})
25 [ "$param" = "$our_param" ] && echo ${cfg_opt##*=} && break
29 # make sure we got uboot-envtools and fw_env.config copied over to the ramfs
30 platform_add_ramfs_ubootenv
()
32 [ -e /usr
/sbin
/fw_printenv
] && install_bin
/usr
/sbin
/fw_printenv
/usr
/sbin
/fw_setenv
33 [ -e /etc
/fw_env.config
] && install_file
/etc
/fw_env.config
35 append sysupgrade_pre_upgrade platform_add_ramfs_ubootenv
37 platform_check_image_openmesh
()
41 local fw_printenv
=/usr
/sbin
/fw_printenv
42 local img_board_target
= img_num_files
= i
=0
43 local cfg_name
= kernel_name
= rootfs_name
=
46 # Combined Extended Image v1
48 img_board_target
=$
(trim $
(dd if="$img_path" bs
=4 skip
=1 count
=8 2>/dev
/null
))
49 img_num_files
=$
(trim $
(dd if="$img_path" bs
=2 skip
=18 count
=1 2>/dev
/null
))
52 echo "Invalid image ($img_magic). Use combined extended images on this platform"
57 case "$img_board_target" in
59 [ "$board" = "om2p" ] && break
60 [ "$board" = "om2p-lc" ] && break
61 [ "$board" = "om2p-hs" ] && break
62 echo "Invalid image board target ($img_board_target) for this platform: $board. Use the correct image for this platform"
66 [ "$board" = "mr600" ] && break
67 [ "$board" = "mr600v2" ] && break
68 echo "Invalid image board target ($img_board_target) for this platform: $board. Use the correct image for this platform"
72 echo "Invalid board target ($img_board_target). Use the correct image for this platform"
77 [ $img_num_files -ne 3 ] && {
78 echo "Invalid number of embedded images ($img_num_files). Use the correct image for this platform"
82 cfg_name
=$
(trim $
(dd if="$img_path" bs
=2 skip
=19 count
=16 2>/dev
/null
))
84 [ "$cfg_name" != "fwupgrade.cfg" ] && {
85 echo "Invalid embedded config file ($cfg_name). Use the correct image for this platform"
89 kernel_name
=$
(trim $
(dd if="$img_path" bs
=2 skip
=55 count
=16 2>/dev
/null
))
91 [ "$kernel_name" != "kernel" ] && {
92 echo "Invalid embedded kernel file ($kernel_name). Use the correct image for this platform"
96 rootfs_name
=$
(trim $
(dd if="$img_path" bs
=2 skip
=91 count
=16 2>/dev
/null
))
98 [ "$rootfs_name" != "rootfs" ] && {
99 echo "Invalid embedded kernel file ($rootfs_name). Use the correct image for this platform"
103 [ ! -x "$fw_printenv" ] && {
104 echo "Please install uboot-envtools!"
108 [ ! -r "/etc/fw_env.config" ] && {
109 echo "/etc/fw_env.config is missing"
116 platform_do_upgrade_openmesh
()
118 local img_path
=$1 img_board_target
=
119 local kernel_start_addr
= kernel_start_addr1
= kernel_start_addr2
=
120 local kernel_size
= kernel_md5
=
121 local rootfs_size
= rootfs_checksize
= rootfs_md5
=
122 local kernel_bsize
= total_size
=7340032
123 local data_offset
=$
((64 * 1024)) block_size
= offset
=
124 local uboot_env_upgrade
="/tmp/fw_env_upgrade"
125 local cfg_size
= kernel_size
= rootfs_size
=
128 [ -f "$CONF_TAR" -a "$SAVE_CONFIG" -eq 1 ] && append
="-j $CONF_TAR"
130 cfg_size
=$
(dd if="$img_path" bs
=2 skip
=35 count
=4 2>/dev
/null
)
131 kernel_size
=$
(dd if="$img_path" bs
=2 skip
=71 count
=4 2>/dev
/null
)
132 rootfs_size
=$
(dd if="$img_path" bs
=2 skip
=107 count
=4 2>/dev
/null
)
134 img_board_target
=$
(trim $
(dd if="$img_path" bs
=4 skip
=1 count
=8 2>/dev
/null
))
135 cfg_content
=$
(dd if="$img_path" bs
=1 skip
=$data_offset count
=$
(echo $
((0x
$cfg_size))) 2>/dev
/null
)
137 case $img_board_target in
139 block_size
=$
((256 * 1024))
140 kernel_start_addr1
=0x9f1c0000
141 kernel_start_addr2
=0x9f8c0000
144 block_size
=$
((64 * 1024))
145 kernel_start_addr1
=0x9f0b0000
146 kernel_start_addr2
=0x9f850000
150 kernel_md5
=$
(cfg_value_get
"$cfg_content" "vmlinux" "md5sum")
151 rootfs_md5
=$
(cfg_value_get
"$cfg_content" "rootfs" "md5sum")
152 rootfs_checksize
=$
(cfg_value_get
"$cfg_content" "rootfs" "checksize")
154 if [ "$((0x$kernel_size % $block_size))" = "0" ]
156 kernel_bsize
=$
(echo $
((0x
$kernel_size)))
158 kernel_bsize
=$
((0x
$kernel_size + ($block_size - (0x
$kernel_size % $block_size))))
161 mtd
-q erase inactive
163 offset
=$
(echo $
(($data_offset + 0x
$cfg_size + 0x
$kernel_size)))
164 dd if="$img_path" bs
=1 skip
=$offset count
=$
(echo $
((0x
$rootfs_size))) 2>&- | mtd
-n -p $kernel_bsize $append write - "inactive"
166 offset
=$
(echo $
(($data_offset + 0x
$cfg_size)))
167 dd if="$img_path" bs
=1 skip
=$offset count
=$
(echo $
((0x
$kernel_size))) 2>&- | mtd
-n write - "inactive"
169 rm $uboot_env_upgrade 2>&-
171 if [ "$(grep 'mtd3:.*inactive' /proc/mtd)" ]
173 printf "kernel_size_1 %u\n" $
(($kernel_bsize / 1024)) >> $uboot_env_upgrade
174 printf "rootfs_size_1 %u\n" $
((($total_size - $kernel_bsize) / 1024)) >> $uboot_env_upgrade
175 printf "bootseq 1,2\n" >> $uboot_env_upgrade
176 kernel_start_addr
=$kernel_start_addr1
178 printf "kernel_size_2 %u\n" $
(($kernel_bsize / 1024)) >> $uboot_env_upgrade
179 printf "rootfs_size_2 %u\n" $
((($total_size - $kernel_bsize) / 1024)) >> $uboot_env_upgrade
180 printf "bootseq 2,1\n" >> $uboot_env_upgrade
181 kernel_start_addr
=$kernel_start_addr2
184 printf "vmlinux_start_addr %s\n" $kernel_start_addr >> $uboot_env_upgrade
185 printf "vmlinux_size 0x%s\n" $kernel_size >> $uboot_env_upgrade
186 printf "vmlinux_checksum %s\n" $kernel_md5 >> $uboot_env_upgrade
187 printf "rootfs_start_addr 0x%x\n" $
(($kernel_start_addr + $kernel_bsize)) >> $uboot_env_upgrade
188 printf "rootfs_size %s\n" $rootfs_checksize >> $uboot_env_upgrade
189 printf "rootfs_checksum %s\n" $rootfs_md5 >> $uboot_env_upgrade
191 fw_setenv
-s $uboot_env_upgrade ||
{
192 echo "failed to update U-Boot environment"