Hmm, according to that log, the last action is to call metadata_downloaded() at line 1073 in gui2/device.py
To debug further, someone that can reproduce the issue is going to have to run from source and stick a few print statements in that function to see where exactly it is hanging.
I initially suspected a deadlock, but if you say that one CPU is pegged, then it cannot be a deadlock.
|