On Wed, Dec 12, 2012 at 7:43 PM, David Ahern <dsah...@gmail.com> wrote: > > you know what's worse? All of your VMs blowing up because anyone runs perf > with precise attribute. Virtualization and and performance monitoring > collide. From the log message for commit 1342798. > > "Intel PEBS in VT-x context uses the DS address as a guest linear address, > even though its programmed by the host as a host linear address. This either > results in guest memory corruption and or the hardware faulting and > 'crashing' the virtual machine. Therefore we have to disable PEBS on VT-x > enter and re-enable on VT-x exit, enforcing a strict exclude_guest."
Right. SO WHY DON'T YOU JUST DO THAT THEN? Disable PEBS on Vt-x enter and re-enable it on exit. End of story. Exactly like you say. But don't in the process screw up people WHO DON'T EVEN DO VIRTUALIZATION! So please, just remove that idiotic "if (!event->attr.exclude_guest)" test. It's wrong. It cannot possibly do the right thing. It is totally misdesigned, exactly because you don't even know beforehand if somebody uses virtualization or not. Now, if the feature had been done the sane way around, and you'd have an explicit flag that says "force this even on entry to virtualized guests", then you could have said "Dave, I can't do that combination of precise and virtualized guests". At that point you have - at perf record time - a valid reason to say EOPNOTSUPP. But doing it this way was wrong. Switch that "exclude_guest" attribute around, and admit that "H" was bogus, and that the right thing to do was to add a "V" flag that sets the "force_guest" flag instead. Problem solved, without screwing people who have no reason to ever care. Linus -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/