1. 13 8月, 2016 1 次提交
  2. 12 7月, 2016 1 次提交
  3. 23 5月, 2016 1 次提交
  4. 18 5月, 2016 1 次提交
  5. 23 2月, 2016 1 次提交
    • P
      include: Clean up includes · 90ce6e26
      Peter Maydell 提交于
      Clean up includes so that osdep.h is included first and headers
      which it implies are not included manually.
      
      This commit was created with scripts/clean-includes.
      
      NB: If this commit breaks compilation for your out-of-tree
      patchseries or fork, then you need to make sure you add
      #include "qemu/osdep.h" to any new .c files that you have.
      Signed-off-by: NPeter Maydell <peter.maydell@linaro.org>
      Reviewed-by: NEric Blake <eblake@redhat.com>
      90ce6e26
  6. 10 2月, 2016 4 次提交
  7. 27 1月, 2016 6 次提交
    • I
      xen: make it possible to build without the Xen PV domain builder · 64a7ad6f
      Ian Campbell 提交于
      Until the previous patch this relied on xc_fd(), which was only
      implemented for Xen 4.0 and earlier.
      
      Given this wasn't working since Xen 4.0 I have marked this as disabled
      by default.
      
      Removing this support drops the use of a bunch of symbols from
      libxenctrl, specifically:
      
        - xc_domain_create
        - xc_domain_destroy
        - xc_domain_getinfo
        - xc_domain_max_vcpus
        - xc_domain_setmaxmem
        - xc_domain_unpause
        - xc_evtchn_alloc_unbound
        - xc_linux_build
      
      This is another step towards only using Xen libraries which provide a
      stable inteface.
      Signed-off-by: NIan Campbell <ian.campbell@citrix.com>
      Reviewed-by: NStefano Stabellini <stefano.stabellini@eu.citrix.com>
      Signed-off-by: NStefano Stabellini <stefano.stabellini@eu.citrix.com>
      64a7ad6f
    • I
      xen: domainbuild: reopen libxenctrl interface after forking for domain watcher. · 228df5c9
      Ian Campbell 提交于
      Using an existing libxenctrl handle after a fork was never
      particularly safe (especially if foreign mappings existed at the time
      of the fork) and the xc fd has been unavailable for many releases.
      
      Reopen the handle after fork and therefore do away with xc_fd().
      Signed-off-by: NIan Campbell <ian.campbell@citrix.com>
      Acked-by: NStefano Stabellini <stefano.stabellini@eu.citrix.com>
      Signed-off-by: NStefano Stabellini <stefano.stabellini@eu.citrix.com>
      228df5c9
    • I
      xen: Use stable library interfaces when they are available. · 5eeb39c2
      Ian Campbell 提交于
      In Xen 4.7 we are refactoring parts libxenctrl into a number of
      separate libraries which will provide backward and forward API and ABI
      compatiblity.
      
      Specifically libxenevtchn, libxengnttab and libxenforeignmemory.
      
      Previous patches have already laid the groundwork for using these by
      switching the existing compatibility shims to reflect the intefaces to
      these libraries.
      
      So all which remains is to update configure to detect the libraries
      and enable their use. Although they are notionally independent we take
      an all or nothing approach to the three libraries since they were
      added at the same time.
      
      The only non-obvious bit is that we now open a proper xenforeignmemory
      handle for xen_fmem instead of reusing the xen_xc handle.
      
      Build tested with 4.0 .. 4.6 (inclusive) and the patches targetting
      4.7 which adds these libraries.
      
      This uses CONFIG_XEN_CTRL_INTERFACE_VERSION == 471 to cover the
      introduction of these new interfaces.
      Signed-off-by: NIan Campbell <ian.campbell@citrix.com>
      Reviewed-by: NStefano Stabellini <stefano.stabellini@eu.citrix.com>
      Signed-off-by: NStefano Stabellini <stefano.stabellini@eu.citrix.com>
      5eeb39c2
    • I
      xen: Switch uses of xc_map_foreign_{pages,bulk} to use libxenforeignmemory API. · e0cb42ae
      Ian Campbell 提交于
      In Xen 4.7 we are refactoring parts libxenctrl into a number of
      separate libraries which will provide backward and forward API and ABI
      compatiblity.
      
      One such library will be libxenforeignmemory which provides access to
      privileged foreign mappings and which will provide an interface
      equivalent to xc_map_foreign_{pages,bulk}.
      
      The new xenforeignmemory_map() function behaves like
      xc_map_foreign_pages() when the err argument is NULL and like
      xc_map_foreign_bulk() when err is non-NULL, which maps into the shim
      here onto checking err == NULL and calling the appropriate old
      function.
      
      Note that xenforeignmemory_map() takes the number of pages before the
      arrays themselves, in order to support potentially future use of
      variable-length-arrays in the prototype (in the future, when Xen's
      baseline toolchain requirements are new enough to ensure VLAs are
      supported).
      
      In preparation for adding support for libxenforeignmemory add support
      to the <=4.0 and <=4.6 compat code in xen_common.h to allow us to
      switch to using the new API. These shims will disappear for versions
      of Xen which include libxenforeignmemory.
      
      Since libxenforeignmemory will have its own handle type but for <= 4.6
      the functionality is provided by using a libxenctrl handle we
      introduce a new global xen_fmem alongside the existing xen_xc. In fact
      we make xen_fmem a pointer to the existing xen_xc, which then works
      correctly with both <=4.0 (xc handle is an int) and <=4.6 (xc handle
      is a pointer). In the latter case xen_fmem is actually a double
      indirect pointer, but it all falls out in the wash.
      
      Unlike libxenctrl libxenforeignmemory has an explicit unmap function,
      rather than just specifying that munmap should be used, so the unmap
      paths are updated to use xenforeignmemory_unmap, which is a shim for
      munmap on these versions of xen. The mappings in xen-hvm.c do not
      appear to be unmapped (which makes sense for a qemu-dm process)
      
      In fb_disconnect this results in a change from simply mmap over the
      existing mapping (with an implicit munmap) to expliclty unmapping with
      xenforeignmemory_unmap and then mapping the required anonymous memory
      in the same hole. I don't think this is a problem since any other
      thread which was racily touching this region would already be running
      the risk of hitting the mapping halfway through the call. If this is
      thought to be a problem then we could consider adding an extra API to
      the libxenforeignmemory interface to replace a foreign mapping with
      anonymous shared memory, but I'd prefer not to.
      Signed-off-by: NIan Campbell <ian.campbell@citrix.com>
      Reviewed-by: NStefano Stabellini <stefano.stabellini@eu.citrix.com>
      Signed-off-by: NStefano Stabellini <stefano.stabellini@eu.citrix.com>
      e0cb42ae
    • I
      xen: Switch to libxengnttab interface for compat shims. · c1345a88
      Ian Campbell 提交于
      In Xen 4.7 we are refactoring parts libxenctrl into a number of
      separate libraries which will provide backward and forward API and ABI
      compatiblity.
      
      One such library will be libxengnttab which provides access to grant
      tables.
      
      In preparation for this switch the compatibility layer in xen_common.h
      (which support building with older versions of Xen) to use what will
      be the new library API. This means that the gnttab shim will disappear
      for versions of Xen which include libxengnttab.
      
      To simplify things for the <= 4.0.0 support we wrap the int fd in a
      malloc(sizeof int) such that the handle is always a pointer. This
      leads to less typedef headaches and the need for
      XC_HANDLER_INITIAL_VALUE etc for these interfaces.
      
      Note that this patch does not add any support for actually using
      libxengnttab, it just adjusts the existing shims.
      Signed-off-by: NIan Campbell <ian.campbell@citrix.com>
      Reviewed-by: NStefano Stabellini <stefano.stabellini@eu.citrix.com>
      Signed-off-by: NStefano Stabellini <stefano.stabellini@eu.citrix.com>
      c1345a88
    • I
      xen: Switch to libxenevtchn interface for compat shims. · a2db2a1e
      Ian Campbell 提交于
      In Xen 4.7 we are refactoring parts libxenctrl into a number of
      separate libraries which will provide backward and forward API and ABI
      compatiblity.
      
      One such library will be libxenevtchn which provides access to event
      channels.
      
      In preparation for this switch the compatibility layer in xen_common.h
      (which support building with older versions of Xen) to use what will
      be the new library API. This means that the evtchn shim will disappear
      for versions of Xen which include libxenevtchn.
      
      To simplify things for the <= 4.0.0 support we wrap the int fd in a
      malloc(sizeof int) such that the handle is always a pointer. This
      leads to less typedef headaches and the need for
      XC_HANDLER_INITIAL_VALUE etc for these interfaces.
      
      Note that this patch does not add any support for actually using
      libxenevtchn, it just adjusts the existing shims.
      
      Note that xc_evtchn_alloc_unbound functionality remains in libxenctrl,
      since that functionality is not exposed by /dev/xen/evtchn.
      Signed-off-by: NIan Campbell <ian.campbell@citrix.com>
      Reviewed-by: NStefano Stabellini <stefano.stabellini@eu.citrix.com>
      Signed-off-by: NStefano Stabellini <stefano.stabellini@eu.citrix.com>
      a2db2a1e
  8. 14 11月, 2015 1 次提交
  9. 10 9月, 2015 2 次提交
  10. 08 7月, 2015 1 次提交
  11. 26 1月, 2015 1 次提交
  12. 20 1月, 2015 1 次提交
  13. 30 10月, 2014 1 次提交
  14. 08 5月, 2014 1 次提交
  15. 09 4月, 2013 1 次提交
    • P
      hw: move headers to include/ · 0d09e41a
      Paolo Bonzini 提交于
      Many of these should be cleaned up with proper qdev-/QOM-ification.
      Right now there are many catch-all headers in include/hw/ARCH depending
      on cpu.h, and this makes it necessary to compile these files per-target.
      However, fixing this does not belong in these patches.
      Signed-off-by: NPaolo Bonzini <pbonzini@redhat.com>
      0d09e41a
  16. 01 3月, 2013 1 次提交
    • P
      hw: include hw header files with full paths · 83c9f4ca
      Paolo Bonzini 提交于
      Done with this script:
      
      cd hw
      for i in `find . -name '*.h' | sed 's/^..//'`; do
        echo '\,^#.*include.*["<]'$i'[">], s,'$i',hw/&,'
      done | sed -i -f - `find . -type f`
      
      This is so that paths remain valid as files are moved.
      
      Instead, files in hw/dataplane are referenced with the relative path.
      We know they are not going to move to include/, and they are the only
      include files that are in subdirectories _and_ move.
      Signed-off-by: NPaolo Bonzini <pbonzini@redhat.com>
      83c9f4ca
  17. 19 12月, 2012 1 次提交
  18. 22 6月, 2012 1 次提交
  19. 21 6月, 2012 1 次提交
  20. 17 5月, 2012 1 次提交
  21. 18 4月, 2012 1 次提交
  22. 17 7月, 2011 1 次提交
    • S
      xen_console: support the new extended xenstore protocol · 0f51726a
      Stefano Stabellini 提交于
      Since CS 21994 on xen-unstable.hg and CS
      466608f3a32e1f9808acdf832a5843af37e5fcec on qemu-xen-unstable.git, few
      changes have been introduced to the PV console xenstore protocol, as
      described by the document docs/misc/console.txt under xen-unstable.hg.
      
      From the Qemu point of view, very few modifications are needed to
      correctly support the protocol: read from xenstore the "output" node
      that tell us what the output of the PV console is going to be.
      In case the output is a tty, write to xenstore the device name.
      
      Changes in v2:
      
      - fix error paths: free malloc'ed strings and close the xenstore
      connection before returning;
      
      - remove useless snprintf in xenstore_store_pv_console_info if i == 0.
      
      Changes in v3:
      
      - replace xs_daemon_open/xs_daemon_close with xs_open/xs_close.
      
      Changes in v4:
      
      - add a compatibility implementation of xs_open/xs_close.
      
      Changes in v5:
      
      - fix code style.
      
      [agraf] fix build error due to missing stub
      Signed-off-by: NStefano Stabellini <stefano.stabellini@eu.citrix.com>
      Signed-off-by: NAlexander Graf <agraf@suse.de>
      0f51726a
  23. 19 6月, 2011 1 次提交
  24. 08 5月, 2011 3 次提交
  25. 12 9月, 2009 1 次提交
  26. 22 4月, 2009 1 次提交