summaryrefslogtreecommitdiffstats
path: root/Documentation/driver-api
diff options
context:
space:
mode:
authorRussell King <rmk+kernel@armlinux.org.uk>2017-07-20 00:09:58 +0200
committerRussell King <rmk+kernel@armlinux.org.uk>2017-07-20 12:37:42 +0200
commit0d70262a2d60886da6fe5b1fc8bbcd76cbbc306d (patch)
treea5ba2a9cc7793d3cc4f14338ea37611356712f38 /Documentation/driver-api
parentARM: kexec: avoid allocating crashkernel region outside lowmem (diff)
downloadlinux-0d70262a2d60886da6fe5b1fc8bbcd76cbbc306d.tar.xz
linux-0d70262a2d60886da6fe5b1fc8bbcd76cbbc306d.zip
ARM: kexec: fix failure to boot crash kernel
When kexec was converted to DTB, the dtb address was passed between machine_kexec_prepare() and machine_kexec() using a static variable. This is bad news if you load a crash kernel followed by a normal kernel or vice versa - the last loaded kernel overwrites the dtb address. This can result in kexec failures, as (eg) we try to boot the crash kernel with the last loaded dtb. For example, with: the crash kernel fails to find the dtb. Avoid this by defining a kimage architecture structure, and store the address to be passed in r2 there, which will either be the ATAGs or the dtb blob. Fixes: 4cabd1d9625c ("ARM: 7539/1: kexec: scan for dtb magic in segments") Fixes: 42d720d1731a ("ARM: kexec: Make .text R/W in machine_kexec") Reported-by: Keerthy <j-keerthy@ti.com> Tested-by: Keerthy <j-keerthy@ti.com> Signed-off-by: Russell King <rmk+kernel@armlinux.org.uk>
Diffstat (limited to 'Documentation/driver-api')
0 files changed, 0 insertions, 0 deletions