Skip to content
Snippets Groups Projects
  1. Mar 07, 2022
    • Vladimir Sementsov-Ogievskiy's avatar
      block: fix preallocate filter: don't do unaligned preallocate requests · 45e62b46
      Vladimir Sementsov-Ogievskiy authored
      
      There is a bug in handling BDRV_REQ_NO_WAIT flag: we still may wait in
      wait_serialising_requests() if request is unaligned. And this is
      possible for the only user of this flag (preallocate filter) if
      underlying file is unaligned to its request_alignment on start.
      
      So, we have to fix preallocate filter to do only aligned preallocate
      requests.
      
      Next, we should fix generic block/io.c somehow. Keeping in mind that
      preallocate is the only user of BDRV_REQ_NO_WAIT and that we have to
      fix its behavior now, it seems more safe to just assert that we never
      use BDRV_REQ_NO_WAIT with unaligned requests and add corresponding
      comment. Let's do so.
      
      Signed-off-by: default avatarVladimir Sementsov-Ogievskiy <vsementsov@virtuozzo.com>
      Reviewed-by: default avatarDenis V. Lunev <den@openvz.org>
      Message-Id: <20220215121609.38570-1-vsementsov@virtuozzo.com>
      [hreitz: Rebased on block GS/IO split]
      Signed-off-by: default avatarHanna Reitz <hreitz@redhat.com>
      45e62b46
    • Peter Maydell's avatar
      block/curl.c: Check error return from curl_easy_setopt() · b0ea6c98
      Peter Maydell authored
      
      Coverity points out that we aren't checking the return value
      from curl_easy_setopt() for any of the calls to it we make
      in block/curl.c.
      
      Some of these options are documented as always succeeding (e.g.
      CURLOPT_VERBOSE) but others have documented failure cases (e.g.
      CURLOPT_URL).  For consistency we check every call, even the ones
      that theoretically cannot fail.
      
      Fixes: Coverity CID 1459336, 1459482, 1460331
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Message-Id: <20220222152341.850419-3-peter.maydell@linaro.org>
      Reviewed-by: default avatarHanna Reitz <hreitz@redhat.com>
      Signed-off-by: default avatarHanna Reitz <hreitz@redhat.com>
      b0ea6c98
    • Peter Maydell's avatar
      block/curl.c: Set error message string if curl_init_state() fails · 2ea7dfcd
      Peter Maydell authored
      
      In curl_open(), the 'out' label assumes that the state->errmsg string
      has been set (either by curl_easy_perform() or by manually copying a
      string into it); however if curl_init_state() fails we will jump to
      that label without setting the string.  Add the missing error string
      setup.
      
      (We can't be specific about the cause of failure: the documentation
      of curl_easy_init() just says "If this function returns NULL,
      something went wrong".)
      
      Signed-off-by: default avatarPeter Maydell <peter.maydell@linaro.org>
      Message-Id: <20220222152341.850419-2-peter.maydell@linaro.org>
      Reviewed-by: default avatarPhilippe Mathieu-Daudé <f4bug@amsat.org>
      Reviewed-by: default avatarHanna Reitz <hreitz@redhat.com>
      Signed-off-by: default avatarHanna Reitz <hreitz@redhat.com>
      2ea7dfcd
    • Hanna Reitz's avatar
      ide: Increment BB in-flight counter for TRIM BH · 7e5cdb34
      Hanna Reitz authored
      When we still have an AIOCB registered for DMA operations, we try to
      settle the respective operation by draining the BlockBackend associated
      with the IDE device.
      
      However, this assumes that every DMA operation is associated with an
      increment of the BlockBackend’s in-flight counter (e.g. through some
      ongoing I/O operation), so that draining the BB until its in-flight
      counter reaches 0 will settle all DMA operations.  That is not the case:
      For TRIM, the guest can issue a zero-length operation that will not
      result in any I/O operation forwarded to the BlockBackend, and also not
      increment the in-flight counter in any other way.  In such a case,
      blk_drain() will be a no-op if no other operations are in flight.
      
      It is clear that if blk_drain() is a no-op, the value of
      s->bus->dma->aiocb will not change between checking it in the `if`
      condition and asserting that it is NULL after blk_drain().
      
      The particular problem is that ide_issue_trim() creates a BH
      (ide_trim_bh_cb()) to settle the TRIM request: iocb->common.cb() is
      ide_dma_cb(), which will either create a new request, or find the
      transfer to be done and call ide_set_inactive(), which clears
      s->bus->dma->aiocb.  Therefore, the blk_drain() must wait for
      ide_trim_bh_cb() to run, which currently it will not always do.
      
      To fix this issue, we increment the BlockBackend's in-flight counter
      when the TRIM operation begins (in ide_issue_trim(), when the
      ide_trim_bh_cb() BH is created) and decrement it when ide_trim_bh_cb()
      is done.
      
      Buglink: https://bugzilla.redhat.com/show_bug.cgi?id=2029980
      
      
      Suggested-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
      Signed-off-by: default avatarHanna Reitz <hreitz@redhat.com>
      Message-Id: <20220120142259.120189-1-hreitz@redhat.com>
      Reviewed-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
      Reviewed-by: default avatarJohn Snow <jsnow@redhat.com>
      Tested-by: default avatarJohn Snow <jsnow@redhat.com>
      7e5cdb34
  2. Mar 05, 2022
  3. Mar 04, 2022
Loading