On 10/10/2017 10:58, Marek Vasut wrote:
>> #0  0x00007ffff7931945 in pthread_cond_wait@@GLIBC_2.3.2 () at 
>> /lib64/libpthread.so.0
>> #1  0x00005555557cf9c5 in qemu_cond_wait (cond=cond@entry=0x555555b5f9c0 
>> <qemu_pause_cond>, mutex=mutex@entry=0x555555b5fa40 <qemu_global_mutex>) at 
>> util/qemu-thread-posix.c:161
>> #2  0x0000555555606ee8 in pause_all_vcpus () at cpus.c:1620
>> #3  0x00005555555cc43a in main (argc=<optimized out>, argv=<optimized out>, 
>> envp=<optimized out>)
>>     at vl.c:4906
>>
>> Looks like the CPU does not get stopped right? Unfortunately, I've got no
>> good clue how to debug that further right now...
> I'd look at pause_all_vcpus() and check why it is stuck.
> I'm a bit overloaded at the moment, so I don't have time to dig in it.
> 

It's actually the CPU thread that is stuck because the
start-of-translation-block test is wrong and never succeeds:

0x7fd715fff0c0:  mov    -0x14(%rsp),%ebp
0x7fd715fff0c4:  test   %ebp,%ebp
0x7fd715fff0c6:  jl     0x7fd715fff0e4

It should be using %r14, not %rsp.  I've sent a patch.

Paolo

Reply via email to