mbox series

[V3,0/4] introduce coalesced pio support

Message ID 1535040889-52782-1-git-send-email-peng.hao2@zte.com.cn (mailing list archive)
Headers show
Series introduce coalesced pio support | expand

Message

Peng Hao Aug. 23, 2018, 4:14 p.m. UTC
Coalesced pio is base on coalesced mmio and can be used for some port
like rtc port, pci-host config port, virtio-pci config port and so on.

Specially in case of rtc as coalesced pio, some versions of windows guest 
access rtc frequently because of rtc as system tick. guest access rtc like 
this: write register index to 0x70, then write or read data from 0x71. 
writing 0x70 port is just as index and do nothing else. So we can use 
coalesced pio to handle this scene to reduce VM-EXIT time.

without my patch, get the vm-exit time of accessing rtc 0x70 and piix 0xcf8
using perf tools: (guest OS : windows 7 64bit)
IO Port Access  Samples Samples%  Time%  Min Time  Max Time  Avg time
0x70:POUT        86     30.99%    74.59%   9us      29us    10.75us (+- 3.41%)
0xcf8:POUT     1119     2.60%     2.12%   2.79us    56.83us 3.41us (+- 2.23%)

with my patch
IO Port Access  Samples Samples%  Time%   Min Time  Max Time   Avg time
 0x70:POUT       106    32.02%    29.47%    0us      10us     1.57us (+- 7.38%)
0xcf8:POUT      1065    1.67%     0.28%   0.41us    65.44us   0.66us (+- 10.55%)

These are just qemu's patches, another patches are for kernel.
I think there is a need for further consideration in changing coalesecd_mmio's 
naming in kernel and qemu together.So maybe another patch does it.

Peng Hao (4):
  target-i386: introduce coalesced_pio kvm header update
  target-i386: add coalesced_pio API
  target-i386: add rtc 0x70 port as coalesced_pio
  target-i386: add i440fx 0xcf8 port as coalesced_pio

 accel/kvm/kvm-all.c       | 58 ++++++++++++++++++++++++++++++++++++++++++-----
 hw/pci-host/piix.c        |  4 ++++
 hw/timer/mc146818rtc.c    |  8 +++++++
 include/exec/memattrs.h   |  2 +-
 linux-headers/linux/kvm.h |  5 ++--
 5 files changed, 68 insertions(+), 9 deletions(-)