[PATCH] arm64:kexec: Memstart should not be before the kernel start address
Goel, Sameer
sgoel at codeaurora.org
Tue May 3 08:12:06 PDT 2016
No, this is not. It was just a minor change to the commit message to
clarify the change a bit. Appreciate your picking up the patch.
Regards,
Sameer
On 4/26/2016 5:58 PM, Geoff Levand wrote:
> Hi,
>
> I already added a patch like this to my series. Is this different?
>
> -Geoff
>
> On Tue, 2016-04-26 at 16:14 -0600, Sameer Goel wrote:
>> Starting 4.6-rc4 the kernel memblock start is rounded down to a desirable
>> alignment. So, the kernel can see reserved memory regions before the kernel
>> start address in the iomem query.
>> Need to make sure that the right kernel start address is picked from the iomem
>> query.
>> ---
>> kexec/arch/arm64/kexec-arm64.c | 12 ++++++++++--
>> 1 file changed, 10 insertions(+), 2 deletions(-)
>>
>> diff --git a/kexec/arch/arm64/kexec-arm64.c b/kexec/arch/arm64/kexec-arm64.c
>> index 776596a..5e39f4f 100644
>> --- a/kexec/arch/arm64/kexec-arm64.c
>> +++ b/kexec/arch/arm64/kexec-arm64.c
>> @@ -30,6 +30,12 @@
>> #include "kexec-syscall.h"
>> #include "arch/options.h"
>>
>> +#define SZ_2M 0x200000
>> +
>> +#define __round_mask(x, y) ((__typeof__(x))((y)-1))
>> +#define round_up(x, y) ((((x)-1) | __round_mask(x, y))+1)
>> +#define round_down(x, y) ((x) & ~__round_mask(x, y))
>> +
>> /* Global varables the core kexec routines expect. */
>>
>> unsigned char reuse_initrd;
>> @@ -944,6 +950,10 @@ static int get_memory_ranges_iomem(struct memory_range *array,
>> > > > str = line + consumed;
>> > > > r.end++;
>>
>> +> > > if (memcmp(str, "Kernel code\n", 12)==0) {
>> +> > > > set_memstart(round_down(r.start,SZ_2M));
>> +> > > }
>> +
>> > > > if (memcmp(str, "System RAM\n", 11)) {
>> > > > > dbgprintf("%s:%d: SKIP: %016Lx - %016Lx : %s", __func__,
>> > > > > > __LINE__, r.start, r.end, str);
>> @@ -956,8 +966,6 @@ static int get_memory_ranges_iomem(struct memory_range *array,
>> > > > > __LINE__, r.start, r.end, str);
>>
>> > > > array[(*count)++] = r;
>> -
>> -> > > set_memstart(r.start);
>> > > }
>>
>> > > fclose(fp);
>
> _______________________________________________
> kexec mailing list
> kexec at lists.infradead.org
> http://lists.infradead.org/mailman/listinfo/kexec
>
--
Qualcomm Innovation Center, Inc.
The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum,
a Linux Foundation Collaborative Project.
More information about the kexec
mailing list