Page MenuHomeFreeBSD

Support multiple OPAL consoles, and don't crash if uart is not stdout
ClosedPublic

Authored by jhibbits on Jun 29 2018, 7:15 PM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Nov 10, 4:56 AM
Unknown Object (File)
Sun, Nov 9, 10:36 PM
Unknown Object (File)
Sun, Nov 9, 10:27 PM
Unknown Object (File)
Sun, Nov 9, 10:27 PM
Unknown Object (File)
Sun, Nov 9, 10:26 PM
Unknown Object (File)
Sat, Nov 8, 9:16 AM
Unknown Object (File)
Fri, Nov 7, 10:41 AM
Unknown Object (File)
Tue, Oct 28, 9:23 AM
Subscribers

Details

Summary

If the chosen console is not the OPAL uart, but OPAL uart devices exist, the console device doesn't attach properly, and faults in the interrupt handler, with a NULL pointer dereference. To fix this, and as a byproduct, also support multiple OPAL consoles, refactor to have the console getc callback use the appropriate softc instead of the global console_sc, which may be NULL in the case of a different device being the console.

Diff Detail

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

Event Timeline

Assuming you have tested this and it works, looks great.

This revision is now accepted and ready to land.Jun 29 2018, 7:18 PM
This revision was automatically updated to reflect the committed changes.