[PATCH 0/5] sysupgrade: introduce compatibility version for devices

Adrian Schmutzler freifunk at adrianschmutzler.de
Thu Jul 9 14:14:55 EDT 2020


We regularly encounter the situation that devices are subject to
changes that will make them incompatible to previous versions.
Removing SUPPORTED_DEVICES will not really be helpful in most of these
cases, as this only helps after a rename.

To solve this situation, this patchset introduces a compatibility
version for devices. It is implemented by a compat_version set for
the device and in image metadata, where old images default to 1.0.

If an incompatible change is introduced, one can increase either
the minor version (1.0->1.1) or the major version (1.0->2.0).

Minor version increment:
This will still allow sysupgrade, but require to reset config
(-n or SAVE_CONFIG=0). If sysupgrade is called without -n, a
corresponding message will be printed. If sysupgrade is called
with -n, it will just pass, with supported devices being checked
as usual. (Which will allow us to add back SUPPORTED_DEVICES for
many cases.)

Major version increment:
This is meant for potential (rare) cases where sysupgrade is
not possible at all, because it would break the device.
In this case, a warning will be printed, and -n won't help.

If image check fails because of one of the versions parts not
matching, the content of DEVICE_COMPAT_MESSAGE is printed in
addition to the generic message (if set).

For both cases, upgrade can still be forced with -F as usual.

By a small trick, this is also applied in a way that will work
sufficiently well for old devices not having the updated fwtool.sh

I hope that this will allow to improve the update experience for
incompatible changes beyond just removing SUPPORTED_DEVICES
as it has been done in the past.

This has been tested on device and appear to work.

I have no idea what this will do with LuCI...

Adrian Schmutzler (5):
  build: add DEVICE_COMPAT_VERSION and DEVICE_COMPAT_MESSAGE
  base-files: add support for compat_version on device
  base-files: fwtool: implement compatibility check for images
  base-files: fwtool: make compat_version backward compatible
  example: implement compat_version for devices

 include/image-commands.mk                     |  9 +++++--
 include/image.mk                              |  3 +++
 package/base-files/files/bin/config_generate  |  7 +++++
 .../files/lib/functions/uci-defaults.sh       |  6 +++++
 .../base-files/files/lib/upgrade/fwtool.sh    | 27 ++++++++++++++++++-
 .../generic/base-files/etc/board.d/02_network | 12 +++++++--
 target/linux/ath79/image/generic-tp-link.mk   |  3 +++
 7 files changed, 62 insertions(+), 5 deletions(-)

-- 
2.20.1




More information about the openwrt-devel mailing list