[putting Avi on CC as the final decision maker] On 2012-09-19 15:37, Muli Ben-Yehuda wrote: > On Tue, Sep 18, 2012 at 03:08:40PM +0200, Jan Kiszka wrote: >> On 2012-09-18 14:50, GaoYi wrote: >>> Hi Jan, >>> >>> I have followed a previous thread about ELI proposed by Abel Gordon, >>> http://www.spinics.net/lists/kvm/msg73907.html. >>> I wonder whether this mechanism will be incorporated in KVM someday. >> >> Likely not. Both Intel and AMD will soon ship hardware that >> obsoletes this invasive and imperfect software solution, see also >> [1]. > > Hi Jan, > > I think this decision may be short-sighted. First, it remains to be > seen how good the upcoming hardware support for interrupt > virtualization will be once it ships. Second, history has been pretty > consistent in that it takes several years for hardware to catch up to > software, and even when it does, software sometimes still wins. (There > are workloads where shadow page tables still outperform EPT/NPT, to > give a concrete example). Although ELI works today, I'd be happy to > hear what parts of it you find "invasive" and "imperfect" (what > software ever is perfect?)
It's imperfect as you need to dedicate a core to pure guest-mode load and cannot run userspace on that core (cannot walk through userspace-based device models e.g.). And it requires that magic bar to map the shadow IDT into the guest (hmm, I think Hitachi avoided this). It's invasive as it has to change Linux to maintain those isolated slave CPUs. That is, of course, based on code that was published by Hitachi. Yours may differ but will still have to solve the same problems. Back then in our discussion, it was unclear if and when real hardware will actually show up. Now the spec is already there, hardware should follow within months (typically). I'm not aware of limitations regarding zero-exit virtualization so far. But please share any insights you collected from studying the specs or recent patches! Jan -- Siemens AG, Corporate Technology, CT RTC ITP SDP-DE Corporate Competence Center Embedded Linux