ipq40xx: unbreak EZVIZ CS-W3-WD1200G EUP on 5.10
authorChristian Lamparter <chunkeey@gmail.com>
Sun, 28 Nov 2021 14:26:18 +0000 (15:26 +0100)
committerChristian Lamparter <chunkeey@gmail.com>
Fri, 3 Dec 2021 23:36:47 +0000 (00:36 +0100)
commit45eb57f12f3a128a1822a20b7e536527ab92ca67
tree6fe1a8a9342f040bb9df3e961f58351a60174b6d
parenteb20a1b8bb631084b9a70126eac2a6e32c3f3565
ipq40xx: unbreak EZVIZ CS-W3-WD1200G EUP on 5.10

with current images, the device is no longer booting.
It gets stuck in the bootloader with "Config not available"
and drops to the uboot shell.

|flash_type: 0
|Hit any key to stop autoboot:  0
|SF: Detected MX25L12805D with page size 4 KiB, total 16 MiB
|Config not availabale
|(IPQ40xx) #

This is because the default bootcmd "bootipq" will only read
the first four MiB of the kernel image. With 5.10 the gzip'd
kernel is slightly larger. So the part of the FIT image which
had the configuration is cut off. Hence it can't find it.

To update the bootcmd, you have to attach the serial console
again and enter the following commands into the boot prompt:

 # setenv bootcmd "sf probe; sf read 84000000 180000 600000; bootm"
 # saveenv
 # run bootcmd

This will allow booting kernels with up to six MiB. This also
allows us to drop the DEVICE_DTS_CONFIG hack we had to use.

Note:
uboot doesn't support LZMA. It fails with:
"Unimplemented compression type 3"

Signed-off-by: Christian Lamparter <chunkeey@gmail.com>
target/linux/ipq40xx/base-files/etc/uci-defaults/05_fix-compat-version [new file with mode: 0644]
target/linux/ipq40xx/image/generic.mk