-
-
Notifications
You must be signed in to change notification settings - Fork 45
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
System messages are printed over tuigreet #68
Comments
You should generalise this: All of grub bleeds into tuigreet, for me a few of the bottom grub lines cover parts of tuigreet. |
There's a chance this is not an issue for tuigreet, since it's logger daemons that are writing stuff to console. Users probably need to configure their I would be nice though to have a paragraph in tuigreet docs explaining this. |
I am facing this overflow issue since I removed the quiet option from grub. I really value seeing a log, so I won't disable that. I hope it can be fixed somehow. |
I think I found a way to fix this. Do
in your greetd (not tuigreet) config. I can't reproduce the issue since I did this (but I don't have a reliable way of reproducing it, so I don't know how much that's worth). I suspect that tty1 is the only one getting those error messages printed to it. So putting greetd on another tty might solve the problem. Ivan |
Personally, I am afraid that this change in Greetd's configuration does not really solve the problem. My [terminal]
vt = "next"
[default_session]
command = "tuigreet --remember --time --issue --asterisks --cmd sway"
user = "greeter" while this is what Tuigreet looks like when I boot without the kernel quiet parameter: |
You're right. I just saw some error messages with |
I feel you, and I have the same issue from time to time. Unfortunately, I have no idea if and how this could be solved, the same issue happens to me with any console program I invoke. Short of rewriting the whole screen, including whitespace, at every frame, I don't see a solution. If anyone has an idea within the scope of |
It might be worth looking at ly. They are kinda doing the same thing as tuigreet but different, and they don't have the problem described here. I have no experience in using C, but you might be able to find what updates their screen. My best guess currently is the very bottom of the file |
I followed a suggestion given on Arch forums and the log messages on tuigreet seem to be gone. Basically, redirect all the logs to a different TTY than the one you are using to boot tuigreet. EDIT: after a reboot, the issue was still there with this method. |
Lucas,
Do the journald messages still go away when you remove `quiet` kernel
commandline argument? (I.e. remove it from /etc/default/grub, do
grub-mkconfig and reboot.)
For me, the above still produces the messages over tuigreet
interface. Although with `quiet` set I don't see anything (maybe I
haven't testing it enough).
Ivan
|
Finally, after reading lots of threads and trying out different possible solutions, I found out that SystemD stops printing its status messages (like it was started with the quiet parameter) upon receiving So I created a file named [Service]
ExecStartPre=kill -SIGRTMIN+21 1
ExecStopPost=kill -SIGRTMIN+20 1 Thanks to this modification, SystemD stops printing its log before launching greetd (and tuigreet along with it) restarting it only after the login screen is closed. I'm not entirely sure that this solution can stop error messages too from being printed over tuigreet, but for now this is the best workaround I was able to find. |
Hello. It seems I rushed a bit with my first comment, because the log messages came back after a full reboot with the workaround I posted before. My apologies. I also tried what you asked me to do. After three reboots, I've seen no log messages over the tuigreet prompt every time I tried to log in. However, I did not have the quiet flag set in my GRUB config before. I'll wait a few more days, and, if the log messages come again, I'll try the workaround proposed by occhioverde and report back. My tuigreet version is 0.7.2. Cheers. |
I tried @Occhioverde's solution and it seemed to have worked. The logs and errors are gone now, will report again if it comes back. EDIT: @foopsss's suggestion I also tried, but no luck though. |
@apognu What about adding an option, for example by pressing F5, to allow user to manually update the screen? |
After sometime, I reverted the changes from @Occhioverde's solution as I happened needed to check the systemd logs at the login screen as my system won't boot into desktop environment. So I had to boot into a livecd and delete the lines in the service file. I guess it's just hard to get them all, debuggability and cleanliness. |
Here is a more elegant way to fix this problem. Inspired by @UltraBlackLinux and I checked ly's repo to find how did they fix this issue. In #4ab41f0 I found that they just change service file with "Type = idle". In getty - ArchWiki, 2.3.1, a small tip point out how it works:
Then I add a new line "Type=idle" in greetd.service file. And tuigreet looks fine after restart. |
I wonder if I'm alone in this, but this doesn't solve the issue for me. I saw the exact error msgs as @literal-line above. Edit: I don't think it is related to this issue but I got it fixed with setting up the silent boot. |
Setting |
I found this config from some thread on reddit. For working with NixOS. Here is the original post. I've been using it in my config and it works like a charm. # this is a life saver.
# literally no documentation about this anywhere.
# might be good to write about this...
# https://www.reddit.com/r/NixOS/comments/u0cdpi/tuigreet_with_xmonad_how/
systemd.services.greetd.serviceConfig = {
Type = "idle";
StandardInput = "tty";
StandardOutput = "tty";
StandardError = "journal"; # Without this errors will spam on screen
# Without these bootlogs will spam on screen
TTYReset = true;
TTYVHangup = true;
TTYVTDisallocate = true;
}; Edit: An example config for arch. I actually haven't tested this one but based on other systemd configs i've seen it should work. # /etc/systemd/system/greetd.d/no_spam.conf
[Service]
Type = "idle"
StandardOutput = "tty"
# Without this errors will spam on screen
StandardError = "journal"
# Without these bootlogs will spam on screen
TTYReset = true
TTYVHangup = true
TTYVTDisallocate = true The arch wiki says |
As an idea, why not making ESC key clear and redraw the whole screen? |
I was having the same problem in Arch and fixed it using by adding the below systemd config with
|
A comment on Reddit seems to have had some luck with these
I can't really reproduce the issue on my systems, but if someone wants to give it a try, have at it. |
This is what I have in my system config. It works very well and I do not have any spam on my screen. |
the nix thing works perfectly. thank you so much |
This is one of the greatest solutions I've ever seen. The source is a lonely comment sourcing another post. That post is a 0 upvote question by someone new to linux. And now our tuigreet is fixed. |
Is there any chance this could merged into greetd? Or maybe have tuigreet send the signals described in #68 (comment) to systemd as part of tuigreet itself? |
I do not think this should be the responsibility of |
It should be the responsibility of the packaging system (e.g. AUR or nixpkgs), correct @apognu? |
In my opinion, yes. But one precision: the responsibility of the package that actually starts a service, so in our case I could add a drop-in systed override for |
Another possible solution is to set I haven't confirmed this actually fixes the problem yet though. Edit: This doesn't seem to work. Although I don't know why. |
I tried the override dropins on Gentoo with systemd, and it does not solve the problem. The particular journal entries that show up for me are the messages from the docker daemon starting containers. |
Could start greetd.service after docker. Would add a little bit of boot time but remove the logs. |
Even though I sympathize with people encountering this issue, I do not think this is I will not lock discussion but will close this. I will still monitor responses just in case something comes up. |
Glad to see this issue finally closed and the typo in title fixed. ;) Thanks for concerning from apognu and all you guys. |
It was consistently fixed with the above solution, but has returned after several updates. This is a fine outcome. Knowing it is not a simple issue and not the result of my incompetence, it's really not that much of an eyesore. tuigreet is still a net positive in my config and morning routine, thank you @apognu. |
I like tuigreet but this drove me crazy. My final solution was running tuigreet in a minimal desktop environment. tuigreet inside rio terminal inside cage wayland compositor |
i have this, and it works fine # /etc/default/grub (ignore the nvidia stuff)
GRUB_CMDLINE_LINUX_DEFAULT="console=tty1 loglevel=3 modprobe.blacklist=nouveau nvidia_drm.modeset=1 nvidia-drm.fbdev=1"
# /proc/sys/kernel/printk
3 4 1 4 |
The
systemd-networkd-wait-online
service often fails on my machine on startup. When it does so, Systemd writesto the system journal and that gets printed to some of the consoles (not sure which ones and how it works). If this happens when I'm in Tuigreet, the messages gets printed right over the Tuigreed interface. In my case the message fills the password field (that's where the cursor is).
Could Tuigreet somehow disable printing of system log messages to the console it works in? (And maybe reenable it when Tuigreet quits.)
I'm using
tuigreet 0.7.3
running Archlinux.The text was updated successfully, but these errors were encountered: