1. 18 Aug, 2014 1 commit
  2. 17 Aug, 2014 1 commit
    • Paolo Bonzini's avatar
      ioport: split deletion and destruction · e3fb0ade
      Paolo Bonzini authored
      Of the two functions portio_list_del and portio_list_destroy,
      the latter is just freeing a memory area.  However, portio_list_del
      is the logical equivalent of memory_region_del_subregion so
      destruction of memory regions does not belong there.
      
      Actually, neither of these APIs are in use; portio is mostly used by
      ISA devices or VGAs, and neither of these is currently hot-unpluggable.
      Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
      e3fb0ade
  3. 17 Oct, 2013 1 commit
  4. 05 Sep, 2013 1 commit
  5. 25 Jul, 2013 1 commit
  6. 12 Jul, 2013 1 commit
    • Anthony Liguori's avatar
      ioport: remove LITTLE_ENDIAN mark for portio · c3cb8e77
      Anthony Liguori authored
      Setting it to LE forces a byte swap when host != guest endian but
      this makes no sense at all.
      
      Herve made the suggestion upon observing that word writes/reads
      were broken into byte writes/reads in such a way as to assume
      devices are interpret registers as LE.
      
      However, even if this were a problem, marking the region as LE is
      not useful because what's essentially happening here is that LE is
      open coded.  So by marking it LE in MemoryRegionOps, we're doing a
      superflous swap.
      
      Now, the portio code is suspicious to begin with.  The dispatch
      layer really has no purpose in splitting I/O requests in the first
      place...
      
      Cc: Hervé Poussineau <hpoussin@reactos.org>
      Cc: Alex Graf <agraf@suse.de>
      Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
      Signed-off-by: default avatarAnthony Liguori <aliguori@us.ibm.com>
      c3cb8e77
  7. 04 Jul, 2013 6 commits
  8. 19 Dec, 2012 1 commit
  9. 19 Mar, 2012 1 commit
  10. 05 Mar, 2012 1 commit
    • Avi Kivity's avatar
      ioport: add destructor method to IORange · c5b703ac
      Avi Kivity authored
      Previously all callers had a containing object with a destructor that
      could be used to trigger cleanup of the IORange objects (typically
      just freeing the containing object), but a forthcoming memory API
      change doesn't fit this pattern.  Rather than setting up a new global
      table, extend the ioport system to support destructors.
      Signed-off-by: default avatarAvi Kivity <avi@redhat.com>
      c5b703ac
  11. 29 Feb, 2012 1 commit
  12. 11 Oct, 2011 1 commit
  13. 29 Jul, 2011 1 commit
  14. 23 Jul, 2011 1 commit
    • Paolo Bonzini's avatar
      report serial devices created with -device in the PIIX4 config space · 6141dbfe
      Paolo Bonzini authored
      Serial and parallel devices created with -device are not reported in
      the PIIX4 configuration space, and are hence not picked up by the DSDT.
      This upsets Windows, which hides them altogether from the guest.
      
      To avoid this, check at the end of machine initialization whether the
      corresponding I/O ports have been registered.  The new function in
      ioport.c does this; this also requires a tweak to isa_unassign_ioport.
      
      I left the comment in piix4_pm_initfn since the registers I moved do
      seem to match the 82371AB datasheet.  There are some quirks though.
      We are setting this bit:
      
          "Device 8 EIO Enable (EIO_EN_DEV8)—R/W. 1=Enable PCI access to the
          device 8 enabled I/O ranges to be claimed by PIIX4 and forwarded
          to the ISA/EIO bus. 0=Disable. The LPT_MON_EN must be set to enable
          the decode."
      
      but not LPT_MON_EN (bit 18 at 50h):
      
          LPT Port Enable (LPT_MON_EN)—R/W. 1=Enable accesses to parallel
          port address range (LPT_DEC_SEL) to generate a device 8 (parallel
          port) decode event. 0=Disable.
      
      We're also setting the LPT_DEC_SEL field (that's the 0x60 written to
      63h) to 11, which means reserved, rather than to 01 (378h-37Fh).
      
      Likewise we're not setting SA_MON_EN, SB_MON_EN (respectively bit 14
      and bit 16 at address 50h) for the serial ports.  However, we're setting
      COMA_DEC_SEL and COMB_DEC_SEL correctly, unlike the corresponding register
      for the parallel port.
      
      All these fields are left as they are, since they are probably only
      meant to be used in the DSDT.
      Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
      Signed-off-by: default avatarAnthony Liguori <aliguori@us.ibm.com>
      6141dbfe
  15. 06 Mar, 2011 1 commit
  16. 21 Nov, 2010 1 commit
    • Avi Kivity's avatar
      Type-safe ioport callbacks · acd1c812
      Avi Kivity authored
      The current ioport callbacks are not type-safe, in that they accept an "opaque"
      pointer as an argument whose type must match the argument to the registration
      function; this is not checked by the compiler.
      
      This patch adds an alternative that is type-safe.  Instead of an opaque
      argument, both registation and the callback use a new IOPort type.  The
      callback then uses container_of() to access its main structures.
      
      Currently the old and new methods exist side by side; once the old way is gone,
      we can also save a bunch of memory since the new method requires one pointer
      per ioport instead of 6.
      Acked-by: default avatarAnthony Liguori <aliguori@us.ibm.com>
      Signed-off-by: default avatarAvi Kivity <avi@redhat.com>
      Signed-off-by: default avatarAnthony Liguori <aliguori@us.ibm.com>
      acd1c812
  17. 09 Sep, 2010 1 commit
  18. 01 Oct, 2009 2 commits
  19. 20 Sep, 2009 1 commit
  20. 06 Sep, 2009 1 commit
  21. 24 Aug, 2009 1 commit
    • Anthony Liguori's avatar
      Unbreak large mem support by removing kqemu · 4a1418e0
      Anthony Liguori authored
      kqemu introduces a number of restrictions on the i386 target.  The worst is that
      it prevents large memory from working in the default build.
      
      Furthermore, kqemu is fundamentally flawed in a number of ways.  It relies on
      the TSC as a time source which will not be reliable on a multiple processor
      system in userspace.  Since most modern processors are multicore, this severely
      limits the utility of kqemu.
      
      kvm is a viable alternative for people looking to accelerate qemu and has the
      benefit of being supported by the upstream Linux kernel.  If someone can
      implement work arounds to remove the restrictions introduced by kqemu, I'm
      happy to avoid and/or revert this patch.
      
      N.B. kqemu will still function in the 0.11 series but this patch removes it from
      the 0.12 series.
      
      Paul, please Ack or Nack this patch.
      Signed-off-by: default avatarAnthony Liguori <aliguori@us.ibm.com>
      4a1418e0
  22. 16 Jul, 2009 2 commits
  23. 09 Jul, 2009 3 commits