Page MenuHomeFreeBSD

Sanity check BIOS EDD CHS numbers before using them.
ClosedPublic

Authored by delphij on Aug 4 2018, 8:53 AM.
Tags
None
Referenced Files
F132482002: D16588.diff
Fri, Oct 17, 7:13 AM
Unknown Object (File)
Wed, Oct 15, 3:52 PM
Unknown Object (File)
Wed, Oct 15, 3:52 PM
Unknown Object (File)
Wed, Oct 15, 4:58 AM
Unknown Object (File)
Thu, Oct 9, 3:37 PM
Unknown Object (File)
Tue, Oct 7, 11:54 PM
Unknown Object (File)
Fri, Oct 3, 4:39 AM
Unknown Object (File)
Tue, Sep 30, 9:12 PM
Subscribers

Details

Reviewers
cy
tsoome
Summary

In r337271, we limited the sector number to the lower of calculated
number and CHS based number. However, on some systems, BIOS would
report 0 in CHS fields, making the system to think there is 0 sectors.

Add a check before comparing the calculated total with bd_sectors.

Test Plan

boot

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 18577
Build 18272: arc lint + arc unit

Event Timeline

This revision is now accepted and ready to land.Aug 4 2018, 11:12 AM

The above change allowed a kernel to load on my laptop[[ https://wiki.freebsd.org/Laptops/Dell_Precision_M4800?highlight=(\bCategoryLaptop\b)| Dell Precision M4800 ]] after updating from r337232 -> r337285; without the change, the kernel was unloadable ("Can't load kernel") and I didn't even get a loader menu (e.g., to facilitate loading a different kernel).

Referenced wrong review. This was committed as rS337317.