Hi,

On 06.06.2017 10:29, liqsub wrote:
Hello all,

I have a question about debuging VirtualBox in Linux environment.

It seems the breakpoint doesn't got been hit.

First I compile a debug version of VirtualBox.
1. start a vm: sudo gdb --args ./VirtualBox --comment ubuntu --startvm
a3af2e12-957b-48a8-8b0c-1afe93fe2d2c --no-startvm-errormsgbox

Hope that you know what you're doing... running VMs as root should only be done for a really, really good reason. Has no impact on your debug problem, however.

2. set break point. For example:

b vpciIOPortOut

3. in the guest, we trigger an IO access.
outw(1,0xd020+0xe)

Did you register your IO callbacks successfully? Did the PCI mapping function get called?

4. In my mind, I think this will break at vpciIOPortOut function. But it
doesn't, the vm just run without break.

If you do things correctly (and I assume that you're not playing with R0 device emulation) then it will break.

Since you're talking about a PCI device, it'd be useful to get the output of (add sudo if you really must work as root)
$ VBoxManage debugvm "vmname" info pci
$ VBoxManage debugvm "vmname" info ioport

5. But as I change the outw to outl/outb.(This will make the 'cb' to be
1 or 4. The VM will crash.
This crash is caused by following Assert in vpciIOPortOut function.

        case VPCI_QUEUE_SEL:
           Assert(cb == 2);
            u32 &= 0xFFFF;
            if (u32 < pState->nQueues)
                pState->uQueueSelector = u32;
            else
                Log3(("%s vpciIOPortOut: Invalid queue selector %08x\n",
INSTANCE(pState), u32));
            break;
So here I think outb/w/l in  guest does TRIGGER the call of
vpciIOPortOut  function. But why does the vm not pause and goto gdb? Is
there something I missed?

Really strange - assertions should be caught by gdb, too.

There's nothing fundamentally wrong with your debugging approach. It really should work, especially as you manage to run into assertions.

Klaus


Thanks.


--

Li Qiang /the Gear Team, Qihoo 360 Inc
_______________________________________________
vbox-dev mailing list
[email protected]
https://www.virtualbox.org/mailman/listinfo/vbox-dev

Reply via email to