[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <CA+CK2bCigGJJqtSt1-4GP0JPVCZrTa6WS4LiMTT0J=04G64e5w@mail.gmail.com>
Date: Sun, 8 Jun 2025 09:49:15 -0400
From: Pasha Tatashin <pasha.tatashin@...een.com>
To: Pratyush Yadav <pratyush@...nel.org>
Cc: jasonmiu@...gle.com, graf@...zon.com, changyuanl@...gle.com,
rppt@...nel.org, dmatlack@...gle.com, rientjes@...gle.com, corbet@....net,
rdunlap@...radead.org, ilpo.jarvinen@...ux.intel.com, kanie@...ux.alibaba.com,
ojeda@...nel.org, aliceryhl@...gle.com, masahiroy@...nel.org,
akpm@...ux-foundation.org, tj@...nel.org, yoann.congal@...le.fr,
mmaurer@...gle.com, roman.gushchin@...ux.dev, chenridong@...wei.com,
axboe@...nel.dk, mark.rutland@....com, jannh@...gle.com,
vincent.guittot@...aro.org, hannes@...xchg.org, dan.j.williams@...el.com,
david@...hat.com, joel.granados@...nel.org, rostedt@...dmis.org,
anna.schumaker@...cle.com, song@...nel.org, zhangguopeng@...inos.cn,
linux@...ssschuh.net, linux-kernel@...r.kernel.org, linux-doc@...r.kernel.org,
linux-mm@...ck.org, gregkh@...uxfoundation.org, tglx@...utronix.de,
mingo@...hat.com, bp@...en8.de, dave.hansen@...ux.intel.com, x86@...nel.org,
hpa@...or.com, rafael@...nel.org, dakr@...nel.org,
bartosz.golaszewski@...aro.org, cw00.choi@...sung.com,
myungjoo.ham@...sung.com, yesanishhere@...il.com, Jonathan.Cameron@...wei.com,
quic_zijuhu@...cinc.com, aleksander.lobakin@...el.com, ira.weiny@...el.com,
andriy.shevchenko@...ux.intel.com, leon@...nel.org, lukas@...ner.de,
bhelgaas@...gle.com, wagi@...nel.org, djeffery@...hat.com,
stuart.w.hayes@...il.com
Subject: Re: [RFC v2 09/16] luo: luo_files: implement file systems callbacks
On Thu, Jun 5, 2025 at 12:04 PM Pratyush Yadav <pratyush@...nel.org> wrote:
>
> On Thu, May 15 2025, Pasha Tatashin wrote:
>
> > Implements the core logic within luo_files.c to invoke the prepare,
> > reboot, finish, and cancel callbacks for preserved file instances,
> > replacing the previous stub implementations. It also handles
> > the persistence and retrieval of the u64 data payload associated with
> > each file via the LUO FDT.
> >
> > This completes the core mechanism enabling registered filesystem
> > handlers to actively manage file state across the live update
> > transition using the LUO framework.
> >
> > Signed-off-by: Pasha Tatashin <pasha.tatashin@...een.com>
> > ---
> > drivers/misc/liveupdate/luo_files.c | 105 +++++++++++++++++++++++++++-
> > 1 file changed, 103 insertions(+), 2 deletions(-)
> >
> [...]
> > @@ -305,7 +369,29 @@ int luo_do_files_prepare_calls(void)
> > */
> > int luo_do_files_freeze_calls(void)
> > {
> > - return 0;
> > + unsigned long token;
> > + struct luo_file *h;
> > + int ret;
> > +
> > + xa_for_each(&luo_files_xa_out, token, h) {
>
> Should we also ensure at this point that there are no open handles to
> this file? How else would a file system ensure the file is in quiescent
> state to do its final serialization?
Do you mean check refcnt here? If so, this is a good idea, but first
we need to implement the lifecycle of liveupdate agent correctectly,
where owner of FD must survive through entering into reboot() with
/dev/liveupdate still open.
> This conflicts with my suggestion to have freeze callbacks never fail,
> but now that I think of it, this is also important, so maybe we have to
> live with freeze that can fail.
>
> > + if (h->fs->freeze) {
> > + ret = h->fs->freeze(h->file, h->fs->arg,
> > + &h->private_data);
> > + if (ret < 0) {
> > + pr_err("Freeze callback failed for file token %#0llx handler '%s' [%d]\n",
> > + (u64)token, h->fs->compatible, ret);
> > + __luo_do_files_cancel_calls(h);
> > +
> > + return ret;
> > + }
> > + }
> > + }
> > +
> > + ret = luo_files_commit_data_to_fdt();
> > + if (ret)
> > + __luo_do_files_cancel_calls(NULL);
> > +
> > + return ret;
> > }
> >
> > /**
> > @@ -316,7 +402,20 @@ int luo_do_files_freeze_calls(void)
> > */
> > void luo_do_files_finish_calls(void)
> > {
> > + unsigned long token;
> > + struct luo_file *h;
> > +
> > luo_files_recreate_luo_files_xa_in();
> > + xa_for_each(&luo_files_xa_in, token, h) {
> > + mutex_lock(&h->mutex);
> > + if (h->state == LIVEUPDATE_STATE_UPDATED && h->fs->finish) {
> > + h->fs->finish(h->file, h->fs->arg,
> > + h->private_data,
> > + h->reclaimed);
> > + h->state = LIVEUPDATE_STATE_NORMAL;
> > + }
> > + mutex_unlock(&h->mutex);
> > + }
>
> We can also clean up luo_files_xa_in at this point, right?
Yes, we can.
Thank you,
Pasha
>
> > }
> >
> > /**
> > @@ -330,6 +429,8 @@ void luo_do_files_finish_calls(void)
> > */
> > void luo_do_files_cancel_calls(void)
> > {
> > + __luo_do_files_cancel_calls(NULL);
> > + luo_files_commit_data_to_fdt();
> > }
> >
> > /**
>
> --
> Regards,
> Pratyush Yadav
Powered by blists - more mailing lists