[vbox-dev] Problems with porting a VritualBox frontend from Windows to Linux

Klaus Espenlaub klaus.espenlaub at oracle.com
Tue Mar 31 13:16:22 GMT 2015


Rūdolfs,

On 31.03.2015 13:22, Rūdolfs Bundulis wrote:
> Hi,
>
> ok I found the root issue - my code did not call  RTR3InitExe(argc,
> &argv, 0) since I built the application only from looking at the API
> interfaces and was not aware that I need to do this (actually maybe it
> makes sense to include a comment int the xpcom tstVBoxAPIXPCOM.cpp
> sample about this?).

"Regular" API clients don't need this, they can happily live with the 
implicit, delayed initialization which disables some functionality. 
That's why it makes no sense to talk about it in tstVBoxAPIXPCOM.cpp - 
it's happily working.

Only API clients actually running VMs inside them absolutely need the 
full initialization as the very first thing, otherwise they won't work.

> Now after I've taken a closer look to the frontends
> I see that all them call the initialization function the first thing. I
> added it and my IFrambuffer implementation started to get invocations.

Pretty sure that e.g. VBoxManage.cpp only does it because in uses quite 
some runtime functionality, and doesn't want to run any risk (in the old 
days it was far less "optional" to do the initialization).

> Since my Windows code worked fine without it - should I add it to
> Windows as well? Any chance it is responsible for the weird recompiler
> longjmp crash I get? Thanks in advance.

Did you by any chance extend the CPUCTX struct or any other data 
structure which might be used by the recompiler? Just hours ago we 
tracked down a MingW gcc bug in the very same area which smells very 
similar...

Regards
Klaus
>
> Best Regards,
> Rudolfs Bundulis
>
>
>
> 2015-03-30 2:42 GMT+03:00 Rūdolfs Bundulis <rudolfs.bundulis at gmail.com
> <mailto:rudolfs.bundulis at gmail.com>>:
>
>     Hi,
>
>     I compiled debug version of 4.3.26 and tried my code against it -
>     now the log has a much nicer assert message just before it ends:
>
>     00:00:55.619996 TM: GIP - u32Mode=1 (SyncTSC) u32UpdateHz=83
>     00:00:55.652313 TM: cTSCTicksPerSecond=0xa0861eba (2 693 144 250)
>     fTSCVirtualized=true  fTSCUseRealTSC=false
>     00:00:55.652322 TM: fMaybeUseOffsettedHostTSC=true
>     TSCTiedToExecution=false TSCNotTiedToHalt=false
>     00:00:55.652373
>     00:00:55.652376 !!Assertion Failed!!
>     00:00:55.652378 Expression: <NULL>
>     00:00:55.652380 Location  :
>     /home/rudolfs/VirtualBox-4.3.26/src/VBox/VMM/VMMR3/TM.cpp(576) int
>     TMR3Init(PVM)
>     00:00:55.652508 Failed to create timer, u32Millies=10
>     rc=VERR_NOT_SUPPORTED.
>
>     I put a breakpoint in TM.cpp:576, and it seems that I am failing
>     because of the code in RTTimerCreateEx():
>
>          /*
>           * We need the signal masks to be set correctly, which they
>     won't be in
>           * unobtrusive mode.
>           */
>          if (RTR3InitIsUnobtrusive())
>              return VERR_NOT_SUPPORTED;
>
>     What is unobtrusive mode and what signal masks do I need to set?
>     I'll have a look at what is done in the frontends, but I guess that
>     you guys here can explain it in more detail.
>
>     Best Reagrds,
>     Rudolfs Bundulis




More information about the vbox-dev mailing list