1. 28 6月, 2012 9 次提交
    • D
      usb-ohci: Use universal DMA helper functions · 9ac6a217
      David Gibson 提交于
      The OHCI device emulation can provide both PCI and SysBus OHCI
      implementations.  Because of this, it was not previously converted to
      use the PCI DMA helper functions.
      
      This patch converts it to use the new universal DMA helper functions.
      In the PCI case, it obtains its DMAContext from pci_dma_context(), in
      the SysBus case, it uses NULL - i.e. assumes for now that there will
      be no IOMMU translation for a SysBus OHCI.
      
      Cc: Gerd Hoffmann <kraxel@redhat.com>
      Cc: Michael S. Tsirkin <mst@redhat.com>
      Signed-off-by: NDavid Gibson <david@gibson.dropbear.id.au>
      Signed-off-by: NBenjamin Herrenschmidt <benh@kernel.crashing.org>
      Signed-off-by: NAnthony Liguori <aliguori@us.ibm.com>
      9ac6a217
    • D
      iommu: Add universal DMA helper functions · d86a77f8
      David Gibson 提交于
      Not that long ago, every device implementation using DMA directly
      accessed guest memory using cpu_physical_memory_*().  This meant that
      adding support for a guest visible IOMMU would require changing every
      one of these devices to go through IOMMU translation.
      
      Shortly before qemu 1.0, I made a start on fixing this by providing
      helper functions for PCI DMA.  These are currently just stubs which
      call the direct access functions, but mean that an IOMMU can be
      implemented in one place, rather than for every PCI device.
      
      Clearly, this doesn't help for non PCI devices, which could also be
      IOMMU translated on some platforms.  It is also problematic for the
      devices which have both PCI and non-PCI version (e.g. OHCI, AHCI) - we
      cannot use the the pci_dma_*() functions, because they assume the
      presence of a PCIDevice, but we don't want to have to check between
      pci_dma_*() and cpu_physical_memory_*() every time we do a DMA in the
      device code.
      
      This patch makes the first step on addressing both these problems, by
      introducing new (stub) dma helper functions which can be used for any
      DMA capable device.
      
      These dma functions take a DMAContext *, a new (currently empty)
      variable describing the DMA address space in which the operation is to
      take place.  NULL indicates untranslated DMA directly into guest
      physical address space.  The intention is that in future non-NULL
      values will given information about any necessary IOMMU translation.
      
      DMA using devices must obtain a DMAContext (or, potentially, contexts)
      from their bus or platform.  For now this patch just converts the PCI
      wrappers to be implemented in terms of the universal wrappers,
      converting other drivers can take place over time.
      
      Cc: Michael S. Tsirkin <mst@redhat.com>
      Cc: Eduard - Gabriel Munteanu <eduard.munteanu@linux360.ro>
      Cc: Richard Henderson <rth@twiddle.net>
      Signed-off-by: NDavid Gibson <david@gibson.dropbear.id.au>
      Signed-off-by: NBenjamin Herrenschmidt <benh@kernel.crashing.org>
      Signed-off-by: NAnthony Liguori <aliguori@us.ibm.com>
      d86a77f8
    • D
      Better support for dma_addr_t variables · 8292f75a
      David Gibson 提交于
      A while back, we introduced the dma_addr_t type, which is supposed to
      be used for bus visible memory addresses.  At present, this is an
      alias for target_phys_addr_t, but this will change when we eventually
      add support for guest visible IOMMUs.
      
      There are some instances of target_phys_addr_t in the code now which
      should really be dma_addr_t, but can't be trivially converted due to
      missing features which this patch corrects.
      
       * We add DMA_ADDR_BITS analagous to TARGET_PHYS_ADDR_BITS.  This is
         important where we need to make a compile-time (#if) based on the
         size of dma_addr_t.
      
       * We add a new helper macro to create device properties which take a
         dma_addr_t, currently an alias to DEFINE_PROP_TADDR().
      Signed-off-by: NDavid Gibson <david@gibson.dropbear.id.au>
      Signed-off-by: NBenjamin Herrenschmidt <benh@kernel.crashing.org>
      Signed-off-by: NAnthony Liguori <aliguori@us.ibm.com>
      8292f75a
    • J
      rtl8139: validate rx ring before receiving packets · fcce6fd2
      Jason Wang 提交于
      Commit ff71f2e8 prevent the possible
      crash during initialization of linux driver by checking the operating
      mode.This seems too strict as:
      
      - the real card could still work in mode other than normal
      - some buggy driver who does not set correct opmode after eeprom
       access
      
      So, considering rx ring address were reset to zero (which could be
      safely trated as an address not intened to DMA to), in order to
      both letting old guest work and preventing the unexpected DMA to
      guest, we can forbid packet receiving when rx ring address is zero.
      Tested-by: NAvi Kivity <avi@redhat.com>
      Signed-off-by: NJason Wang <jasowang@redhat.com>
      Signed-off-by: NAnthony Liguori <aliguori@us.ibm.com>
      fcce6fd2
    • D
      Remove support for non-threaded VNC server · 2624bab8
      Daniel P. Berrange 提交于
      QEMU now has a fundamental requirement for pthreads, so there
      is no compelling reason to retain support for the non-threaded
      VNC server. Remove the --{enable,disable}-vnc-thread configure
      arguments, and all CONFIG_VNC_THREAD conditionals
      Signed-off-by: NDaniel P. Berrange <berrange@redhat.com>
      Signed-off-by: NAnthony Liguori <aliguori@us.ibm.com>
      2624bab8
    • A
      configure: Assure existence of linux-headers/ build directory · a307beb6
      Andreas Färber 提交于
      Commit ec5b06d7 (configure: ensure directory exists when creating symlinks)
      moved the creation of directories into the symlink() function but forgot
      the case where no symlink is created.
      
      This leads to build errors on arm Linux due to -I../linux-headers.
      
      Unbreak the build on arm Linux by reverting part of that commit.
      Signed-off-by: NAndreas Färber <afaerber@suse.de>
      Signed-off-by: NAnthony Liguori <aliguori@us.ibm.com>
      a307beb6
    • P
      Makefile.target: Update clean command to clean hw/ directory · b54fa7dd
      Peter Maydell 提交于
      Now we create object files in a hierarchy under hw/, so the
      'clean' target must also be updated to delete those object files.
      Rather than using a manual list of subdirectories which will
      easily drift out of date, we just delete all .o and .d files
      in the target directory hierarchy.
      Signed-off-by: NPeter Maydell <peter.maydell@linaro.org>
      Signed-off-by: NAnthony Liguori <aliguori@us.ibm.com>
      b54fa7dd
    • A
      qtest: fix infinite loop when QEMU aborts abruptly · 039380a8
      Anthony Liguori 提交于
      From Markus:
      
      Makes "make check" hang:
      
          QTEST_QEMU_BINARY=x86_64-softmmu/qemu-system-x86_64 gtester -k --verbose -m=quick tests/crash-test tests/rtc-test
          TEST: tests/crash-test... (pid=972)
          qemu-system-x86_64: Device needs media, but drive is empty
      [Nothing happens, wait a while, then hit ^C]
          make: *** [check-qtest-x86_64] Interrupt
      
      This was due to the fact that we weren't checked for errors when
      reading from the QMP socket.  This patch adds appropriate error
      checking.
      Reported-by: NMarkus Armbruster <armbru@redhat.com>
      Signed-off-by: NAnthony Liguori <aliguori@us.ibm.com>
      039380a8
    • A
      qdev: fix use-after-free in the error path of qdev_init_nofail · 7de3abe5
      Anthony Liguori 提交于
      From Markus:
      
      Before:
      
          $ qemu-system-x86_64 -display none -drive if=ide
          qemu-system-x86_64: Device needs media, but drive is empty
          qemu-system-x86_64: Initialization of device ide-hd failed
          [Exit 1 ]
      
      After:
      
          $ qemu-system-x86_64 -display none -drive if=ide
          qemu-system-x86_64: Device needs media, but drive is empty
          Segmentation fault (core dumped)
          [Exit 139 (SIGSEGV)]
      
      This error always existed as qdev_init() frees the object.  But QOM
      goes a bit further and purposefully sets the class pointer to NULL to
      help find use-after-free.  It worked :-)
      
      Cc: Andreas Faerber <afaerber@suse.de>
      Reported-by: NMarkus Armbruster <armbru@redhat.com>
      Signed-off-by: NAnthony Liguori <aliguori@us.ibm.com>
      7de3abe5
  2. 27 6月, 2012 9 次提交
  3. 25 6月, 2012 2 次提交
  4. 24 6月, 2012 20 次提交