-
Notifications
You must be signed in to change notification settings - Fork 59
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
Stuck on "Generating" #51
Comments
Does this issue reproduce if you disable parallel processing? |
I did another batch last night (eight videos in total) with parallel processing disabled, and it got stuck on the third video. |
The latest version (6.2.2) contains a potential fix for this issue. Feel free to update. It's basically the same as the previous issue where I have no idea about the cause since it does not reproduce on my device with the exact same setup. I just guessed the possible reason and implemented something hoping it can help. |
I ran some more singles, this time on a ~90 second video. Out of maybe five or six encodes, one of them still got stuck on generating. |
I tried 6 90-second videos using PAN to upscale 1080p -> 2160p. All of them were successfully and took 2000 seconds. Tried again and was still successful. Now I highly suspect this is an issue that requires a specific setup to reproduce. (I haven't received any other reports for this issue.) It will be a huge pain to investigate. Probably it makes sense adding a watchdog mechanism to detect such hang-up and crash the app intentionally so that the state of app can be captured and reported. I'd suggest you to try CLI version which does not rely on the system built-in encoder. This will also significantly speed up your workflow. |
I also experienced this issue on certain videos. I'm able to reliably reproduce this stuck on generating problem. Let me upgrade to the latest version and test again. Are you able to download and test a 1GB test file? I think if I truncate it the problem no longer produces reliably. |
Sure. If you don't feel like sharing the video publicly you can send a feedback email from the |
Not sure what is special about my setup, but I get stuck at "Generating" almost 100% of the time when using the GUI. The models I have been trying to use are REAL-ESRGAN and REAL-CUGAN, and targeting 2x scaling. Using the CLI I have never seen any lockup, an upscaled videos are processed correctly. My only issues are when using the GUI. System is Mac Studio running Monterey 12.3, with M1 Max and 32GB of memory. If there are any useful logs generated I am happy to include them here, because the GUI path is a very reliable failure for me. |
@chase-cobb Would you mind sharing a sample video that can reproduce the issue reliably? You can use the in-app feedback email to send the file if you don't want to share publicly. BTW it's preferred to use CLI to process videos because it's far more flexible and efficient in terms of compression. You can even make full use of hardware encoding (via |
I think my macbook pro did go to sleep in the process so I'm not sure. I'm trying it again now (anyway to speed it up?) so while I wait, here are the videos: (1) (2). [Link sent through in-app feedback email.] |
Using CLI you can bypass the system encoder which is used by this app. Additionally, you can fine-tune compression parameters, 10-bit color, HDR, etc. A few useful documents:
No. It only supports hardware encoding provided by the OS.
It's not possible without very significant work at low level (not worth doing). The system encoder does not support |
I have figured out a way to dump process state while the app is running normally. I'd appreciate if any of you can provide a "crash" report while the app is stuck at "Generating". The steps are follows when the issue reproduces:
The report shouldn't contain any sensitive information. But if you don't want to share publicly, please attach it to a feedback email sent from the app. |
@imxieyi I am running some batches on different systems today (2x M1 Max and a regular M1) with the same version of SW and the exact same files. The behavior I'm seeing seems to be somewhat random, and I would like to verify that it is the file causing the issue before I dig further into that path. Either way, I expect I will have a log to share using the method you mentioned above in the next few hours. |
"Random" is definitely how I would describe my experiences as well. I haven't been able to mess with it for a while, but as soon as I get the chance, I'll try to generate a crash report. |
Is this crash report enough? Do you also want memory dump and/or spindump? Also, faster version would be |
Maybe. At least it can tell where exactly is the app stuck at.
If you can provide this as well it will be even better. Please send it from feedback email though since it may contain your personal data. |
The tests I ran yesterday pretty much nailed the fact that this is a somewhat random issue, and my general suspicion is that this may be a race condition that is more reliably hit on faster machines. Yesterday I ended up running the same set of files on one of my M1 Max and regular M1. Neither completed the batch files, but the regular M1 made it through the files the M1 Max got stuck on. Exact same files and they were all batch converted with Handbrake prior to the test. The regular M1 got stuck while processing, which I've never seen before, and I will create a new issue with reports and spindumps for this issue. The 2nd M1 Max unit ran a different set of files, that have previously been batched via CLI and got stuck on the 4th file of 6 total. This leads me to believe it is not the files themselves. Also, I have repeatedly batch converted these same files with waifu2x CLI without any issue, in an attempt to test my own automation scripts. I am working on gathering the necessary reports and spindumps to share shortly. |
Is this a valid email where we can send logs and such? [email protected] |
Yes. Please use this email to send the files. |
Email sent |
After analyzing your files it looks like AVAssetWriter.finishWriting never calls the completionHandler. It's likely due to an internal deadlock inside AVAssetWriter. Since the writer encodes video asynchronously, I guess adding some delay before calling finishWriting will help. The next update will try this and see if it works. |
...Apparently I can't dump process memory without disabling SIP. How can I ensure that a core dump is written when I trigger a crash? From some research it seems like it's not as straightforward as |
Thank all of you for providing crash logs and spindumps. The new 6.2.4 version no longer waits for AVAssetWriter.finishWriting callback but instead polls the status with a timeout. It should no longer be stuck at "Generating" forever. Note that this is not a proper fix since the reason is still unknown. According to spindumps you shared it was not due to a deadlock. Most likely it will still wait 60 seconds until throwing a "timed out" error and continue with the next file. Error logs will be automatically reported now if you don't block Crashlytics via something like AdGuard. |
This seems to happen almost every time I perform a batch (although it's possible that I haven't tried enough singles to know it never happens there either). I haven't done nearly as much with photos; my input is primarily h.264 or HEVC. I've mostly been using the
Real-
models. But I remember it happening onPAN
as well.Output file sizes are usually less than 4GB. I always run with Parallel Processing using ANE + GPU. There is no consistency on which video gets stuck. Could be the first two in the batch, or somewhere in the middle. But one thing has been very consistent: there are always two videos stuck on "Generating." There's never just one video that didn't make it.
Some other information that might be useful: clicking the "Stop" button does not stop it from generating. I have to quit waifu2x in order to start another batch. Additionally, after quitting the app, the files that were being generated appear to have the expected file size for a completed render.
It seems like maybe something is getting stuck in the completion of the container, rather that the video itself? Although, that doesn't explain why two always get stuck.
Originally posted by @mattbisme in #48 (comment)
The text was updated successfully, but these errors were encountered: