From: Wei Yang <richard.weiyang@gmail.com>
To: Ingo Molnar <mingo@kernel.org>
Cc: Wei Yang <richard.weiyang@gmail.com>,
tglx@linutronix.de, mingo@redhat.com, hpa@zytor.com,
x86@kernel.org, linux-kernel@vger.kernel.org
Subject: Re: [Resend PATCH] x86/e820: break the loop when the region is less then current region
Date: Sat, 28 Jan 2017 02:09:03 +0800 [thread overview]
Message-ID: <20170127180903.GA48696@WeideMacBook-Pro.local> (raw)
In-Reply-To: <20170127084723.GD25162@gmail.com>
[-- Attachment #1: Type: text/plain, Size: 2531 bytes --]
Hi, Ingo
Glad to see your comments.
On Fri, Jan 27, 2017 at 09:47:23AM +0100, Ingo Molnar wrote:
>
>* Wei Yang <richard.weiyang@gmail.com> wrote:
>
>> e820_all_mapped() iterates the e820 table to check whether a region is
>> mapped or not. Since the e820 table is sorted, when the region is less than
>> the current region, no need to continue the iteration.
>>
>> The patch breaks the loop accordingly.
>>
>> Signed-off-by: Wei Yang <richard.weiyang@gmail.com>
>> ---
>> arch/x86/kernel/e820.c | 8 +++++++-
>> 1 file changed, 7 insertions(+), 1 deletion(-)
>>
>> diff --git a/arch/x86/kernel/e820.c b/arch/x86/kernel/e820.c
>> index 90e8dde..f4fb197 100644
>> --- a/arch/x86/kernel/e820.c
>> +++ b/arch/x86/kernel/e820.c
>> @@ -86,10 +86,16 @@ int __init e820_all_mapped(u64 start, u64 end, unsigned type)
>> for (i = 0; i < e820->nr_map; i++) {
>> struct e820entry *ei = &e820->map[i];
>>
>> + /* Since the e820 table is sorted, when the region is less
>> + * than the current region, break it.
>> + */
>> + if (ei->addr >= end)
>> + break;
>
>Please have a look at the relevant sections in Documentation/CodingStyle. (And
>yes, this file violates it in a number of ways, but that's no reason to add to the
>mess.)
>
I took a look in the Documentation/CodingStyle, looks the comment style is not
the preferred one. While I have checked this by scripts/checkpatch.pl, which
prompts 0 error and 0 warning, so I thought it is fine.
I would change this if you like.
>But, more importantly, the reason I have not applied the patch before is that
>while it's true that the e820 map is _eventually_ sorted, have you made certain
>that all calls to e820_all_mapped() are done when the map is already sorted?
>
I think so, if not those caller really need to make sure not to do this at
that moment.
The e820_all_mapped() can't work well if it is not sorted, even without this
change.
For example, we have two ranges [0x1000, 0x1FFF] and [0x2000, 0x2FFF] but they
are not sorted in e820. Then a range [0x1500, 0x2500] would be judge not all
mapped, which actually is in range [0x1000, 0x2FFF].
BTW, I went through all the callers, and most of them are called from
subsys_init() or arch_initcall() which is after setup_memory_map() called in
setup_arch().
And two of them are called by e820_add_kernel_range() and
efi_reserve_boot_services(), and both are after setup_memory_map().
>Thanks,
>
> Ingo
--
Wei Yang
Help you, Help me
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 819 bytes --]
prev parent reply other threads:[~2017-01-27 18:09 UTC|newest]
Thread overview: 3+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-01-27 2:47 [Resend PATCH] x86/e820: break the loop when the region is less then current region Wei Yang
2017-01-27 8:47 ` Ingo Molnar
2017-01-27 18:09 ` Wei Yang [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20170127180903.GA48696@WeideMacBook-Pro.local \
--to=richard.weiyang@gmail.com \
--cc=hpa@zytor.com \
--cc=linux-kernel@vger.kernel.org \
--cc=mingo@kernel.org \
--cc=mingo@redhat.com \
--cc=tglx@linutronix.de \
--cc=x86@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.