1. 31 8月, 2018 1 次提交
  2. 27 11月, 2017 1 次提交
    • K
      QAPI & interop: Clarify events emitted by 'block-job-cancel' · c117bb14
      Kashyap Chamarthy 提交于
      When you cancel an in-progress 'mirror' job (or "active `block-commit`")
      with QMP `block-job-cancel`, it emits the event: BLOCK_JOB_CANCELLED.
      However, when `block-job-cancel` is issued *after* `drive-mirror` has
      indicated (via the event BLOCK_JOB_READY) that the source and
      destination have reached synchronization:
      
          [...] # Snip `drive-mirror` invocation & outputs
          {
            "execute":"block-job-cancel",
            "arguments":{
              "device":"virtio0"
            }
          }
      
          {"return": {}}
      
      It (`block-job-cancel`) will counterintuitively emit the event
      'BLOCK_JOB_COMPLETED':
      
          {
            "timestamp":{
              "seconds":1510678024,
              "microseconds":526240
            },
            "event":"BLOCK_JOB_COMPLETED",
            "data":{
              "device":"virtio0",
              "len":41126400,
              "offset":41126400,
              "speed":0,
              "type":"mirror"
            }
          }
      
      But this is expected behaviour, where the _COMPLETED event indicates
      that synchronization has successfully ended (and the destination now has
      a point-in-time copy, which is at the time of cancel).
      
      So add a small note to this effect in 'block-core.json'.  While at it,
      also update the "Live disk synchronization -- drive-mirror and
      blockdev-mirror" section in 'live-block-operations.rst'.
      
      (Thanks: Max Reitz for reminding me of this caveat on IRC.)
      Signed-off-by: NKashyap Chamarthy <kchamart@redhat.com>
      Reviewed-by: NEric Blake <eblake@redhat.com>
      Signed-off-by: NKevin Wolf <kwolf@redhat.com>
      c117bb14
  3. 18 7月, 2017 1 次提交
    • K
      live-block-ops.txt: Rename, rewrite, and improve it · 8508eee7
      Kashyap Chamarthy 提交于
      This patch documents (including their QMP invocations) all the four
      major kinds of live block operations:
      
        - `block-stream`
        - `block-commit`
        - `drive-mirror` (& `blockdev-mirror`)
        - `drive-backup` (& `blockdev-backup`)
      
      Things considered while writing this document:
      
        - Use reStructuredText as markup language (with the goal of generating
          the HTML output using the Sphinx Documentation Generator).  It is
          gentler on the eye, and can be trivially converted to different
          formats.  (Another reason: upstream QEMU is considering to switch to
          Sphinx, which uses reStructuredText as its markup language.)
      
        - Raw QMP JSON output vs. 'qmp-shell'.  I debated with myself whether
          to only show raw QMP JSON output (as that is the canonical
          representation), or use 'qmp-shell', which takes key-value pairs.  I
          settled on the approach of: for the first occurrence of a command,
          use raw JSON; for subsequent occurrences, use 'qmp-shell', with an
          occasional exception.
      
        - Usage of `-blockdev` command-line.
      
        - Usage of 'node-name' vs. file path to refer to disks.  While we have
          `blockdev-{mirror, backup}` as 'node-name'-alternatives for
          `drive-{mirror, backup}`, the `block-commit` command still operates
          on file names for parameters 'base' and 'top'.  So I added a caveat
          at the beginning to that effect.
      
          Refer this related thread that I started (where I learnt
          `block-stream` was recently reworked to accept 'node-name' for 'top'
          and 'base' parameters):
          https://lists.nongnu.org/archive/html/qemu-devel/2017-05/msg06466.html
          "[RFC] Making 'block-stream', and 'block-commit' accept node-name"
      
      All commands showed in this document were tested while documenting.
      
      Thanks: Eric Blake for the section: "A note on points-in-time vs file
      names".  This useful bit was originally articulated by Eric in his
      KVMForum 2015 presentation, so I included that specific bit in this
      document.
      Signed-off-by: NKashyap Chamarthy <kchamart@redhat.com>
      Reviewed-by: NEric Blake <eblake@redhat.com>
      Message-id: 20170717105205.32639-3-kchamart@redhat.com
      Signed-off-by: NJeff Cody <jcody@redhat.com>
      8508eee7