Re: [PATCH] x86/acpi: check rsdp address received via bootparams to be valid

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



* Juergen Gross <jgross@xxxxxxxx> wrote:

> On 16/01/18 17:35, Ingo Molnar wrote:
> > 
> > * Juergen Gross <jgross@xxxxxxxx> wrote:
> > 
> >> On 16/01/18 16:46, Ingo Molnar wrote:
> >>>
> >>> * Juergen Gross <jgross@xxxxxxxx> wrote:
> >>>
> >>>> There seem to exist several grub2 versions trashing
> >>>> boot_params.hdr.acpi_rsdp_addr.
> >>>>
> >>>> So don't just believe this address to be valid, but verify it pointing
> >>>> to a valid RSDP table.
> >>>
> >>> Exactly what kind of values do those Grub2 versions put into that field? Pointer 
> >>> to something, or random noise?
> >>
> >> Looks like random noise. On Mike's system it was 0x000000000151.
> >>
> >>> Also, what exactly does 'validation' mean, how robustly does it filter out of spec 
> >>> uses of the boot protocol?
> >>
> >> It validates the RSDP has the correct 8 byte eye catcher in it and
> >> the checksum of the structure is correct. Searching the RSDP by
> >> scanning memory is using the same checks, so I guess this ought to
> >> be okay. Odds are about 1 : 2^80 for false positives.
> > 
> > Ok, this should work - but only because the RSDP is defined in such a robust 
> > fashion.
> > 
> > The boot protocol extension is still fragile: what I worry about is that if we 
> > start relying on the extended boot protocol with widespread installed base of out 
> > of spec Grub2 loaders, other extensions (which cannot be sanity checked) would be 
> > less robust.
> > 
> > Is there a way to detect the broken Grub2 versions somehow and just limit the boot 
> > protocol for them?
> > 
> > The other solution would be to just discontinue this boot protocol extension and 
> > define a new one.
> 
> I think the best way to do it would be to let grub2 report the version
> of the protocol it is honoring. This reported version should not be
> higher than that of the kernel. The kernel would then know which fields
> of setup_header are known by grub2 and thus can be trusted to be
> correct.
> 
> I can modify my patch series to add the grub2 version information before
> the new rsdp_address field so this band-aid patch won't be required.
> 
> What do you think?

Such an approach would be a lot more future proof I think - except that I don't 
think the ABI should be 'version' based but 'size' based, like 
sys_sched_getattr().

The idea is that we introduce a 'size' field in the existing boot params, which 
would be zero for old bootloaders. (Is such a free field available?)

The boot loader puts the boot parameter structure size it currently supports, and 
the kernel reads it and acts accordingly.

This is flexible in a both forwards and backwards ABI-compatible manner, i.e. old 
kernel could run with new boot loader and old bootloader could run with new 
kernel, while having the maximum common set of boot protocol features supported.

If such an interface would be possible to create, that is.

Thanks,

	Ingo
--
To unsubscribe from this list: send the line "unsubscribe linux-acpi" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html



[Index of Archives]     [Linux IBM ACPI]     [Linux Power Management]     [Linux Kernel]     [Linux Laptop]     [Kernel Newbies]     [Share Photos]     [Security]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Samba]     [Video 4 Linux]     [Device Mapper]     [Linux Resources]

  Powered by Linux