Avi Kivity wrote: > Gregory Haskins wrote: >>>> And likewise, in both cases, G1 would (should?) know what to do with >>>> that "address" as it relates to G2, just as it would need to know what >>>> the PIO address is for. Typically this would result in some kind of >>>> translation of that "address", but I suppose even this is completely >>>> arbitrary and only G1 knows for sure. E.g. it might translate from >>>> hypercall vector X to Y similar to your PIO example, it might >>>> completely >>>> change transports, or it might terminate locally (e.g. emulated device >>>> in G1). IOW: G2 might be using hypercalls to talk to G1, and G1 >>>> might >>>> be using MMIO to talk to H. I don't think it matters from a topology >>>> perspective (though it might from a performance perspective). >>>> >>> How can you translate a hypercall? G1's and H's hypercall mechanisms >>> can be completely different. >>> >> >> Well, what I mean is that the hypercall ABI is specific to G2->G1, but >> the path really looks like G2->(H)->G1 transparently since H gets all >> the initial exits coming from G2. But all H has to do is blindly >> reinject the exit with all the same parameters (e.g. registers, >> primarily) to the G1-root context. >> >> So when the trap is injected to G1, G1 sees it as a normal HC-VMEXIT, >> and does its thing according to the ABI. Perhaps the ABI for that >> particular HC-id is a PIOoHC, so it turns around and does a >> ioread/iowrite PIO, trapping us back to H. >> >> So this transform of the HC-id "X" to PIO("Y") is the translation I was >> referring to. It could really be anything, though (e.g. HC "X" to HC >> "Z", if thats what G1s handler for X told it to do) >> > > That only works if the device exposes a pio port, and the hypervisor > exposes HC_PIO. If the device exposes the hypercall, things break > once you assign it. Well, true. But normally I would think you would resurface the device from G1 to G2 anyway, so any relevant transform would also be reflected in the resurfaced device config. I suppose if you had a hard requirement that, say, even the pci-config space was pass-through, this would be a problem. I am not sure if that is a realistic environment, though. > >>> Of course mmio is faster in this case since it traps directly. >>> >>> btw, what's the hypercall rate you're seeing? at 10K hypercalls/sec, a >>> 0.4us difference will buy us 0.4% reduction in cpu load, so let's see >>> what's the potential gain here. >>> >> >> Its more of an issue of execution latency (which translates to IO >> latency, since "execution" is usually for the specific goal of doing >> some IO). In fact, per my own design claims, I try to avoid exits like >> the plague and generally succeed at making very few of them. ;) >> >> So its not really the .4% reduction of cpu use that allures me. Its the >> 16% reduction in latency. Time/discussion will tell if its worth the >> trouble to use HC or just try to shave more off of PIO. If we went that >> route, I am concerned about falling back to MMIO, but Anthony seems to >> think this is not a real issue. >> > > You need to use absolute numbers, not percentages off the smallest > component. If you want to reduce latency, keep things on the same > core (IPIs, cache bounces are more expensive than the 200ns we're > seeing here). > > Ok, so there are no shortages of IO cards that can perform operations in the order of 10us-15us. Therefore a 350ns latency (the delta between PIO and HC) turns into a 2%-3.5% overhead when compared to bare-metal. I am not really at liberty to talk about most of the kinds of applications that might care. A trivial example might be PTPd clock distribution. But this is going nowhere. Based on Anthony's asserting that the MMIO fallback worry is unfounded, and all the controversy this is causing, perhaps we should just move on and just forget the whole thing. If I have to I will patch the HC code in my own tree. For now, I will submit a few patches to clean up the locking on the io_bus. That may help narrow the gap without all this stuff, anyway. -Greg
Attachment:
signature.asc
Description: OpenPGP digital signature