Skip to content
Snippets Groups Projects
  1. Apr 15, 2016
  2. Apr 14, 2016
  3. Apr 13, 2016
  4. Apr 12, 2016
    • Pavel Butsykin's avatar
      ide: really restart pending and in-flight atapi dma · 502356ee
      Pavel Butsykin authored
      
      Restart of ATAPI DMA used to be unreachable, because the request to do
      so wasn't indicated in bus->error_status due to the lack of spare bits, and
      ide_restart_bh() would return early doing nothing.
      
      This patch makes use of the observation that not all bit combinations were
      possible in ->error_status. In particular, IDE_RETRY_READ only made sense
      together with IDE_RETRY_DMA or IDE_RETRY_PIO. This allows to re-use
      IDE_RETRY_READ alone as an indicator of ATAPI DMA restart request.
      
      To makes things more uniform, ATAPI DMA gets its own value for ->dma_cmd.
      As a means against confusion, macros are added to test the state of
      ->error_status.
      
      The patch fixes the restart of both in-flight and pending ATAPI DMA,
      following the scheme similar to that of IDE DMA.
      
      [Including a fixup patch:
      Message-id: 1460465594-15777-1-git-send-email-pbutsykin@virtuozzo.com
      --js]
      
      Signed-off-by: default avatarPavel Butsykin <pbutsykin@virtuozzo.com>
      Signed-off-by: default avatarDenis V. Lunev <den@openvz.org>
      Reviewed-by: default avatarRoman Kagan <rkagan@virtuozzo.com>
      Reviewed-by: default avatarJohn Snow <jsnow@redhat.com>
      Message-id: 1459924806-306-4-git-send-email-den@openvz.org
      Signed-off-by: default avatarJohn Snow <jsnow@redhat.com>
      502356ee
    • Pavel Butsykin's avatar
      ide: restart atapi dma by re-evaluating command packet · 9a41826f
      Pavel Butsykin authored
      
      ide_atapi_dma_restart() used to just complete the DMA with an error,
      under the assumption that there isn't enough information to restart it.
      
      However, as the contents of the ->io_buffer is preserved, it looks safe to
      just re-evaluate it and dispatch the ATAPI command again.
      
      Signed-off-by: default avatarPavel Butsykin <pbutsykin@virtuozzo.com>
      Reviewed-by: default avatarRoman Kagan <rkagan@virtuozzo.com>
      Signed-off-by: default avatarDenis V. Lunev <den@openvz.org>
      Reviewed-by: default avatarJohn Snow <jsnow@redhat.com>
      Message-id: 1459924806-306-3-git-send-email-den@openvz.org
      Signed-off-by: default avatarJohn Snow <jsnow@redhat.com>
      9a41826f
    • Pavel Butsykin's avatar
      ide: don't lose pending dma state · 218fd37c
      Pavel Butsykin authored
      
      If the migration occurs after the IDE DMA has been set up but before it
      has been initiated, the state gets lost upon save/restore. Specifically,
      ->dma_cb callback gets cleared, so, when the guest eventually starts bus
      mastering, the DMA never completes, causing the guest to time out the
      operation.
      
      OTOH all the infrastructure is already in place to restart the DMA if
      the migration happens while the DMA is in progress.
      
      So reuse that infrastructure, by setting bus->error_status based on
      ->dma_cmd in pre_save if ->dma_cb callback is already set but DMAING is
      clear. This will indicate the need for restart and make sure ->dma_cb
      is restored in ide_restart_bh(); howeover since DMAING is clear the state
      upon restore will be exactly "ready for DMA" as before the save.
      
      Signed-off-by: default avatarPavel Butsykin <pbutsykin@virtuozzo.com>
      Reviewed-by: default avatarRoman Kagan <rkagan@virtuozzo.com>
      Signed-off-by: default avatarDenis V. Lunev <den@openvz.org>
      Reviewed-by: default avatarJohn Snow <jsnow@redhat.com>
      Message-id: 1459924806-306-2-git-send-email-den@openvz.org
      Signed-off-by: default avatarJohn Snow <jsnow@redhat.com>
      218fd37c
    • Anthony PERARD's avatar
      xen: Fix IDE unplug · d1fc684f
      Anthony PERARD authored
      
      After commit e5e78550 (blockdev: Separate BB name management), starting a
      guest with PVHVM support result in this assert:
      qemu-system-i386: block/block-backend.c:173: blk_delete: Assertion `!blk->name' failed.
      
      A backtrace show that a caller is pci_piix3_xen_ide_unplug().
      
      This patch fix it.
      
      Signed-off-by: default avatarAnthony PERARD <anthony.perard@citrix.com>
      Message-id: 1460382666-29885-1-git-send-email-anthony.perard@citrix.com
      Signed-off-by: default avatarJohn Snow <jsnow@redhat.com>
      d1fc684f
    • Peter Maydell's avatar
      Merge remote-tracking branch 'remotes/kevin/tags/for-upstream' into staging · d44122ec
      Peter Maydell authored
      
      Block layer patches for 2.6
      
      # gpg: Signature made Tue 12 Apr 2016 17:10:29 BST using RSA key ID C88F2FD6
      # gpg: Good signature from "Kevin Wolf <kwolf@redhat.com>"
      
      * remotes/kevin/tags/for-upstream:
        qemu-iotests: iotests.py: get rid of __all__
        qemu-iotests: 068: don't require KVM
        qemu-iotests: 148: properly skip test if quorum support is missing
        qemu-iotests: iotests.VM: remove qtest socket on error
        qemu-iotests: fix 051 on non-PC architectures
        qemu-iotests: check: don't place files with predictable names in /tmp
        MAINTAINERS: Block layer core, qcow2 and blkdebug
        qcow2: Prevent backing file names longer than 1023
        vpc: fix return value check for blk_pwrite
        iotests: Make 150 use qemu-img map instead of du
        block: initialize qcrypto API at startup
        qemu-img: fix formatting of error message
        iotests: fix the broken 026.nocache output
      
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      d44122ec
    • Kevin Wolf's avatar
      Merge remote-tracking branch 'mreitz/tags/pull-block-for-kevin-2016-04-12' into queue-block · 5158ac58
      Kevin Wolf authored
      
      Block patches for 2.6-rc2.
      
      # gpg: Signature made Tue Apr 12 18:08:20 2016 CEST using RSA key ID E838ACAD
      # gpg: Good signature from "Max Reitz <mreitz@redhat.com>"
      
      * mreitz/tags/pull-block-for-kevin-2016-04-12:
        qemu-iotests: iotests.py: get rid of __all__
        qemu-iotests: 068: don't require KVM
        qemu-iotests: 148: properly skip test if quorum support is missing
        qemu-iotests: iotests.VM: remove qtest socket on error
        qemu-iotests: fix 051 on non-PC architectures
        qemu-iotests: check: don't place files with predictable names in /tmp
      
      Signed-off-by: default avatarKevin Wolf <kwolf@redhat.com>
      5158ac58
    • Sascha Silbe's avatar
      qemu-iotests: iotests.py: get rid of __all__ · 3ef3dcef
      Sascha Silbe authored
      
      The __all__ list contained a typo for as long as the iotests module
      existed. That typo prevented "from iotests import *" (which is the
      only case where iotests.__all__ is used at all) from ever working.
      
      The names used by iotests are highly prone to name collisions, so
      importing them all unconditionally is a bad idea anyway. Since __all__
      is not adding any value, let's just get rid of it.
      
      Fixes: f345cfd0 ("qemu-iotests: add iotests Python module")
      Signed-off-by: default avatarSascha Silbe <silbe@linux.vnet.ibm.com>
      Reviewed-by: default avatarBo Tu <tubo@linux.vnet.ibm.com>
      Message-id: 1459848109-29756-8-git-send-email-silbe@linux.vnet.ibm.com
      Reviewed-by: default avatarMax Reitz <mreitz@redhat.com>
      Signed-off-by: default avatarMax Reitz <mreitz@redhat.com>
      3ef3dcef
    • Sascha Silbe's avatar
      qemu-iotests: 068: don't require KVM · 9bf8027d
      Sascha Silbe authored
      
      None of the other test cases explicitly enable KVM and there's no
      obvious reason for 068 to require it. Drop this so all test cases can be
      executed in environments where KVM is not available (e.g. because the
      user doesn't have sufficient permissions to access /dev/kvm).
      
      Signed-off-by: default avatarSascha Silbe <silbe@linux.vnet.ibm.com>
      Reviewed-by: default avatarBo Tu <tubo@linux.vnet.ibm.com>
      Message-id: 1459848109-29756-6-git-send-email-silbe@linux.vnet.ibm.com
      Signed-off-by: default avatarMax Reitz <mreitz@redhat.com>
      9bf8027d
    • Sascha Silbe's avatar
      qemu-iotests: 148: properly skip test if quorum support is missing · 3f647b51
      Sascha Silbe authored
      
      qemu-iotests test case 148 already had some code for skipping the test
      if quorum support is missing, but it didn't work in all
      cases. TestQuorumEvents.setUp() gets run before the actual test class
      (which contains the skipping code) and tries to start qemu with a drive
      using the quorum driver. For some reason this works fine when using
      qcow2, but fails for raw.
      
      As the entire test case requires quorum, just check for availability
      before even starting the test suite. Introduce a verify_quorum()
      function in iotests.py for this purpose so future test cases can make
      use of it.
      
      Signed-off-by: default avatarSascha Silbe <silbe@linux.vnet.ibm.com>
      Reviewed-by: default avatarBo Tu <tubo@linux.vnet.ibm.com>
      Message-id: 1459848109-29756-5-git-send-email-silbe@linux.vnet.ibm.com
      Reviewed-by: default avatarMax Reitz <mreitz@redhat.com>
      Signed-off-by: default avatarMax Reitz <mreitz@redhat.com>
      3f647b51
    • Sascha Silbe's avatar
      qemu-iotests: iotests.VM: remove qtest socket on error · c1c71e49
      Sascha Silbe authored
      
      On error, VM.launch() cleaned up the monitor unix socket, but left the
      qtest unix socket behind. This caused the remaining sub-tests to fail
      with EADDRINUSE:
      
      +======================================================================
      +ERROR: testQuorum (__main__.TestFifoQuorumEvents)
      +----------------------------------------------------------------------
      +Traceback (most recent call last):
      +  File "148", line 63, in setUp
      +    self.vm.launch()
      +  File "/home6/silbe/qemu/tests/qemu-iotests/iotests.py", line 247, in launch
      +    self._qmp.accept()
      +  File "/home6/silbe/qemu/tests/qemu-iotests/../../scripts/qmp/qmp.py", line 141, in accept
      +    return self.__negotiate_capabilities()
      +  File "/home6/silbe/qemu/tests/qemu-iotests/../../scripts/qmp/qmp.py", line 57, in __negotiate_capabilities
      +    raise QMPConnectError
      +QMPConnectError
      +
      +======================================================================
      +ERROR: testQuorum (__main__.TestQuorumEvents)
      +----------------------------------------------------------------------
      +Traceback (most recent call last):
      +  File "148", line 63, in setUp
      +    self.vm.launch()
      +  File "/home6/silbe/qemu/tests/qemu-iotests/iotests.py", line 244, in launch
      +    self._qtest = qtest.QEMUQtestProtocol(self._qtest_path, server=True)
      +  File "/home6/silbe/qemu/tests/qemu-iotests/../../scripts/qtest.py", line 33, in __init__
      +    self._sock.bind(self._address)
      +  File "/usr/lib64/python2.7/socket.py", line 224, in meth
      +    return getattr(self._sock,name)(*args)
      +error: [Errno 98] Address already in use
      
      Fix this by cleaning up both the monitor socket and the qtest socket iff
      they exist.
      
      Signed-off-by: default avatarSascha Silbe <silbe@linux.vnet.ibm.com>
      Reviewed-by: default avatarBo Tu <tubo@linux.vnet.ibm.com>
      Message-id: 1459848109-29756-4-git-send-email-silbe@linux.vnet.ibm.com
      Reviewed-by: default avatarMax Reitz <mreitz@redhat.com>
      Signed-off-by: default avatarMax Reitz <mreitz@redhat.com>
      c1c71e49
    • Sascha Silbe's avatar
      qemu-iotests: fix 051 on non-PC architectures · 1759386b
      Sascha Silbe authored
      
      Commit 61de4c68 [block: Remove BDRV_O_CACHE_WB] updated the reference
      output for PCs, but neglected to do the same for the generic reference
      output file. Fix 051 on all non-PC architectures by applying the same
      change to the generic output file.
      
      Fixes: 61de4c68 ("block: Remove BDRV_O_CACHE_WB")
      Signed-off-by: default avatarSascha Silbe <silbe@linux.vnet.ibm.com>
      Reviewed-by: default avatarBo Tu <tubo@linux.vnet.ibm.com>
      Message-id: 1459848109-29756-3-git-send-email-silbe@linux.vnet.ibm.com
      Reviewed-by: default avatarMax Reitz <mreitz@redhat.com>
      Signed-off-by: default avatarMax Reitz <mreitz@redhat.com>
      1759386b
    • Sascha Silbe's avatar
      qemu-iotests: check: don't place files with predictable names in /tmp · 0145b4e1
      Sascha Silbe authored
      
      Placing files with predictable or even hard-coded names in /tmp is a
      security risk and can prevent or disturb operation on a multi-user
      machine. Place them inside the "scratch" directory instead, as we
      already do for most other test-related files.
      
      Signed-off-by: default avatarSascha Silbe <silbe@linux.vnet.ibm.com>
      Reviewed-by: default avatarBo Tu <tubo@linux.vnet.ibm.com>
      Message-id: 1459848109-29756-2-git-send-email-silbe@linux.vnet.ibm.com
      Reviewed-by: default avatarMax Reitz <mreitz@redhat.com>
      Signed-off-by: default avatarMax Reitz <mreitz@redhat.com>
      0145b4e1
    • Hanna Reitz's avatar
      MAINTAINERS: Block layer core, qcow2 and blkdebug · c4189d85
      Hanna Reitz authored
      
      As agreed with Kevin and already practiced for a while, I am adding
      myself as co-maintainer of the block layer core, qcow2 and blkdebug.
      
      Signed-off-by: default avatarMax Reitz <mreitz@redhat.com>
      Signed-off-by: default avatarKevin Wolf <kwolf@redhat.com>
      c4189d85
    • Hanna Reitz's avatar
      qcow2: Prevent backing file names longer than 1023 · 4e876bcf
      Hanna Reitz authored
      
      We reject backing file names with a length of more than 1023 characters
      when opening a qcow2 file, so we should not produce such files
      ourselves.
      
      Cc: qemu-stable@nongnu.org
      Signed-off-by: default avatarMax Reitz <mreitz@redhat.com>
      Signed-off-by: default avatarKevin Wolf <kwolf@redhat.com>
      4e876bcf
    • Paolo Bonzini's avatar
      vpc: fix return value check for blk_pwrite · 40a99aac
      Paolo Bonzini authored
      
      bdrv_pwrite_sync used to return zero or negative error, while blk_pwrite returns
      the number of written bytes when successful.  This caused VPC image creation
      to fail spectacularly: it wrote the first 512 bytes, and then exited immediately
      because of the non-zero answer from blk_pwrite.  But the truly spectacular part
      is that it returns a positive value (the 512 that blk_pwrite returned) causing
      everyone to believe that it succeeded.
      
      This fixes qemu-iotests with vpc format.
      
      Fixes: b8f45cdf
      Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
      Signed-off-by: default avatarKevin Wolf <kwolf@redhat.com>
      40a99aac
Loading