diff options
author | David Gibson <david@gibson.dropbear.id.au> | 2025-03-19 16:14:23 +1100 |
---|---|---|
committer | Stefano Brivio <sbrivio@redhat.com> | 2025-03-19 17:17:18 +0100 |
commit | c250ffc5c11385d9618b3a8165e676d68d5cbfa2 (patch) | |
tree | 419db89512ffc2765154ef2a7466346ce56de385 | |
parent | cfb3740568ab291d7be00e457658c45ce9367ed5 (diff) | |
download | passt-c250ffc5c11385d9618b3a8165e676d68d5cbfa2.tar passt-c250ffc5c11385d9618b3a8165e676d68d5cbfa2.tar.gz passt-c250ffc5c11385d9618b3a8165e676d68d5cbfa2.tar.bz2 passt-c250ffc5c11385d9618b3a8165e676d68d5cbfa2.tar.lz passt-c250ffc5c11385d9618b3a8165e676d68d5cbfa2.tar.xz passt-c250ffc5c11385d9618b3a8165e676d68d5cbfa2.tar.zst passt-c250ffc5c11385d9618b3a8165e676d68d5cbfa2.zip |
migrate: Bump migration version number
v1 of the migration stream format, had some flaws: it didn't properly
handle endianness of the MSS field, and it didn't transfer the RFC7323
timestamp. We've now fixed those bugs, but it requires incompatible
changes to the stream format.
Because of the timestamps in particular, v1 is not really usable, so there
is little point maintaining compatible support for it. However, v1 is in
released packages, both upstream and downstream (RHEL at least). Just
updating the stream format without bumping the version would lead to very
cryptic errors if anyone did attempt to migrate between an old and new
passt.
So, bump the migration version to v2, so we'll get a clear error message if
anyone attempts this. We don't attempt to maintain backwards compatibility
with v1, however: we'll simply fail if given a v1 stream.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Signed-off-by: Stefano Brivio <sbrivio@redhat.com>
-rw-r--r-- | migrate.c | 10 |
1 files changed, 7 insertions, 3 deletions
@@ -96,8 +96,8 @@ static int seen_addrs_target_v1(struct ctx *c, return 0; } -/* Stages for version 1 */ -static const struct migrate_stage stages_v1[] = { +/* Stages for version 2 */ +static const struct migrate_stage stages_v2[] = { { .name = "observed addresses", .source = seen_addrs_source_v1, @@ -118,7 +118,11 @@ static const struct migrate_stage stages_v1[] = { /* Supported encoding versions, from latest (most preferred) to oldest */ static const struct migrate_version versions[] = { - { 1, stages_v1, }, + { 2, stages_v2, }, + /* v1 was released, but not widely used. It had bad endianness for the + * MSS and omitted timestamps, which meant it usually wouldn't work. + * Therefore we don't attempt to support compatibility with it. + */ { 0 }, }; |