Currently, the FDT folio is preserved inside __kho_finalize(). If the
user performs multiple finalize/abort cycles, kho_preserve_folio() is
called repeatedly for the same FDT folio.

Since the FDT folio is allocated once during kho_init(), it should be
marked for preservation at the same time. Move the preservation call to
kho_init() to align the preservation state with the object's lifecycle
and simplify the finalize path.

Signed-off-by: Pasha Tatashin <[email protected]>
---
 kernel/liveupdate/kexec_handover.c | 8 ++++----
 1 file changed, 4 insertions(+), 4 deletions(-)

diff --git a/kernel/liveupdate/kexec_handover.c 
b/kernel/liveupdate/kexec_handover.c
index bc7f046a1313..a4b33ca79246 100644
--- a/kernel/liveupdate/kexec_handover.c
+++ b/kernel/liveupdate/kexec_handover.c
@@ -1164,10 +1164,6 @@ static int __kho_finalize(void)
        if (err)
                goto abort;
 
-       err = kho_preserve_folio(virt_to_folio(kho_out.fdt));
-       if (err)
-               goto abort;
-
        err = kho_mem_serialize(&kho_out);
        if (err)
                goto abort;
@@ -1319,6 +1315,10 @@ static __init int kho_init(void)
        if (err)
                goto err_free_fdt;
 
+       err = kho_preserve_folio(virt_to_folio(kho_out.fdt));
+       if (err)
+               goto err_free_fdt;
+
        if (fdt) {
                kho_in_debugfs_init(&kho_in.dbg, fdt);
                return 0;
-- 
2.52.0.rc1.455.g30608eb744-goog


Reply via email to