[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <mafs0y0ponf6b.fsf@kernel.org>
Date: Mon, 06 Oct 2025 18:55:08 +0200
From: Pratyush Yadav <pratyush@...nel.org>
To: Pasha Tatashin <pasha.tatashin@...een.com>
Cc: pratyush@...nel.org, 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, lennart@...ttering.net, brauner@...nel.org,
linux-api@...r.kernel.org, linux-fsdevel@...r.kernel.org,
saeedm@...dia.com, ajayachandra@...dia.com, jgg@...dia.com,
parav@...dia.com, leonro@...dia.com, witu@...dia.com,
hughd@...gle.com, skhawaja@...gle.com, chrisl@...nel.org,
steven.sistare@...cle.com
Subject: Re: [PATCH v4 02/30] kho: make debugfs interface optional
Hi Pasha,
On Mon, Sep 29 2025, Pasha Tatashin wrote:
> Currently, KHO is controlled via debugfs interface, but once LUO is
> introduced, it can control KHO, and the debug interface becomes
> optional.
>
> Add a separate config CONFIG_KEXEC_HANDOVER_DEBUG that enables
> the debugfs interface, and allows to inspect the tree.
>
> Move all debugfs related code to a new file to keep the .c files
> clear of ifdefs.
>
> Co-developed-by: Mike Rapoport (Microsoft) <rppt@...nel.org>
> Signed-off-by: Mike Rapoport (Microsoft) <rppt@...nel.org>
> Signed-off-by: Pasha Tatashin <pasha.tatashin@...een.com>
[...]
> @@ -662,36 +660,24 @@ static void __init kho_reserve_scratch(void)
> kho_enable = false;
> }
>
> -struct fdt_debugfs {
> - struct list_head list;
> - struct debugfs_blob_wrapper wrapper;
> - struct dentry *file;
> +struct kho_out {
> + struct blocking_notifier_head chain_head;
> + struct mutex lock; /* protects KHO FDT finalization */
> + struct kho_serialization ser;
> + bool finalized;
> + struct kho_debugfs dbg;
> };
>
> -static int kho_debugfs_fdt_add(struct list_head *list, struct dentry *dir,
> - const char *name, const void *fdt)
> -{
> - struct fdt_debugfs *f;
> - struct dentry *file;
> -
> - f = kmalloc(sizeof(*f), GFP_KERNEL);
> - if (!f)
> - return -ENOMEM;
> -
> - f->wrapper.data = (void *)fdt;
> - f->wrapper.size = fdt_totalsize(fdt);
> -
> - file = debugfs_create_blob(name, 0400, dir, &f->wrapper);
> - if (IS_ERR(file)) {
> - kfree(f);
> - return PTR_ERR(file);
> - }
> -
> - f->file = file;
> - list_add(&f->list, list);
> -
> - return 0;
> -}
> +static struct kho_out kho_out = {
> + .chain_head = BLOCKING_NOTIFIER_INIT(kho_out.chain_head),
> + .lock = __MUTEX_INITIALIZER(kho_out.lock),
> + .ser = {
> + .track = {
> + .orders = XARRAY_INIT(kho_out.ser.track.orders, 0),
> + },
> + },
> + .finalized = false,
> +};
There is already one definition for struct kho_out and a static struct
kho_out early in the file. This is a second declaration and definition.
And I was super confused when I saw patch 3 since it seemed to be making
unrelated changes to this struct (and removing an instance of this,
which should be done in this patch instead). In fact, this patch doesn't
even build due to this problem. I think some patch massaging is needed
to fix this all up.
>
> /**
> * kho_add_subtree - record the physical address of a sub FDT in KHO root tree.
[...]
--
Regards,
Pratyush Yadav
Powered by blists - more mailing lists