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
F152993598: D16588.id46280.diff
Sat, Apr 18, 12:49 PM
Unknown Object (File)
Wed, Apr 15, 4:10 AM
Unknown Object (File)
Tue, Apr 14, 11:23 PM
Unknown Object (File)
Tue, Apr 14, 7:34 AM
Unknown Object (File)
Thu, Apr 9, 10:34 AM
Unknown Object (File)
Thu, Apr 9, 8:03 AM
Unknown Object (File)
Wed, Apr 8, 9:34 AM
Unknown Object (File)
Wed, Apr 8, 3:20 AM
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.