On 25/10/2024 23:15, Rob Herring wrote: > On Wed, Oct 23, 2024 at 12:14 PM Usama Arif <usamaarif642@xxxxxxxxx> wrote: >> >> __pa() is only intended to be used for linear map addresses and using >> it for initial_boot_params which is in fixmap for arm64 will give an >> incorrect value. Hence save the physical address when it is known at >> boot time when calling early_init_dt_scan for arm64 and use it at kexec >> time instead of converting the virtual address using __pa(). >> >> Reported-by: Breno Leitao <leitao@xxxxxxxxxx> >> Suggested-by: Mark Rutland <mark.rutland@xxxxxxx> >> Signed-off-by: Usama Arif <usamaarif642@xxxxxxxxx> >> Fixes: ac10be5cdbfa ("arm64: Use common of_kexec_alloc_and_setup_fdt()") > > This looks fine, but what is the symptom without this compared to > before the above change? The original code in the referenced commit > above didn't remove the reservation at all. Unless the current code > does something worse, this is new functionality more than a fix (for > stable). > > Rob After the series in [1] was merged, we always get a warning when kexecing a debug kernel, which was reported by Breno in [2]. The issue is using __pa for a fixmap address in arm64 as described in [2], which could result in removing a memory reservation for a completely unrelated area. That was introduced by the patch just before "arm64: Use common of_kexec_alloc_and_setup_fdt" [3], but arm64 switched to using the common kexec fdt function in that commit. This commit is trying to fix removing and corrupting any random memory reservation (and get rid of the warning) that was introduced by [1], not adding a new functionality. [1] https://lore.kernel.org/all/20210221174930.27324-7-nramas@xxxxxxxxxxxxxxxxxxx/ [2] https://lore.kernel.org/all/ZnFKEtqfqJkYflwL@xxxxxxxxx/ [3] https://lore.kernel.org/all/20210221174930.27324-6-nramas@xxxxxxxxxxxxxxxxxxx/ Thanks, Usama