stand/fdt: don't send clobbered FDT to the kernel
ClosedPublic

Authored by kevans on Sun, Dec 31, 6:27 AM.

Details

Summary

If fdt_overlay_apply fails at some stage to apply the overlay to the base, both the base and overlay may be in an inconsistent state (some fixups applied, some phandles adjusted, some symbols merged). These can be bad for a number of reasons, to include user frustration if some fixups applied and not others. Fail a life safer by making a clean copy of the base FDT for every overlay that we can simply discard if things go awry.

This also allows us the luxury of simply discarding overlays if we hit some kind of memory limit or if they're malformed and extremely large for some reason. We'll now leave a nice error message indicating that some overlays could not be applied due to size restrictions and we apply what we can.

I note that our overlay implementation has some flaws that might still leave your system in an unbootable state even if an overlay applies correctly; please exercise caution in using overlays until we can swap it out for libfdt's implementation.

Diff Detail

Repository
rS FreeBSD src repository
Lint
Automatic diff as part of commit; lint not applicable.
Unit
Automatic diff as part of commit; unit tests not applicable.
kevans created this revision.Sun, Dec 31, 6:27 AM
kevans updated this revision to Diff 37410.Tue, Jan 2, 3:24 PM

Tested on a clean -HEAD now; corrected an inverted check (== 0 vs. != 0)

kevans edited the summary of this revision. (Show Details)Tue, Jan 2, 3:28 PM
This revision was not accepted when it landed; it landed in state Needs Review.Mon, Jan 15, 5:00 AM
Closed by commit rS327991: stand/fdt: don't send clobbered FDT to the kernel (authored by kevans, committed by ). · Explain Why
This revision was automatically updated to reflect the committed changes.