1. 05 3月, 2016 6 次提交
    • E
      qapi: Update docs to match recent generator changes · 9ee86b85
      Eric Blake 提交于
      Several commits have been changing the generator, but not updating
      the docs to match:
      - The implicit tag member is named "type", not "kind".  Screwed up in
      commit 39a18158.
      - Commit 9f08c8ec made list types lazy, and thereby dropped
      UserDefOneList if nothing explicitly uses the list type.
      - Commit 51e72bc1 switched the parameter order with 'name' occurring
      earlier.
      - Commit e65d89bf changed the layout of UserDefOneList.
      - Prefer the term 'member' over 'field'.
      - We now expose visit_type_FOO_members() for objects.
      - etc.
      
      Rework the examples to show slightly more output (we don't want to
      show too much; that's what the testsuite is for), and regenerate the
      output to match all recent changes.  Also, rearrange output to show
      .h files before .c (understanding the interface first often makes
      the implementation easier to follow).
      Reported-by: NMarc-André Lureau <marcandre.lureau@redhat.com>
      Signed-off-by: NEric Blake <eblake@redhat.com>
      Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
      Message-Id: <1457021813-10704-5-git-send-email-eblake@redhat.com>
      9ee86b85
    • E
      qapi-visit: Expose visit_type_FOO_members() · 4d91e911
      Eric Blake 提交于
      Dan Berrange reported a case where he needs to work with a
      QCryptoBlockOptions union type using the OptsVisitor, but only
      visit one of the branches of that type (the discriminator is not
      visited directly, but learned externally).  When things were
      boxed, it was easy: just visit the variant directly, which took
      care of both allocating the variant and visiting its members, then
      store that pointer in the union type.  But now that things are
      unboxed, we need a way to visit the members without allocation,
      done by exposing visit_type_FOO_members() to the user.
      
      Before the patch, we had quite a bit of code associated with
      object_members_seen to make sure that a declaration of the helper
      was in scope before any use of the function.  But now that the
      helper is public and declared in the header, the .c file no
      longer needs to worry about topological sorting (the helper is
      always in scope), which leads to some nice cleanups.
      Signed-off-by: NEric Blake <eblake@redhat.com>
      Message-Id: <1457021813-10704-4-git-send-email-eblake@redhat.com>
      Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
      4d91e911
    • E
      qapi: Rename 'fields' to 'members' in generated C code · c81200b0
      Eric Blake 提交于
      C types and JSON objects don't have fields, but members.  We
      shouldn't gratuitously invent terminology.  This patch is a
      strict renaming of static genarated functions, plus the naming
      of the dummy filler member for empty structs, before the next
      patch exposes some of that naming to the rest of the code base.
      Suggested-by: NMarkus Armbruster <armbru@redhat.com>
      Signed-off-by: NEric Blake <eblake@redhat.com>
      Message-Id: <1457021813-10704-3-git-send-email-eblake@redhat.com>
      Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
      c81200b0
    • E
      qapi: Rename 'fields' to 'members' in generator · 14f00c6c
      Eric Blake 提交于
      C types and JSON objects don't have fields, but members.  We
      shouldn't gratuitously invent terminology.  This patch is a
      strict renaming of generator code internals (including testsuite
      comments), before later patches rename C interfaces.
      
      No change to generated code with this patch.
      Suggested-by: NMarkus Armbruster <armbru@redhat.com>
      Signed-off-by: NEric Blake <eblake@redhat.com>
      Message-Id: <1457021813-10704-2-git-send-email-eblake@redhat.com>
      Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
      14f00c6c
    • E
      qapi-dealloc: Reduce use outside of generated code · 96a1616c
      Eric Blake 提交于
      No need to roll our own use of the dealloc visitors when we can
      just directly use the qapi_free_FOO() functions that do what we
      want in one line.
      
      In net.c, inline net_visit() into its remaining lone caller.
      
      After this patch, test-visitor-serialization.c is the only
      non-generated file that needs to use a dealloc visitor, because
      it is testing low level aspects of the visitor interface.
      Signed-off-by: NEric Blake <eblake@redhat.com>
      Message-Id: <1456262075-3311-2-git-send-email-eblake@redhat.com>
      Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
      96a1616c
    • D
      qmp-shell: fix pretty printing of JSON responses · e55250c6
      Daniel P. Berrange 提交于
      Pretty printing of JSON responses is important to be able to understand
      large responses from query commands in particular. Unfortunately this
      was broken during the addition of the verbose flag in
      
        commit 1ceca07e
        Author: John Snow <jsnow@redhat.com>
        Date:   Wed Apr 29 15:14:04 2015 -0400
      
          scripts: qmp-shell: Add verbose flag
      
      This is because that change turned the python data structure into a
      formatted JSON string before the pretty print was given it. So we're
      just pretty printing a string, which is a no-op.
      
      The original pretty printer would output python objects.
      
      (QEMU) query-chardev
      {   u'return': [   {   u'filename': u'vc',
                             u'frontend-open': False,
                             u'label': u'parallel0'},
                         {   u'filename': u'vc',
                             u'frontend-open': True,
                             u'label': u'serial0'},
                         {   u'filename': u'unix:/tmp/qemp,server',
                             u'frontend-open': True,
                             u'label': u'compat_monitor0'}]}
      
      This fixes the problem by switching to outputting pretty formatted JSON
      text instead. This has the added benefit that the pretty printed output
      is now valid JSON text. Due to the way the verbose flag was handled, the
      pretty printing now applies to the command sent, as well as its response:
      
      (QEMU) query-chardev
      {
          "execute": "query-chardev",
          "arguments": {}
      }
      {
          "return": [
              {
                  "frontend-open": false,
                  "label": "parallel0",
                  "filename": "vc"
              },
              {
                  "frontend-open": true,
                  "label": "serial0",
                  "filename": "vc"
              },
              {
                  "frontend-open": true,
                  "label": "compat_monitor0",
                  "filename": "unix:/tmp/qmp,server"
              }
          ]
      }
      Signed-off-by: NDaniel P. Berrange <berrange@redhat.com>
      Message-Id: <1456224706-1591-1-git-send-email-berrange@redhat.com>
      Tested-by: NKashyap Chamarthy <kchamart@redhat.com>
      Reviewed-by: NJohn Snow <jsnow@redhat.com>
      [Bonus fix: multiple -p now work]
      Signed-off-by: NMarkus Armbruster <armbru@redhat.com>
      e55250c6
  2. 04 3月, 2016 31 次提交
  3. 03 3月, 2016 3 次提交
    • P
      Merge remote-tracking branch 'remotes/amit-virtio-rng/tags/rng-for-2.6-1' into staging · 2d3b7c01
      Peter Maydell 提交于
      rng:
      - implement a request queue for rng-random so multiple guest requests
        don't result in vq buffers getting forgotten
      - remove unused request cancellation code
      - a VM with multiple vq buffers, when migrated, could get in a situation
        where not all buffers are handed back to the guest.  This is now
        fixed.
      
      # gpg: Signature made Thu 03 Mar 2016 12:18:54 GMT using RSA key ID 854083B6
      # gpg: Good signature from "Amit Shah <amit@amitshah.net>"
      # gpg:                 aka "Amit Shah <amit@kernel.org>"
      # gpg:                 aka "Amit Shah <amitshah@gmx.net>"
      
      * remotes/amit-virtio-rng/tags/rng-for-2.6-1:
        virtio-rng: ask for more data if queue is not fully drained
        rng: add request queue support to rng-random
        rng: move request queue cleanup from RngEgd to RngBackend
        rng: move request queue from RngEgd to RngBackend
        rng: remove the unused request cancellation code
        MAINTAINERS: Add an entry for the include/sysemu/rng*.h files
      Signed-off-by: NPeter Maydell <peter.maydell@linaro.org>
      2d3b7c01
    • L
      virtio-rng: ask for more data if queue is not fully drained · f8693c2c
      Ladi Prosek 提交于
      This commit effectively reverts:
      
        commit 4621c176
        Author: Amit Shah <amit.shah@redhat.com>
        Date:   Wed Nov 21 11:21:19 2012 +0530
      
        virtio-rng: remove extra request for entropy
      
      but instead of calling virtio_rng_process unconditionally, it
      first checks to see if the queue is empty as a little bit of
      optimization.
      Signed-off-by: NLadi Prosek <lprosek@redhat.com>
      Reviewed-by: NAmit Shah <amit.shah@redhat.com>
      Message-Id: <1456998514-19271-1-git-send-email-lprosek@redhat.com>
      Signed-off-by: NAmit Shah <amit.shah@redhat.com>
      f8693c2c
    • L
      rng: add request queue support to rng-random · 60253ed1
      Ladi Prosek 提交于
      Requests are now created in the RngBackend parent class and the
      code path is shared by both rng-egd and rng-random.
      
      This commit fixes the rng-random implementation which processed
      only one request at a time and simply discarded all but the most
      recent one. In the guest this manifested as delayed completion
      of reads from virtio-rng, i.e. a read was completed only after
      another read was issued.
      
      By switching rng-random to use the same request queue as rng-egd,
      the unsafe stack-based allocation of the entropy buffer is
      eliminated and replaced with g_malloc.
      Signed-off-by: NLadi Prosek <lprosek@redhat.com>
      Reviewed-by: NAmit Shah <amit.shah@redhat.com>
      Message-Id: <1456994238-9585-5-git-send-email-lprosek@redhat.com>
      Signed-off-by: NAmit Shah <amit.shah@redhat.com>
      60253ed1