public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH] x86 efi: efi reverve boot service fix
@ 2013-10-16  7:03 Dave Young
  2013-10-16  7:11 ` Dave Young
  2013-10-16  8:35 ` [PATCH v2] " Dave Young
  0 siblings, 2 replies; 8+ messages in thread
From: Dave Young @ 2013-10-16  7:03 UTC (permalink / raw)
  To: matt, x86, linux-kernel, mjg59, hpa, James.Bottomley, vgoyal,
	linux-efi


Current code check boot service region with kernel text region by: 
start+size >= __pa_symbol(_text)
The end of the above region should be start + size - 1 instead.

I see this problem in ovmf + Fedora 19 grub boot:
text start: 1000000 md start: 800000 md size: 800000

Signed-off-by: Dave Young <dyoung@redhat.com>
---
 arch/x86/platform/efi/efi.c |    2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

--- linux-2.6.orig/arch/x86/platform/efi/efi.c
+++ linux-2.6/arch/x86/platform/efi/efi.c
@@ -440,7 +440,7 @@ void __init efi_reserve_boot_services(vo
 		 * - Not within any part of the kernel
 		 * - Not the bios reserved area
 		*/
-		if ((start+size >= __pa_symbol(_text)
+		if ((start + size - 1 >= __pa_symbol(_text)
 				&& start <= __pa_symbol(_end)) ||
 			!e820_all_mapped(start, start+size, E820_RAM) ||
 			memblock_is_region_reserved(start, size)) {

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] x86 efi: efi reverve boot service fix
  2013-10-16  7:03 [PATCH] x86 efi: efi reverve boot service fix Dave Young
@ 2013-10-16  7:11 ` Dave Young
  2013-10-16  7:29   ` H. Peter Anvin
  2013-10-16  8:07   ` Matt Fleming
  2013-10-16  8:35 ` [PATCH v2] " Dave Young
  1 sibling, 2 replies; 8+ messages in thread
From: Dave Young @ 2013-10-16  7:11 UTC (permalink / raw)
  To: matt, x86, linux-kernel, mjg59, hpa, James.Bottomley, vgoyal,
	linux-efi

typo, fix hpa's mail address..

On 10/16/13 at 03:03pm, Dave Young wrote:
> 
> Current code check boot service region with kernel text region by: 
> start+size >= __pa_symbol(_text)
> The end of the above region should be start + size - 1 instead.
> 
> I see this problem in ovmf + Fedora 19 grub boot:
> text start: 1000000 md start: 800000 md size: 800000
> 
> Signed-off-by: Dave Young <dyoung@redhat.com>
> ---
>  arch/x86/platform/efi/efi.c |    2 +-
>  1 file changed, 1 insertion(+), 1 deletion(-)
> 
> --- linux-2.6.orig/arch/x86/platform/efi/efi.c
> +++ linux-2.6/arch/x86/platform/efi/efi.c
> @@ -440,7 +440,7 @@ void __init efi_reserve_boot_services(vo
>  		 * - Not within any part of the kernel
>  		 * - Not the bios reserved area
>  		*/
> -		if ((start+size >= __pa_symbol(_text)
> +		if ((start + size - 1 >= __pa_symbol(_text)
>  				&& start <= __pa_symbol(_end)) ||
>  			!e820_all_mapped(start, start+size, E820_RAM) ||
>  			memblock_is_region_reserved(start, size)) {

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] x86 efi: efi reverve boot service fix
  2013-10-16  7:11 ` Dave Young
@ 2013-10-16  7:29   ` H. Peter Anvin
  2013-10-16  8:24     ` Dave Young
  2013-10-16  8:07   ` Matt Fleming
  1 sibling, 1 reply; 8+ messages in thread
From: H. Peter Anvin @ 2013-10-16  7:29 UTC (permalink / raw)
  To: Dave Young, matt, x86, linux-kernel, mjg59, James.Bottomley,
	vgoyal, linux-efi

On 10/16/2013 12:11 AM, Dave Young wrote:
>>
>> --- linux-2.6.orig/arch/x86/platform/efi/efi.c
>> +++ linux-2.6/arch/x86/platform/efi/efi.c
>> @@ -440,7 +440,7 @@ void __init efi_reserve_boot_services(vo
>>  		 * - Not within any part of the kernel
>>  		 * - Not the bios reserved area
>>  		*/
>> -		if ((start+size >= __pa_symbol(_text)
>> +		if ((start + size - 1 >= __pa_symbol(_text)
>>  				&& start <= __pa_symbol(_end)) ||
>>  			!e820_all_mapped(start, start+size, E820_RAM) ||
>>  			memblock_is_region_reserved(start, size)) {

It would be better to change >= to >.

	-hpa


^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] x86 efi: efi reverve boot service fix
  2013-10-16  7:11 ` Dave Young
  2013-10-16  7:29   ` H. Peter Anvin
@ 2013-10-16  8:07   ` Matt Fleming
  2013-10-16  8:28     ` Dave Young
  2013-10-16  8:36     ` Maarten Lankhorst
  1 sibling, 2 replies; 8+ messages in thread
From: Matt Fleming @ 2013-10-16  8:07 UTC (permalink / raw)
  To: Dave Young
  Cc: x86, linux-kernel, mjg59, hpa, James.Bottomley, vgoyal, linux-efi,
	Maarten Lankhorst

Also better include Maarten on Cc as the author of the code.

On Wed, 16 Oct, at 03:11:22PM, Dave Young wrote:
> typo, fix hpa's mail address..
> 
> On 10/16/13 at 03:03pm, Dave Young wrote:
> > 
> > Current code check boot service region with kernel text region by: 
> > start+size >= __pa_symbol(_text)
> > The end of the above region should be start + size - 1 instead.
> > 
> > I see this problem in ovmf + Fedora 19 grub boot:
> > text start: 1000000 md start: 800000 md size: 800000
> > 
> > Signed-off-by: Dave Young <dyoung@redhat.com>
> > ---
> >  arch/x86/platform/efi/efi.c |    2 +-
> >  1 file changed, 1 insertion(+), 1 deletion(-)
> > 
> > --- linux-2.6.orig/arch/x86/platform/efi/efi.c
> > +++ linux-2.6/arch/x86/platform/efi/efi.c
> > @@ -440,7 +440,7 @@ void __init efi_reserve_boot_services(vo
> >  		 * - Not within any part of the kernel
> >  		 * - Not the bios reserved area
> >  		*/
> > -		if ((start+size >= __pa_symbol(_text)
> > +		if ((start + size - 1 >= __pa_symbol(_text)
> >  				&& start <= __pa_symbol(_end)) ||
> >  			!e820_all_mapped(start, start+size, E820_RAM) ||
> >  			memblock_is_region_reserved(start, size)) {

-- 
Matt Fleming, Intel Open Source Technology Center

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] x86 efi: efi reverve boot service fix
  2013-10-16  7:29   ` H. Peter Anvin
@ 2013-10-16  8:24     ` Dave Young
  0 siblings, 0 replies; 8+ messages in thread
From: Dave Young @ 2013-10-16  8:24 UTC (permalink / raw)
  To: H. Peter Anvin
  Cc: matt, x86, linux-kernel, mjg59, James.Bottomley, vgoyal,
	linux-efi

On 10/16/13 at 12:29am, H. Peter Anvin wrote:
> On 10/16/2013 12:11 AM, Dave Young wrote:
> >>
> >> --- linux-2.6.orig/arch/x86/platform/efi/efi.c
> >> +++ linux-2.6/arch/x86/platform/efi/efi.c
> >> @@ -440,7 +440,7 @@ void __init efi_reserve_boot_services(vo
> >>  		 * - Not within any part of the kernel
> >>  		 * - Not the bios reserved area
> >>  		*/
> >> -		if ((start+size >= __pa_symbol(_text)
> >> +		if ((start + size - 1 >= __pa_symbol(_text)
> >>  				&& start <= __pa_symbol(_end)) ||
> >>  			!e820_all_mapped(start, start+size, E820_RAM) ||
> >>  			memblock_is_region_reserved(start, size)) {
> 
> It would be better to change >= to >.

Both are fine to me, will resend with '>'

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] x86 efi: efi reverve boot service fix
  2013-10-16  8:07   ` Matt Fleming
@ 2013-10-16  8:28     ` Dave Young
  2013-10-16  8:36     ` Maarten Lankhorst
  1 sibling, 0 replies; 8+ messages in thread
From: Dave Young @ 2013-10-16  8:28 UTC (permalink / raw)
  To: Matt Fleming
  Cc: x86, linux-kernel, mjg59, hpa, James.Bottomley, vgoyal, linux-efi,
	Maarten Lankhorst

On 10/16/13 at 09:07am, Matt Fleming wrote:
> Also better include Maarten on Cc as the author of the code.

Will do in next version

^ permalink raw reply	[flat|nested] 8+ messages in thread

* [PATCH v2] x86 efi: efi reverve boot service fix
  2013-10-16  7:03 [PATCH] x86 efi: efi reverve boot service fix Dave Young
  2013-10-16  7:11 ` Dave Young
@ 2013-10-16  8:35 ` Dave Young
  1 sibling, 0 replies; 8+ messages in thread
From: Dave Young @ 2013-10-16  8:35 UTC (permalink / raw)
  To: matt, x86, linux-kernel, mjg59, hpa, maarten.lankhorst,
	James.Bottomley, vgoyal, linux-efi, pjones

Current code check boot service region with kernel text region by: 
start+size >= __pa_symbol(_text)
The end of the above region should be start + size - 1 instead.

I see this problem in ovmf + Fedora 19 grub boot:
text start: 1000000 md start: 800000 md size: 800000

Signed-off-by: Dave Young <dyoung@redhat.com>
---
v2: use > instead of >= per hpa

 arch/x86/platform/efi/efi.c |    2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

--- linux-2.6.orig/arch/x86/platform/efi/efi.c
+++ linux-2.6/arch/x86/platform/efi/efi.c
@@ -440,7 +440,7 @@ void __init efi_reserve_boot_services(vo
 		 * - Not within any part of the kernel
 		 * - Not the bios reserved area
 		*/
-		if ((start+size >= __pa_symbol(_text)
+		if ((start + size > __pa_symbol(_text)
 				&& start <= __pa_symbol(_end)) ||
 			!e820_all_mapped(start, start+size, E820_RAM) ||
 			memblock_is_region_reserved(start, size)) {

^ permalink raw reply	[flat|nested] 8+ messages in thread

* Re: [PATCH] x86 efi: efi reverve boot service fix
  2013-10-16  8:07   ` Matt Fleming
  2013-10-16  8:28     ` Dave Young
@ 2013-10-16  8:36     ` Maarten Lankhorst
  1 sibling, 0 replies; 8+ messages in thread
From: Maarten Lankhorst @ 2013-10-16  8:36 UTC (permalink / raw)
  To: Matt Fleming, Dave Young
  Cc: x86, linux-kernel, mjg59, hpa, James.Bottomley, vgoyal, linux-efi

op 16-10-13 10:07, Matt Fleming schreef:
> Also better include Maarten on Cc as the author of the code.
>
> On Wed, 16 Oct, at 03:11:22PM, Dave Young wrote:
>> typo, fix hpa's mail address..
>>
>> On 10/16/13 at 03:03pm, Dave Young wrote:
>>> Current code check boot service region with kernel text region by: 
>>> start+size >= __pa_symbol(_text)
>>> The end of the above region should be start + size - 1 instead.

Acked-by: Maarten Lankhorst <maarten.lankhorst@canonical.com>

>>> I see this problem in ovmf + Fedora 19 grub boot:
>>> text start: 1000000 md start: 800000 md size: 800000
>>>
>>> Signed-off-by: Dave Young <dyoung@redhat.com>
>>> ---
>>>  arch/x86/platform/efi/efi.c |    2 +-
>>>  1 file changed, 1 insertion(+), 1 deletion(-)
>>>
>>> --- linux-2.6.orig/arch/x86/platform/efi/efi.c
>>> +++ linux-2.6/arch/x86/platform/efi/efi.c
>>> @@ -440,7 +440,7 @@ void __init efi_reserve_boot_services(vo
>>>  		 * - Not within any part of the kernel
>>>  		 * - Not the bios reserved area
>>>  		*/
>>> -		if ((start+size >= __pa_symbol(_text)
>>> +		if ((start + size - 1 >= __pa_symbol(_text)
>>>  				&& start <= __pa_symbol(_end)) ||
>>>  			!e820_all_mapped(start, start+size, E820_RAM) ||
>>>  			memblock_is_region_reserved(start, size)) {


^ permalink raw reply	[flat|nested] 8+ messages in thread

end of thread, other threads:[~2013-10-16  8:36 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-10-16  7:03 [PATCH] x86 efi: efi reverve boot service fix Dave Young
2013-10-16  7:11 ` Dave Young
2013-10-16  7:29   ` H. Peter Anvin
2013-10-16  8:24     ` Dave Young
2013-10-16  8:07   ` Matt Fleming
2013-10-16  8:28     ` Dave Young
2013-10-16  8:36     ` Maarten Lankhorst
2013-10-16  8:35 ` [PATCH v2] " Dave Young

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox