1. 01 10月, 2018 3 次提交
  2. 25 9月, 2018 1 次提交
  3. 31 8月, 2018 2 次提交
  4. 29 8月, 2018 3 次提交
    • E
      qapi: Add comments to aid debugging generated introspection · 8c643361
      Eric Blake 提交于
      We consciously chose in commit 1a9a507b to hide QAPI type names
      from the introspection output on the wire, but added a command
      line option -u to unmask the type name when doing a debug build.
      The unmask option still remains useful to some other forms of
      automated analysis, so it will not be removed; however, when it
      is not in use, the generated .c file can be hard to read.  At
      the time when we first introduced masking, the generated file
      consisted only of a monolithic C string, so there was no clean
      way to inject any comments.
      
      Later, in commit 7d0f982b, we switched the generation to output
      a QLit object, in part to make it easier for future addition of
      conditional compilation.  In fact, commit d626b6c1 took advantage
      of this by passing a tuple instead of a bare object for encoding
      the output of conditionals.  By extending that tuple, we can now
      interject strategic comments.
      
      For now, type name debug aid comments are only output once per
      meta-type, rather than at all uses of the number used to encode
      the type within the introspection data.  But this is still a lot
      more convenient than having to regenerate the file with the
      unmask operation temporarily turned on - merely search the
      generated file for '"NNN" =' to learn the corresponding source
      name and associated definition of type NNN.
      
      The generated qapi-introspect.c changes only with the addition
      of comments, such as:
      
      | @@ -14755,6 +15240,7 @@
      |          { "name", QLIT_QSTR("[485]"), },
      |          {}
      |      })),
      | +    /* "485" = QCryptoBlockInfoLUKSSlot */
      |      QLIT_QDICT(((QLitDictEntry[]) {
      |          { "members", QLIT_QLIST(((QLitObject[]) {
      |              QLIT_QDICT(((QLitDictEntry[]) {
      Signed-off-by: NEric Blake <eblake@redhat.com>
      Message-Id: <20180827213943.33524-3-eblake@redhat.com>
      Reviewed-by: NMarkus Armbruster <armbru@redhat.com>
      [Rebased, update to qapi-code-gen.txt corrected]
      Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
      8c643361
    • M
      qapi: Update docs for generator changes since commit 9ee86b85 · 913b5e28
      Markus Armbruster 提交于
      Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
      Message-Id: <20180828120736.32323-3-armbru@redhat.com>
      Reviewed-by: NEric Blake <eblake@redhat.com>
      913b5e28
    • P
      qapi: Drop qapi_event_send_FOO()'s Error ** argument · 3ab72385
      Peter Xu 提交于
      The generated qapi_event_send_FOO() take an Error ** argument.  They
      can't actually fail, because all they do with the argument is passing it
      to functions that can't fail: the QObject output visitor, and the
      @qmp_emit callback, which is either monitor_qapi_event_queue() or
      event_test_emit().
      
      Drop the argument, and pass &error_abort to the QObject output visitor
      and @qmp_emit instead.
      Suggested-by: NEric Blake <eblake@redhat.com>
      Suggested-by: NMarkus Armbruster <armbru@redhat.com>
      Signed-off-by: NPeter Xu <peterx@redhat.com>
      Message-Id: <20180815133747.25032-4-peterx@redhat.com>
      Reviewed-by: NMarkus Armbruster <armbru@redhat.com>
      [Commit message rewritten, update to qapi-code-gen.txt corrected]
      Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
      3ab72385
  5. 25 8月, 2018 1 次提交
    • M
      docs/interop/qmp-spec: How to force known good parser state · 72e9e569
      Markus Armbruster 提交于
      Section "QGA Synchronization" specifies that sending "a raw 0xFF
      sentinel byte" makes the server "reset its state and discard all
      pending data prior to the sentinel."  What actually happens there is a
      lexical error, which will produce one or more error responses.
      Moreover, it's not specific to QGA.
      
      Create new section "Forcing the JSON parser into known-good state" to
      document the technique properly.  Rewrite section "QGA
      Synchronization" to document just the other direction, i.e. command
      guest-sync-delimited.
      
      Section "Protocol Specification" mentions "synchronization bytes
      (documented below)".  Delete that.
      
      While there, fix it not to claim '"Server" is QEMU itself', but
      '"Server" is either QEMU or the QEMU Guest Agent'.
      Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
      Reviewed-by: NEric Blake <eblake@redhat.com>
      Message-Id: <20180823164025.12553-2-armbru@redhat.com>
      72e9e569
  6. 22 8月, 2018 1 次提交
  7. 21 8月, 2018 1 次提交
  8. 20 8月, 2018 1 次提交
  9. 17 8月, 2018 1 次提交
    • D
      docs: add guidance on configuring CPU models for x86 · 2544e9e4
      Daniel P. Berrangé 提交于
      With the recent set of CPU hardware vulnerabilities on x86, it is
      increasingly difficult to understand which CPU configurations are
      good to use and what flaws they might be vulnerable to.
      
      This doc attempts to help management applications and administrators in
      picking sensible CPU configuration on x86 hosts. It outlines which of
      the named CPU models are good choices, and describes which extra CPU
      flags should be enabled to allow the guest to mitigate hardware flaws.
      Signed-off-by: NDaniel P. Berrangé <berrange@redhat.com>
      Message-Id: <20180627160103.13634-1-berrange@redhat.com>
      Signed-off-by: NEduardo Habkost <ehabkost@redhat.com>
      2544e9e4
  10. 15 8月, 2018 1 次提交
  11. 10 8月, 2018 1 次提交
  12. 30 7月, 2018 1 次提交
  13. 19 7月, 2018 1 次提交
  14. 13 7月, 2018 1 次提交
  15. 05 7月, 2018 3 次提交
  16. 04 7月, 2018 5 次提交
    • M
      qapi: Polish command flags documentation in qapi-code-gen.txt · 153d73f3
      Markus Armbruster 提交于
      Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
      Reviewed-by: NEric Blake <eblake@redhat.com>
      Message-Id: <20180703085358.13941-33-armbru@redhat.com>
      153d73f3
    • M
      qmp: Redo how the client requests out-of-band execution · 00ecec15
      Markus Armbruster 提交于
      Commit cf869d53 "qmp: support out-of-band (oob) execution" added a
      general mechanism for command-independent arguments just for an
      out-of-band flag:
      
          The "control" key is introduced to store this extra flag.  "control"
          field is used to store arguments that are shared by all the commands,
          rather than command specific arguments.  Let "run-oob" be the first.
      
      However, it failed to reject unknown members of "control".  For
      instance, in QMP command
      
          {"execute": "query-name", "id": 42, "control": {"crap": true}}
      
      "crap" gets silently ignored.
      
      Instead of fixing this, revert the general "control" mechanism
      (because YAGNI), and do it the way I initially proposed, with key
      "exec-oob".  Simpler code, simpler interface.
      
      An out-of-band command
      
          {"execute": "migrate-pause", "id": 42, "control": {"run-oob": true}}
      
      becomes
      
          {"exec-oob": "migrate-pause", "id": 42}
      Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
      Reviewed-by: NEric Blake <eblake@redhat.com>
      Message-Id: <20180703085358.13941-13-armbru@redhat.com>
      [Commit message typo fixed]
      00ecec15
    • M
      qmp: Make "id" optional again even in "oob" monitors · 80cd93bd
      Markus Armbruster 提交于
      Commit cf869d53 "qmp: support out-of-band (oob) execution" made
      "id" mandatory for all commands when the client accepted capability
      "oob".  This is rather onerous when you play with QMP by hand, and
      unnecessarily so: only out-of-band commands need an ID for reliable
      matching of response to command.
      
      Revert that part of commit cf869d53 for now, but have documentation
      advise on the need to use "id" with out-of-band commands.
      Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
      Message-Id: <20180703085358.13941-8-armbru@redhat.com>
      Reviewed-by: NDaniel P. Berrangé <berrange@redhat.com>
      Reviewed-by: NEric Blake <eblake@redhat.com>
      80cd93bd
    • M
      docs/interop/qmp: Improve OOB documentation · 71696cc6
      Markus Armbruster 提交于
      OOB documentation is spread over qmp-spec.txt sections 2.2.1
      Capabilities and 2.3 Issuing Commands.  The amount of detail is a bit
      distracting there.  Move the meat of the matter to new section 2.3.1
      Out of band execution.
      
      Throw in a few other improvements while there:
      
      * 2.2 Server Greeting: Drop advice to search entire capabilities
        array; should be obvious.
      
      * 3. QMP Examples
      
        - 3.1 Server Greeting: Update greeting to the one we expect for the
          release.  Now shows capability "oob".  Update qmp-intro.txt
          likewise.
      
        - 3.2 Capabilities negotiation: Show client accepting capability
          "oob".
      
        - 3.7 Out-of-band execution: New.
      Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
      Reviewed-by: NEric Blake <eblake@redhat.com>
      Message-Id: <20180703085358.13941-4-armbru@redhat.com>
      [Whitespace tidied up]
      71696cc6
    • M
      qapi: add 'if' to top-level expressions · 967c8851
      Marc-André Lureau 提交于
      Accept 'if' key in top-level elements, accepted as string or list of
      string type. The following patches will modify the test visitor to
      check the value is correctly saved, and generate #if/#endif code (as a
      single #if/endif line or a series for a list).
      
      Example of 'if' key:
      { 'struct': 'TestIfStruct', 'data': { 'foo': 'int' },
        'if': 'defined(TEST_IF_STRUCT)' }
      
      The generated code is for now *unconditional*. Later patches generate
      the conditionals.
      Signed-off-by: NMarc-André Lureau <marcandre.lureau@redhat.com>
      Reviewed-by: NMarkus Armbruster <armbru@redhat.com>
      Message-Id: <20180703155648.11933-2-marcandre.lureau@redhat.com>
      [Commit message and Documentation improved]
      Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
      967c8851
  17. 03 7月, 2018 1 次提交
  18. 30 6月, 2018 1 次提交
  19. 29 6月, 2018 1 次提交
  20. 27 6月, 2018 1 次提交
  21. 22 6月, 2018 1 次提交
    • A
      qapi: allow empty branches in flat unions · 800877bb
      Anton Nefedov 提交于
      It often happens that just a few discriminator values imply extra data in
      a flat union. Existing checks did not make possible to leave other values
      uncovered. Such cases had to be worked around by either stating a dummy
      (empty) type or introducing another (subset) discriminator enumeration.
      
      Both options create redundant entities in qapi files for little profit.
      
      With this patch it is not necessary anymore to add designated union
      fields for every possible value of a discriminator enumeration.
      Signed-off-by: NAnton Nefedov <anton.nefedov@virtuozzo.com>
      Message-Id: <1529311206-76847-2-git-send-email-anton.nefedov@virtuozzo.com>
      Reviewed-by: NMarkus Armbruster <armbru@redhat.com>
      Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
      800877bb
  22. 21 6月, 2018 1 次提交
  23. 16 6月, 2018 5 次提交
    • C
      Add functional/acceptance tests infrastructure · c3d7e8c9
      Cleber Rosa 提交于
      This patch adds the very minimum infrastructure necessary for writing
      and running functional/acceptance tests, including:
      
       * Documentation
       * The avocado_qemu.Test base test class
       * One example tests (version.py)
      
      Additional functionality is expected to be added along the tests that
      require them.
      Signed-off-by: NCleber Rosa <crosa@redhat.com>
      Message-Id: <20180530184156.15634-2-crosa@redhat.com>
      Reviewed-by: NPhilippe Mathieu-Daudé <f4bug@amsat.org>
      Tested-by: NPhilippe Mathieu-Daudé <f4bug@amsat.org>
      [ehabkost: fix typo on testing.rst]
      Reviewed-by: NStefan Hajnoczi <stefanha@redhat.com>
      Signed-off-by: NEduardo Habkost <ehabkost@redhat.com>
      c3d7e8c9
    • E
      tcg: remove tb_lock · 0ac20318
      Emilio G. Cota 提交于
      Use mmap_lock in user-mode to protect TCG state and the page descriptors.
      In !user-mode, each vCPU has its own TCG state, so no locks needed.
      Per-page locks are used to protect the page descriptors.
      
      Per-TB locks are used in both modes to protect TB jumps.
      
      Some notes:
      
      - tb_lock is removed from notdirty_mem_write by passing a
        locked page_collection to tb_invalidate_phys_page_fast.
      
      - tcg_tb_lookup/remove/insert/etc have their own internal lock(s),
        so there is no need to further serialize access to them.
      
      - do_tb_flush is run in a safe async context, meaning no other
        vCPU threads are running. Therefore acquiring mmap_lock there
        is just to please tools such as thread sanitizer.
      
      - Not visible in the diff, but tb_invalidate_phys_page already
        has an assert_memory_lock.
      
      - cpu_io_recompile is !user-only, so no mmap_lock there.
      
      - Added mmap_unlock()'s before all siglongjmp's that could
        be called in user-mode while mmap_lock is held.
        + Added an assert for !have_mmap_lock() after returning from
          the longjmp in cpu_exec, just like we do in cpu_exec_step_atomic.
      
      Performance numbers before/after:
      
      Host: AMD Opteron(tm) Processor 6376
      
                       ubuntu 17.04 ppc64 bootup+shutdown time
      
        700 +-+--+----+------+------------+-----------+------------*--+-+
            |    +    +      +            +           +           *B    |
            |         before ***B***                            ** *    |
            |tb lock removal ###D###                         ***        |
        600 +-+                                           ***         +-+
            |                                           **         #    |
            |                                        *B*          #D    |
            |                                     *** *         ##      |
        500 +-+                                ***           ###      +-+
            |                             * ***           ###           |
            |                            *B*          # ##              |
            |                          ** *          #D#                |
        400 +-+                      **            ##                 +-+
            |                      **           ###                     |
            |                    **           ##                        |
            |                  **         # ##                          |
        300 +-+  *           B*          #D#                          +-+
            |    B         ***        ###                               |
            |    *       **       ####                                  |
            |     *   ***      ###                                      |
        200 +-+   B  *B     #D#                                       +-+
            |     #B* *   ## #                                          |
            |     #*    ##                                              |
            |    + D##D#     +            +           +            +    |
        100 +-+--+----+------+------------+-----------+------------+--+-+
                 1    8      16      Guest CPUs       48           64
        png: https://imgur.com/HwmBHXe
      
                    debian jessie aarch64 bootup+shutdown time
      
        90 +-+--+-----+-----+------------+------------+------------+--+-+
           |    +     +     +            +            +            +    |
           |         before ***B***                                B    |
        80 +tb lock removal ###D###                              **D  +-+
           |                                                   **###    |
           |                                                 **##       |
        70 +-+                                             ** #       +-+
           |                                             ** ##          |
           |                                           **  #            |
        60 +-+                                       *B  ##           +-+
           |                                       **  ##               |
           |                                    ***  #D                 |
        50 +-+                               ***   ##                 +-+
           |                             * **   ###                     |
           |                           **B*  ###                        |
        40 +-+                     ****  # ##                         +-+
           |                   ****     #D#                             |
           |             ***B**      ###                                |
        30 +-+    B***B**        ####                                 +-+
           |    B *   *     # ###                                       |
           |     B       ###D#                                          |
        20 +-+   D  ##D##                                             +-+
           |      D#                                                    |
           |    +     +     +            +            +            +    |
        10 +-+--+-----+-----+------------+------------+------------+--+-+
                1     8     16      Guest CPUs        48           64
        png: https://imgur.com/iGpGFtv
      
      The gains are high for 4-8 CPUs. Beyond that point, however, unrelated
      lock contention significantly hurts scalability.
      Reviewed-by: NRichard Henderson <richard.henderson@linaro.org>
      Reviewed-by: NAlex Bennée <alex.bennee@linaro.org>
      Signed-off-by: NEmilio G. Cota <cota@braap.org>
      Signed-off-by: NRichard Henderson <richard.henderson@linaro.org>
      0ac20318
    • E
      translate-all: protect TB jumps with a per-destination-TB lock · 194125e3
      Emilio G. Cota 提交于
      This applies to both user-mode and !user-mode emulation.
      
      Instead of relying on a global lock, protect the list of incoming
      jumps with tb->jmp_lock. This lock also protects tb->cflags,
      so update all tb->cflags readers outside tb->jmp_lock to use
      atomic reads via tb_cflags().
      
      In order to find the destination TB (and therefore its jmp_lock)
      from the origin TB, we introduce tb->jmp_dest[].
      
      I considered not using a linked list of jumps, which simplifies
      code and makes the struct smaller. However, it unnecessarily increases
      memory usage, which results in a performance decrease. See for
      instance these numbers booting+shutting down debian-arm:
                            Time (s)  Rel. err (%)  Abs. err (s)  Rel. slowdown (%)
      ------------------------------------------------------------------------------
       before                  20.88          0.74      0.154512                 0.
       after                   20.81          0.38      0.079078        -0.33524904
       GTree                   21.02          0.28      0.058856         0.67049808
       GHashTable + xxhash     21.63          1.08      0.233604          3.5919540
      
      Using a hash table or a binary tree to keep track of the jumps
      doesn't really pay off, not only due to the increased memory usage,
      but also because most TBs have only 0 or 1 jumps to them. The maximum
      number of jumps when booting debian-arm that I measured is 35, but
      as we can see in the histogram below a TB with that many incoming jumps
      is extremely rare; the average TB has 0.80 incoming jumps.
      
      n_jumps: 379208; avg jumps/tb: 0.801099
      dist: [0.0,1.0)|▄█▁▁▁▁▁▁▁▁▁▁▁ ▁▁▁▁▁▁ ▁▁▁  ▁▁▁     ▁|[34.0,35.0]
      Reviewed-by: NRichard Henderson <richard.henderson@linaro.org>
      Signed-off-by: NEmilio G. Cota <cota@braap.org>
      Signed-off-by: NRichard Henderson <richard.henderson@linaro.org>
      194125e3
    • E
      translate-all: discard TB when tb_link_page returns an existing matching TB · 95590e24
      Emilio G. Cota 提交于
      Use the recently-gained QHT feature of returning the matching TB if it
      already exists. This allows us to get rid of the lookup we perform
      right after acquiring tb_lock.
      Suggested-by: NRichard Henderson <richard.henderson@linaro.org>
      Reviewed-by: NRichard Henderson <richard.henderson@linaro.org>
      Signed-off-by: NEmilio G. Cota <cota@braap.org>
      Signed-off-by: NRichard Henderson <richard.henderson@linaro.org>
      95590e24
    • E
      translate-all: make l1_map lockless · 78722ed0
      Emilio G. Cota 提交于
      Groundwork for supporting parallel TCG generation.
      
      We never remove entries from the radix tree, so we can use cmpxchg
      to implement lockless insertions.
      Reviewed-by: NRichard Henderson <richard.henderson@linaro.org>
      Reviewed-by: NAlex Bennée <alex.bennee@linaro.org>
      Signed-off-by: NEmilio G. Cota <cota@braap.org>
      Signed-off-by: NRichard Henderson <richard.henderson@linaro.org>
      78722ed0
  24. 15 6月, 2018 1 次提交
  25. 12 6月, 2018 1 次提交