-
Notifications
You must be signed in to change notification settings - Fork 9
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
The script doesnt work half the time #46
Comments
Are you using a virtual display driver like IDDSampleDriver? |
Yep |
There is a bug currently in Sunshine where it will pick the iGPU instead of the dedicated GPU causing it to display errors like no video from host or encoding errors. Try installing this version of sunshine which contains the fix |
Is this the nightly version or just patched sunshine? |
It's not yet in the nightly version of sunshine, the link I provided you is the patched version from the pull request |
Got it thanks, I will reply in a few days if it fixed it or not. |
Did it resolve the issue? |
Yes, its fixed, I hope they will accept your edit into the main build. |
@Nonary Hi. I tried to use the Sunshine version you've provided above but still I can't get the script to work properly. I also have hybrid mode enabled in my laptop and when I try to start streaming I get error code -1
The automation seems to work, but the streaming don't. I have dual monitors (laptop and a second monitor) and configured MonitorSwapAutomation to only use my second monitor when start streaming. I can see my second monitor being enabled and my laptop's monitor being disable, but then I get this error code "-1". Same thing when I try to use MonitorProfileSwitcher. Do you have any ideas? |
I need the entire logs of sunshine, plus the logs of the monitor swapper. Keep in mind sunshine erases logs every time it is restarted so you'll have to repeat the issue if you've stopped sunshine and started it recently |
Thank you very much for your replay. Here you can get the entire sunshine's logs: Here you'll find the MonitorSwap's logs: Again, I did not configure any dummy display. My goal is to automatically use only my second monitor when I start streaming. That way, I can turn off the screen of my second monitor, and my laptop's screen will also be turned off because the script is supposed to enable only the second monitor. I followed your guide, but targeted my second monitor instead of a dummy device/virtual display. I also set the resolution and refresh rate in the dummy.cfg file to my desired settings. |
Can you move the script to your user profile instead of C:\Apps? It generally does not work properly outside of user profile due to how Windows handles read/write access. |
Is it a virtual or actual dummy plug? Don't include the xml file, just remove and reinstall driver, again only matters if youre using virtual display instead of dummy plug |
I just tried and did not work, same error code "-1" and same log description.
It's not either a dummy plug or virtual display. I did not want to mess with virtual display, since I got issues last time about my entire screen getting black even after restarting laptop. Somehow the virtual display got activated as primary display and had little headache to get things back. My laptop only has a one HDMI port which I use to connect my second monitor and I used it as extended mode. This is my normal/daily setup. What I want is just automate the process of disable my laptop's monitor and only enable my second monitor. That way I can just turn off my second monitor's screen while it still plugged and powered on. What I did was configure the dummy.cfg to use only my second monitor instead a virtual/dummy display. One curios thing is:
After do these steps, if I start streaming again from moonlight everything works as supposed to. Somehow if I first start streaming with the dummy.cfg condition already enabled and then get the primary.cfg condition back again, if start streaming again from primary.cfg condition enabled everything works. However if I restart sunshine then it stops to work again and I receive the error code "-1". |
Unfortunately, I can't fix that issue because it's a limitation of DXGI itself. The problem happens because the laptop switches between integrated and hybrid graphics. If Sunshine is set to use dedicated graphics while the display is set to integrated graphics (or vice versa), it won't be able to capture properly. Additionally, Microsoft has a restriction where the GPU preference can only be set once per process's lifetime. That's why you're noticing it works only once before you need to restart the process. I'll ask the Sunshine developer community about the possibility of allowing Sunshine to restart itself if it encounters a DXGI failure. This could work around the "once per lifetime" issue by automating the restart process. But beyond that, there's no solution until Microsoft changes the API to allow setting GPU preference more than once per process lifetime. |
Okay, I got it. Thank you very much for your explanation and your time. I think even if I try to use a virtual display, instead of enabling only my second monitor as I'm doing, will I face the same issue, right? Since the problem it seems to be related to the hybrid mode (iGPU and dGPU activated at the same time). |
You should only need to restart it if Sunshine was launched while in extended mode. However, I'm not completely sure—it might require a restart any time you need to stream. After reviewing the code, it seems this issue can't be fixed in Sunshine without altering the streaming method to resemble GameStream, which spawns a new process for each session or connection. This change would significantly increase code complexity, so unlikely to happen because of that. |
Got it. I would need an automation to disable extended mode every time I want to stream. I would actually need to disable extended mode and restart sunshine to work properly. Indeed it seems too much complicated. But thank you anyway. |
Closing out issue as original poster confirmed that the sunshine fix resolved their issue |
@broslife I have some good news, I am currently developing a workaround script to the DuplicateOutput Failed Issue and the issue with laptops with hybrid GUIs. I was able to replicate the issue on my desktop and develop a proof of concept: https://github.com/Nonary/DuplicateOutputFailFix |
Hi! Thanks for let me know. I will be glad to test your proof of concept and then share the results with you. |
I tested your PoC following all the steps you from the guide and it worked very well. One question about the HybridGPUMonitorTask. Is this script running constantly? It doesn't affect nothing about computer's performance? |
It does run in the background, in order for the script to work properly it has to monitor the log file of Sunshine at all times. I have optimized it to only poll once a second, and the entire log is streamed and buffered so it doesn't load the entire file in memory at once. Both of these optimizations keeps the CPU usage and RAM low. |
On my system it is taking 0% CPU usage and consumes a paltry 19MB of memory for example |
The script automates restarting sunshine in the scenario where the GPU preference needs to change, which means there will be sometimes where you start a stream it will kick you back out to start streaming again because Sunshine had to be restarted. There is no way around that, otherwise you wouldn’t be able to stream at all until you manually restarted Sunshine like discussed earlier in this issue. |
So basically about 5/10 occasions the script doesnt function And I get a no encode device error.
After restarting sunshine it works again.
I tried changing strict restore, start delay and I did not set any forced codec ,gpu or monitor.
The text was updated successfully, but these errors were encountered: