-
-
Notifications
You must be signed in to change notification settings - Fork 100
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
Bar slows down after repeated display changes #336
Comments
I have tried to reproduce with this config:
This is what it looks like when disconnecting and connecting a display: test.mp4Although the video doesn't capture it, there is a slight flickering on display connect, disconnect because I reset all bars on these events. |
So... this was a bit more difficult than I thought. Couple of unrelated findings:
Now I just built from source and suddenly I can use I ran with your test config file and observed the behavior. The video below shows it pretty well -- I detach and reattach one of my two external screens repeatedly. I had the impression that things got worse over time, and I was reminded that I previously saw Sketchybar consume over 1GB of memory... so I recorded the process info in Activity Monitor together with the reaction of the bar itself. Please let me know anything else I can tell you -- would be great to find out what this is all about! 20230310-sketchybar-flicker.mp4 |
It is not documented because it is not yet released. I have added this feature a few days ago: c406cfa Feel free to create a PR for the
As I said, it is an unreleased, undocumented feature I have added recently. This is the difference between current brew release and current master: v2.14.1...master
Possibly a memory leak. There is a slow memory leak in the current brew release which I fixed here (which is probably unrelated): ce4724f I will see if I can reproduce when detaching and re-attaching frequently. But some small amount of flickering is perfectly normal. |
Found a memory leak that appears when not setting the bar to be |
Created a new brew release just now, should be fixed. |
Sorry, was busy with other stuff. I have installed the latest from brew and it certainly doesn't make anything worse. I can still see that the bar flickers off and on several times when screens come and go -- will see over time whether the behavior degrades as it seemed to do previously. There's still something odd about the brew build. I built your latest from master and I get
When I do the same with the updated brew version, I get
... IOW, nothing. Weird. The good news is that the brew version now outputs an error when I use |
It has nothing to do with the brew version and the compiled version. You get the invalid domain error when sketchybar is running. If it is not running you get nothing. Thats simply because all arguments except |
Oh, I see. Fair enough. Haven't read all the source code yet ;) |
After a while -- I can still see this problem getting worse over time. As I mentioned before, the flicker does not only occur when I attach or detach screens, but also when the screen(s) come back on after they went to sleep (when the screen is locked in my absence). This allows me to observe, over the course of a day, how the behavior changes. On a couple of occasions I have also seen that the bar is not visible anymore after I detached the external screens. In that situation the bar is still running, but I need to kill it to actually see it again. Finally, I think there may be more memory leaks. I'm getting in the habit to restart the bar once a day or so to keep it running properly. |
Played around with Xcode a bit (I don't normally work with it) and managed to run the profiler. No leaks found so far, but for fun I tried to detach and attach a screen and the allocation graph looks like this: I can't judge if that's a problem -- there's lots of RAM available -- but it seems a bit unusual... and since we're talking basic C, no garbage collection or other modern magic, should this extra allocation occur? From previous cursory glances at the activity monitor, I believe this will happen every time I detach/attach. Anyway, I'll leave the bar running with profiler for a while and see what I find. |
Yeah, so the extra magic that happens in the background is vm allocations by the system. Specifically the WindowServer allocates vm space for the backing store of the windows. AFAIK this is handled by the system and since there are no leaks (which I would be responsible for) there seems to be something odd going on with the backing stores not being released properly (or at least they are not released immediately). I have found this one function: extern CGError SLSSetWindowToReleaseBackingOnOrderOut(int cid, uint32_t wid, bool release); but setting this to true does not change anything regarding the mach_vm allocations. |
Several findings. I'm watching the "persistent" and "# persistent" columns now, since I understand that these show memory and allocations that have not been freed yet. I assume that we would expect to see these numbers remain largely static, since there is no reason to keep allocating (and not freeing) additional memory after an initial startup period.
I noticed that the "# persistent" column was growing by one each second even if I was not doing anything. I believe the update frequency for the aliases is once per second, so I restarted without any aliases and this problem went away.
Regarding your last comment -- I had been watching the row "all heap & anonymous VM" so far. But I repeated some of my tests and watched the rows "all heap allocations" and "all anonymous VM" instead. The value in the row "all anonymous VM" remained the same, or varied by very small values (it went up by one at some point when I wasn't doing anything). It's mainly the value "all heap allocations" that grows. |
Right, thanks. I can see that... pretty disconcerting behavior in any case, if you see memory consumption of this tiny bar creep beyond the 1GB mark after a while. And I don't think I have any other app running that behaves this way. Anyway... if you say there's no leak I'll gladly believe you. Then the weird flickering redraw behavior must have a different reason, but it's definitely still there. |
It could still be that this is in fact a problem... but I am not sure how to solve it. It seems that the memory is not properly given back on window destruction... I will investigate further. |
I think I have found the problem. Calling |
Thanks for the update! That's a weird change. Maybe a bug? But that would presumably affect many applications... Edit: what strange API function is Second edit, with apologies. It's a Skylight function, alright. But... still I have no clue where to find any docs. Very strange. Third edit: private framework, I see... such fun. Sorry for all the questions. |
Ok good news, I have looked through the implementation of these private functions and found that there is a retain problem caused by calling |
I just left sketchybar running since yesterday around the same time -- 24 hours, but the machine was sleeping overnight. Just now it became unbearable, for a reason that may or may not be related to the issues we've been discussing. What happens is that sketchybar slows down switching between spaces. When I Cmd-Tab between apps that run in different spaces, there is a very noticeable delay. The delay is two-part. First, nothing happens for a short while - a good part of a second, I think. Then, the space switches, and the second part of the delay is the slow redrawing of the bar itself. You've seen my screenshots, I have these nine space symbols on the bar, and I can basically see them appear one by one. The process altogether doesn't take super long, but it's very annoying anyway if you need to switch back and forth. Anyway... I was going to wait until I can take a screenshot of the bar using 1GB of memory, but now I killed it at 545MB and after the restart space switching is fast and snappy again. I'm not sure whether all this comes down to the same issue(s), and I wonder how I'm apparently the only one with these persistent problems. |
Yeah this sounds like what I was able to reproduce by intentionally forcing window refreshes in a loop. I think this will be fixed once I get behind all of this. Maybe your monitor connects and disconnects several times when the system sleeps which provokes this problem. |
That is possible, but I also observe that things get worse and worse during the day as I lock and unlock the machine. When I lock it, the monitors go to sleep, and then the reconnect when I come back and unlock. Then I usually detach the machine a couple of times during a day... it adds up. |
I think this commit should fix the problem: 33f815c (funnily enough, if you look at the changes) Sadly I did not find a way to achieve this while keeping the transactional window ordering around. Can you test the latest master? brew uninstall sketchybar
brew install sketchybar --head
brew services restart sketchybar |
I repeated some of my previous tests with the master version and there are definitely improvements. Running with only the space indicators and no aliases, here is the memory curve after a display sleep/wake cycle: You can see something that never happened before: memory consumption decreased at the point where the screen was detached. Now I tried to run with two aliases (wifi and clock), which I also did previously. First, I noticed that memory consumption (and the "# persistent" value) increased when I moved the mouse between displays/spaces -- much like it did before. But one thing was new: I also saw that the "# persistent" value sometimes decreased when I stopped moving the mouse for a while. And then, the display sleek/wake cycle again resulted in a decrease of memory consumption: I'll leave the bar running now and check back on the overall consumption and behavior in a little while.
I'm not sure how this change would manifest itself during use. I'd still like to know how you found out what functions like |
Okay that sounds promising so far.
There is no description or documentation for these functions. These are functions apple has designed for use in their own applications, like their own menubar and such. These functions can be very powerful and some things simply can not be done with the public frameworks apple exposes. The signatures of these functions and their behavior can be constructed by reading the binary instructions. Basically: everything is open source if you know how to handle raw binary instructions (or assembly). Actually this the reason for this project altogether since I was fascinated by yabais use of private frameworks and wanted to have my own playground. |
No worries, I understand what you're saying. But if all you have is function signatures, I wonder how you know what the function with |
As I said! Kudos for making that effort. You should start a wiki and document this stuff, so others don't have to do it all over again. So far, no significant change. I started this morning with this (after the tests described above): Right now I have this: |
One more update this morning: things are still good. Here's the same activity monitor screenshot: The thing that has not changed is the original subject of this report:
This problem is less noticeable now because the flickering doesn't take as long as it did previously. Certainly much easier to ignore, unless you're keen to track this down. I'll leave it to you to close this issue or keep it open for further investigation. Please let me know if I can supply any more information. |
Thanks for the update. The flickering you see on monitor connect and disconnect is an artifact created by how I handle display added/removed/resized events and could be circumvented by implementing a better display change system, i.e. I currently destroy all bars and recreate them from scratch on any of those events. The thing that causes the flickering is that there usually are multiple events that correspond to a singular display change (e.g. display added, display moved and eventually even display resized right after each other on a single display connect leading to all bars on all displays being destroyed and recreated several times). This is also the reason why display events would cause the massive memory problems related to the skylight retain problem that we discussed. |
Maybe a basic "debouncing" of the various events would help, without having to track specifically through the sequence -- assuming the sequence is perhaps not always exactly the same, especially with multiple screens generating events at more or less the same time. When I plug my monitors in or wake up from sleep, the Mac takes several seconds to sort itself out. If Sketchybar took a half second somewhere in there to debounce events and then react once to redisplay itself, that would not add any relevant delay but probably look nicer and clean up the process. Just an idea for a pragmatic workaround. |
I made the display event handling less aggressive, only the display added/removed events will now lead to a full reset. Further improvements are still possible but then complexity of book keeping rises a bit. You can try it by running: brew upgrade sketchybar --fetch-HEAD I will need to test this new display implementation a bit before making a new release. |
Certainly much easier on the eye! I tried to unplug a display, this redisplayed the bar only once, no flicker. Then I plugged the display back in, and this caused a multi-stage redisplay:
I'll leave this running and let you know if I see any new issues. |
The new release contains these fixes. To switch back to the stable releases simply uninstall and install sketchybar again without the |
Is |
Sonoma (or some newer version of Ventura) has fixed the memory problems with Maybe I will start using it again for window ordering on Sonoma and up. |
Please note that the title is a guess. I notice this redrawing behavior when I plug or unplug external screens (which is how I did it for the video below), but it also happens when the Mac comes back from sleep. In that case, since all screens are already attached, the bar redraws several times on all three screens (two external, plus the internal display).
My configuration is super simple, I use standard values for almost everything. What remains is this:
Any guesses what else I may try? Assuming this is not standard behavior? Oh, I'm running Ventura 13.2.1 on my M2 Mac (edit: and SketchyBar 2.14.0).
20230307-sketchybar-flicker.mp4
The text was updated successfully, but these errors were encountered: