Page MenuHomeFreeBSD

loader: Fully reset terminal settings, not just colors
ClosedPublic

Authored by freqlabs on Sep 20 2019, 7:42 PM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Jan 7, 9:55 PM
Unknown Object (File)
Fri, Jan 3, 3:51 AM
Unknown Object (File)
Dec 17 2024, 9:26 AM
Unknown Object (File)
Dec 2 2024, 9:26 AM
Unknown Object (File)
Nov 24 2024, 11:48 PM
Unknown Object (File)
Nov 14 2024, 8:22 PM
Unknown Object (File)
Nov 13 2024, 7:57 AM
Unknown Object (File)
Oct 31 2024, 7:01 AM
Subscribers

Details

Summary

Early boot firmware or other software may leave serial terminals in an unspecified, potentially broken state at boot. This can include problems such as unfavorable color settings or fixed scrolling regions which make the loader menu and later kernel messages unreadable.

We currently reset terminal color settings using an ANSI escape sequence when loader colors are enabled. Instead, we should use the \ec escape sequence to reset all of the terminal settings. This should fix a broader range of console visibility issues.

Sponsored by: iXsystems, Inc.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

Another OK from lua side

This revision is now accepted and ready to land.Sep 20 2019, 7:48 PM

Hmm... on second thought, this might need tested with a black-on-white xterm. I seem to recall having to spit out color.default() because we couldn't cope with the different background color and kept screwing up @emaste's xterm. I'm assuming this will put us back into that state, and we'll need to have the color.default() back after the reset.

Hmm... on second thought, this might need tested with a black-on-white xterm. I seem to recall having to spit out color.default() because we couldn't cope with the different background color and kept screwing up @emaste's xterm. I'm assuming this will put us back into that state, and we'll need to have the color.default() back after the reset.

the terminal reset means you will get the terminal defaults - if the xterm was set to black on white, it will have black on white after reset. Now the loader teken is built white on black and we have no toggle to set teken defaults (yet) - so if you did set fg/bg colors for local console, then after terminal reset you will get white on black.

Sorry, I do need to take a second look at this one. My terminal doesn't seem to be resetting the font brightness correctly when loader_color=YES in a bhyve VM looking at the serial console. Everything looks bolded until I reset the terminal again in the shell using `printf '\033c' and then it goes back to normal.

I moved the UEFI console resize to before the screen reset in loader.lua to be consistent with the order of this sequence in the forth loader.rc version. In doing so I noticed a few if blocks for the menu could be combined, so I combined them.

The odd brightness issue I had noticed earlier was fixed by @tsoome over the weekend in rS352601, thanks!

