public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* RE: [PATCH] Ghost EDD devices in /sys again
@ 2008-09-06 22:08 H. Peter Anvin
  2008-09-28  6:34 ` Andrey Borzenkov
  0 siblings, 1 reply; 8+ messages in thread
From: H. Peter Anvin @ 2008-09-06 22:08 UTC (permalink / raw)
  To: Andrey Borzenkov
  Cc: Andrew Morton, Rafael J. Wysocki, Linux Kernel Mailing List,
	Ingo Molnar

I think this is closer to what we really want; after all, memory being written is the "first principles" test that applies here.

-- 
Sent from my mobile phone (pardon any lack of formatting)


-----Original Message-----
From: Andrey Borzenkov <arvidjaar@newmail.ru>
Sent: Saturday, September 06, 2008 10:46
To: H. Peter Anvin <hpa@zytor.com>
Cc: Andrew Morton <akpm@linux-foundation.org>; Rafael J. Wysocki <rjw@sisk.pl>; Linux Kernel Mailing List <linux-kernel@vger.kernel.org>; Ingo Molnar <mingo@elte.hu>
Subject: Re: [PATCH] Ghost EDD devices in /sys again

On Saturday 06 September 2008, H. Peter Anvin wrote:
> 
> Andrey Borzenkov wrote:
> > 
> > Was it really that simple?
> > 
> > Subject: [PATCH] Fix ghost devices under /sys/firmware/edd
> > From: Andrey Borzenkov <arvidjaar@mail.ru>
> > 
> > Some BIOSes do not always set CF on error before return from int13.
> > The patch adds additional check for status being zero (AH == 0).
> > 
> 
> Do you have any evidence that there aren't any BIOSes which leave AH != 
> 0 on legitimate success?  If so, you have turned a nuisance bug into 
> something that could cause install failures.
> 

Hmm ... if install depends on having valid MBR, it will break right
now as well, because it will have duplicated signatures. So at least
something like following is needed.

diff --git a/arch/x86/boot/edd.c b/arch/x86/boot/edd.c
index d93cbc6..4c20d31 100644
--- a/arch/x86/boot/edd.c
+++ b/arch/x86/boot/edd.c
@@ -58,6 +58,7 @@ static u32 read_mbr_sig(u8 devno, struct edd_info *ei, u32 *mbrsig)
        if (mbrbuf_end > (char *)(size_t)boot_params.hdr.heap_end_ptr)
                return -1;

+       memset(mbrbuf_ptr, 0, sector_size);
        if (read_mbr(devno, mbrbuf_ptr))
                return -1;



^ permalink raw reply related	[flat|nested] 8+ messages in thread
* Ghost EDD devices in /sys again
@ 2008-09-05 18:19 Andrey Borzenkov
  2008-09-06  8:40 ` [PATCH] " Andrey Borzenkov
  0 siblings, 1 reply; 8+ messages in thread
From: Andrey Borzenkov @ 2008-09-05 18:19 UTC (permalink / raw)
  To: hpa, Andrew Morton; +Cc: Rafael J. Wysocki, Linux Kernel Mailing List

[-- Attachment #1: Type: text/plain, Size: 795 bytes --]

This is regression but old enough. Apparently I had for whatever reasons
EDD turned off till recently. This is 2.6.27-rc5 just in case.

In 2006 I fixed ghost devices due to buggy BIOS:

http://marc.info/?l=linux-kernel&m=114087765422490&w=2

Later edd.S has been rewritten in C, and apparently this patch has been
lost:

{pts/1}% ls /sys/firmware/edd
int13_dev80/  int13_dev84/  int13_dev88/  int13_dev8c/
int13_dev81/  int13_dev85/  int13_dev89/  int13_dev8d/
int13_dev82/  int13_dev86/  int13_dev8a/  int13_dev8e/
int13_dev83/  int13_dev87/  int13_dev8b/  int13_dev8f/

But I have just a single disk. This is the same system BTW.

Unfortunately I do not speak asm language of C; if somebody could provide
equivalent fix for current edd.c, I am more than ready to test it.

Thank you

-andrey

[-- Attachment #2: This is a digitally signed message part. --]
[-- Type: application/pgp-signature, Size: 197 bytes --]

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

end of thread, other threads:[~2008-09-28 15:14 UTC | newest]

Thread overview: 8+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-09-06 22:08 [PATCH] Ghost EDD devices in /sys again H. Peter Anvin
2008-09-28  6:34 ` Andrey Borzenkov
2008-09-28 15:12   ` H. Peter Anvin
  -- strict thread matches above, loose matches on Subject: below --
2008-09-05 18:19 Andrey Borzenkov
2008-09-06  8:40 ` [PATCH] " Andrey Borzenkov
2008-09-06 12:07   ` Ingo Molnar
2008-09-06 14:34     ` Ingo Molnar
2008-09-06 14:04   ` H. Peter Anvin
2008-09-06 17:46     ` Andrey Borzenkov

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