Date: Thu, 28 Sep 2017 02:55:55 -0700 From: <soralx@cydem.org> To: <jkim@FreeBSD.org> Cc: <vbox@FreeBSD.org> Subject: Re: [virtualbox-ose] Build failure: global register variable Message-ID: <20170928025555.032ce67a@mscad14> In-Reply-To: <6b02f95f-207b-0f55-8e30-11512979804e@FreeBSD.org> References: <20170917195419.431341e7@mscad14> <20170920191710.58d335df@mscad14> <20170921160000.689755f8@mscad14> <5c68323f-5fed-342b-ad92-e74d178f9daf@FreeBSD.org> <20170924180619.23e149be@mscad14> <6b02f95f-207b-0f55-8e30-11512979804e@FreeBSD.org>
index | next in thread | previous in thread | raw e-mail
Jung-uk,
> >>> [0] clang/lib/Basic/Targets/X86.h:
> >>> 860 bool validateGlobalRegisterVariable(StringRef RegName,
> >>> unsigned RegSize, 861 bool
> >>> &HasSizeMismatch) const override { 862 // rsp and rbp are the
> >>> only 64-bit registers the x86 backend can currently 863 //
> >>> handle. 864 if (RegName.equals("rsp") || RegName.equals("rbp"))
> >>> { 865 // Check that the register size is 64-bit.
> >>> 866 HasSizeMismatch = RegSize != 64;
> >>> 867 return true;
> >>> 868 }
> >>
> >> Please try the attached patch.
> >
> > Thanks for the patch! I gave it a quick try (not an extensive test),
> > and VirtualBox, compiled fully with clang, seems to work as usual.
>
> Committed (r450636), thanks!
Sadly, I forgot to disable VT-x when testing. My bad.
I tested again, and found that, on unpatched VBox, the virtual
machine boots and works fine with both VT-x on and off, while
patched version fails to start the VM when VT-x is turned off:
VBoxManage: error: No error info
VBoxManage: error: Details: code NS_ERROR_CALL_FAILED (0x800706be),
component ProgressProxy, interface IProgress
How would one go about debugging this?
> For more detailed information, please read the commit log.
>
> https://svnweb.freebsd.org/changeset/ports/450636
>
> Jung-uk Kim
--
[SorAlx] ridin' VN2000 Classic LT
help
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20170928025555.032ce67a>