stand/lua/loader.lua
58 ↗(On Diff #62482)

I'd consider going a step further and eliminating the single-use 'menu' local and instead just invoking require("menu").run(). I really don't recall why I split this up... trolling through the history doesn't explain much.

Eliminate menu local per review.

I was a bit slow taking the screenshot and caught the menu mid-scroll but here it is in a black on white terminal:

Screen Shot 2019-09-24 at 3.58.16 PM.png (914×1 px, 427 KB)

I must ask for someone with a commit bit to put this one in for me as well, if there are no further concerns. Thanks in advance!

Do we need this now that tsoome has committed all his stuff to fix the broken color stuff that lead to this situation in the first place?

This aims to reset more of the state to defaults, not just colors. Things like the scroll region for example, so we don't have all the output stuck on one line. There are a multitude of software/firmware/hardware issues that can cause the state to be unfavorable at boot. Loose serial connections, buggy firmware, etc. tsoome's work complements this change rather than invalidating it.

Does this work for EFI console? When I tried it, the terminal emualtor intercepted the escape sequences and so the serial console didn't get them...

I had very similar code in FORTH for our boot loader and it didn't work with EFI, just comconsole. while we've transitioned to teken, it looks like it eats the ESC c and does a reset for the eficonsole, which means that efi's com redirect in the BIOS doesn't work.

stand/forth/screen.4th
43 ↗(On Diff #62484)

The reset sequence is ESC c, not ESC [ c.
https://en.wikipedia.org/wiki/ANSI_escape_code

stand/lua/loader.lua
50 ↗(On Diff #62484)

Why only reset of if color is enabled if the goal is to also reset scrolling regions?

while we've transitioned to teken, it looks like it eats the ESC c

Ok, that looks pretty tough to deal with. Now that you mention it, I'm not seeing colors on the EFI serial console either, and under bhyve the scroll region is broken after the loader hands off to the kernel as well. It's everything I wanted to fix, still broken! Ugh! I thought I had tested that, but I guess I only tested a video output with the EFI console.

One way of dealing with this could be to add a variable to bypass teken for users of serial EFI consoles. A more challenging but perhaps more flexible option would be to implement a driver for the EFI serial protocol and either expose it as something like "efiserial" console or maybe add special handling to the existing EFI console driver to duplicate ANSI sequences to the serial port.

I don't think solving that problem with the EFI console/teken is within the scope of this change, though I am certainly hoping it gets fixed. I've only learned of teken's existence a few days ago. Can someone more familiar with that piece provide their input on the issue?

stand/forth/screen.4th
43 ↗(On Diff #62484)

Oops, I will change this to

: ris ( -- ) 27 emit [char] c emit ;
stand/lua/loader.lua
50 ↗(On Diff #62484)

To not bother people who don't want to see ANSI escape sequences. Making the set of loader options even more complicated seemed less user friendly.

In D21733#475782, @ryan_freqlabs.com wrote:

while we've transitioned to teken, it looks like it eats the ESC c

Ok, that looks pretty tough to deal with. Now that you mention it, I'm not seeing colors on the EFI serial console either, and under bhyve the scroll region is broken after the loader hands off to the kernel as well. It's everything I wanted to fix, still broken! Ugh! I thought I had tested that, but I guess I only tested a video output with the EFI console.

It is the most maddening part to get right... It's why I never upstreamed my hacks that I knew didn't work.

One way of dealing with this could be to add a variable to bypass teken for users of serial EFI consoles. A more challenging but perhaps more flexible option would be to implement a driver for the EFI serial protocol and either expose it as something like "efiserial" console or maybe add special handling to the existing EFI console driver to duplicate ANSI sequences to the serial port.

I actually think that's quite hard and involved. The current code doesn't differentiate, unfortunately. It would take a little while to understand a good path forward. At the moment, I see parsing ConOut, looking up handles and using that in something complicated, but there may be something simpler...

I don't think solving that problem with the EFI console/teken is within the scope of this change, though I am certainly hoping it gets fixed. I've only learned of teken's existence a few days ago. Can someone more familiar with that piece provide their input on the issue?

This can really only work for comconsole. And even there it can only be imperfect. And people will complain and expect me to fix it, so I'm reluctant to sign off until we have a better notion of a path forward...

In D21733#475785, @imp wrote:
In D21733#475782, @ryan_freqlabs.com wrote:

while we've transitioned to teken, it looks like it eats the ESC c

Ok, that looks pretty tough to deal with. Now that you mention it, I'm not seeing colors on the EFI serial console either, and under bhyve the scroll region is broken after the loader hands off to the kernel as well. It's everything I wanted to fix, still broken! Ugh! I thought I had tested that, but I guess I only tested a video output with the EFI console.

It is the most maddening part to get right... It's why I never upstreamed my hacks that I knew didn't work.

One way of dealing with this could be to add a variable to bypass teken for users of serial EFI consoles. A more challenging but perhaps more flexible option would be to implement a driver for the EFI serial protocol and either expose it as something like "efiserial" console or maybe add special handling to the existing EFI console driver to duplicate ANSI sequences to the serial port.

I actually think that's quite hard and involved. The current code doesn't differentiate, unfortunately. It would take a little while to understand a good path forward. At the moment, I see parsing ConOut, looking up handles and using that in something complicated, but there may be something simpler...

I don't think solving that problem with the EFI console/teken is within the scope of this change, though I am certainly hoping it gets fixed. I've only learned of teken's existence a few days ago. Can someone more familiar with that piece provide their input on the issue?

This can really only work for comconsole. And even there it can only be imperfect. And people will complain and expect me to fix it, so I'm reluctant to sign off until we have a better notion of a path forward...

I am investigating this already, I have couple of ideas, but most certainly there are many traps.

Use the correct escape sequence for reset in forth.

@tsoome is efi console / teken in shape for this now?

This revision is now accepted and ready to land.Mar 26 2020, 8:29 PM