From: Pasha Tatashin <pasha.tatashin@soleen.com>
To: Mike Rapoport <rppt@kernel.org>
Cc: Pasha Tatashin <pasha.tatashin@soleen.com>,
linux-kselftest@vger.kernel.org, shuah@kernel.org,
akpm@linux-foundation.org, linux-mm@kvack.org,
skhan@linuxfoundation.org, linux-doc@vger.kernel.org,
linux-kernel@vger.kernel.org, corbet@lwn.net,
dmatlack@google.com, kexec@lists.infradead.org,
pratyush@kernel.org, skhawaja@google.com, graf@amazon.com
Subject: Re: [PATCH v6 07/13] kho: add support for linked-block serialization
Date: Wed, 3 Jun 2026 12:05:04 +0000 [thread overview]
Message-ID: <aiANtYRRDr5iO5QR@plex> (raw)
In-Reply-To: <178046937151.468621.13398573538792303093.b4-review@b4>
On 06-03 09:49, Mike Rapoport wrote:
> On Wed, 03 Jun 2026 03:28:58 +0000, Pasha Tatashin <pasha.tatashin@soleen.com> wrote:
> > diff --git a/include/linux/kho/abi/block.h b/include/linux/kho/abi/block.h
> > new file mode 100644
> > index 000000000000..8641c20b379b
> > --- /dev/null
> > +++ b/include/linux/kho/abi/block.h
> > @@ -0,0 +1,56 @@
> > [ ... skip 25 lines ... ]
> > +#define _LINUX_KHO_ABI_BLOCK_H
> > +
> > +#include <asm/page.h>
> > +#include <linux/types.h>
> > +
> > +#define KHO_BLOCK_ABI_COMPATIBLE "kho-block-v1"
>
> It's never used by block set and after looking at the following patches I
> found that it's appended to LUO compatible string.
>
> While this works for LUO, I think it should be kho_block_set_restore()
> responsibility to verify the compatibility.
It should work for any component that relies on kho_block. My proposal
is to use this method for other common KHO data structures (e.g., kho
vmalloc, kho radix, future kho xarray). There is no need for them to
carry the compatibility string in their metadata, as whoever uses them
will include their compatibility string.
For now, reviewers will have to make sure that if the ABI header content
is changed, the compatibility string is updated.
> > diff --git a/kernel/liveupdate/kho_block.c b/kernel/liveupdate/kho_block.c
> > new file mode 100644
> > index 000000000000..4f147c308e6b
> > --- /dev/null
> > +++ b/kernel/liveupdate/kho_block.c
> > @@ -0,0 +1,411 @@
> > [ ... skip 121 lines ... ]
> > +/**
> > + * kho_block_set_grow - Expand the block set to accommodate the target count.
> > + * @bs: The block set.
> > + * @count: The target number of valid entries to accommodate.
> > + *
> > + * Acts as a runtime notifier when new resources (such as files or sessions)
>
> Not sure I understand what "runtime notifier" means in this context.
It came from discussion with Pratyush, but I think we are on the same
page what they are, and I will just remove this.
>
> > [ ... skip 11 lines ... ]
> > +
> > + while (count > bs->nblocks * bs->count_per_block) {
> > + int err = kho_block_set_grow_one(bs);
> > +
> > + if (err)
> > + return err;
>
> This leaks memory if more than one block is added.
>
> > [ ... skip 31 lines ... ]
> > + * unregistered, allowing the block set to release and unallocate redundant
> > + * preserved memory blocks. Checks if the last block in the set can be removed
> > + * because the remaining entry count is fully accommodated by the preceding blocks.
> > + *
> > + * Note: It is the caller's responsibility to ensure that entries are removed
> > + * in LIFO (last-in, first-out) order (the reverse order of their insertion).
>
> I think "in LIFO order" is sufficient :)
Oh, I keep removing those :-)
> > [ ... skip 173 lines ... ]
> > + it->i = 0;
> > + }
> > +
> > + entry = kho_block_entry(it, it->i++);
> > + it->block->ser->count = it->i;
> > + return entry;
>
> This looks way better than the previous version :)
> Thanks!
Thank you. I will send a new version of this patch as a reply to this
email to avoid cluttering the mailing list.
Pasha
>
> --
> Sincerely yours,
> Mike.
>
next prev parent reply other threads:[~2026-06-03 12:05 UTC|newest]
Thread overview: 24+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-06-03 3:28 [PATCH v6 00/13] liveupdate: Remove limits on sessions and files Pasha Tatashin
2026-06-03 3:28 ` [PATCH v6 01/13] liveupdate: change file_set->count type to u64 for type safety Pasha Tatashin
2026-06-03 3:28 ` [PATCH v6 02/13] liveupdate: avoid mixing cleanup guards with goto in luo_session_retrieve_fd Pasha Tatashin
2026-06-03 6:52 ` Mike Rapoport
2026-06-03 3:28 ` [PATCH v6 03/13] liveupdate: centralize state management into struct luo_ser Pasha Tatashin
2026-06-03 6:52 ` Mike Rapoport
2026-06-03 3:28 ` [PATCH v6 04/13] liveupdate: register luo_ser as KHO subtree Pasha Tatashin
2026-06-03 6:50 ` Mike Rapoport
2026-06-03 9:32 ` Mike Rapoport
2026-06-03 13:31 ` Mike Rapoport
2026-06-03 3:28 ` [PATCH v6 05/13] liveupdate: Extract luo_file_deserialize_one helper Pasha Tatashin
2026-06-03 3:28 ` [PATCH v6 06/13] liveupdate: Extract luo_session_deserialize_one helper Pasha Tatashin
2026-06-03 3:28 ` [PATCH v6 07/13] kho: add support for linked-block serialization Pasha Tatashin
2026-06-03 6:49 ` Mike Rapoport
2026-06-03 12:05 ` Pasha Tatashin [this message]
2026-06-03 13:21 ` Pasha Tatashin
2026-06-03 13:59 ` Mike Rapoport
2026-06-03 14:11 ` Pasha Tatashin
2026-06-03 3:28 ` [PATCH v6 08/13] liveupdate: defer session block allocation and physical address setting Pasha Tatashin
2026-06-03 3:29 ` [PATCH v6 09/13] liveupdate: Remove limit on the number of sessions Pasha Tatashin
2026-06-03 3:29 ` [PATCH v6 10/13] liveupdate: Remove limit on the number of files per session Pasha Tatashin
2026-06-03 3:29 ` [PATCH v6 11/13] selftests/liveupdate: Test session and file limit removal Pasha Tatashin
2026-06-03 3:29 ` [PATCH v6 12/13] selftests/liveupdate: Add stress-sessions kexec test Pasha Tatashin
2026-06-03 3:29 ` [PATCH v6 13/13] selftests/liveupdate: Add stress-files " Pasha Tatashin
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=aiANtYRRDr5iO5QR@plex \
--to=pasha.tatashin@soleen.com \
--cc=akpm@linux-foundation.org \
--cc=corbet@lwn.net \
--cc=dmatlack@google.com \
--cc=graf@amazon.com \
--cc=kexec@lists.infradead.org \
--cc=linux-doc@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-kselftest@vger.kernel.org \
--cc=linux-mm@kvack.org \
--cc=pratyush@kernel.org \
--cc=rppt@kernel.org \
--cc=shuah@kernel.org \
--cc=skhan@linuxfoundation.org \
--cc=skhawaja@google.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox