1. 13 1月, 2016 2 次提交
  2. 20 10月, 2014 1 次提交
  3. 22 9月, 2014 2 次提交
    • C
      async: aio_context_new(): Handle event_notifier_init failure · 2f78e491
      Chrysostomos Nanakos 提交于
      On a system with a low limit of open files the initialization
      of the event notifier could fail and QEMU exits without printing any
      error information to the user.
      
      The problem can be easily reproduced by enforcing a low limit of open
      files and start QEMU with enough I/O threads to hit this limit.
      
      The same problem raises, without the creation of I/O threads, while
      QEMU initializes the main event loop by enforcing an even lower limit of
      open files.
      
      This commit adds an error message on failure:
      
       # qemu [...] -object iothread,id=iothread0 -object iothread,id=iothread1
       qemu: Failed to initialize event notifier: Too many open files in system
      Signed-off-by: NChrysostomos Nanakos <cnanakos@grnet.gr>
      Signed-off-by: NStefan Hajnoczi <stefanha@redhat.com>
      2f78e491
    • F
      thread-pool: Convert thread_pool_aiocb_info.cancel to cancel_async · 3391f5e5
      Fam Zheng 提交于
      The .cancel_async shares the same the first half with .cancel: try to
      steal the request if not submitted yet. In this case set the elem to
      THREAD_DONE status and ret to -ECANCELED, which means
      thread_pool_completion_bh will call the cb with -ECANCELED.
      
      If the request is already submitted, do nothing, as we know the normal
      completion will happen in the future.
      
      Testing code update:
      
      Before, done_cb is only called if the request is already submitted by
      thread pool. Now done_cb is always called, even before it is submitted,
      because we emulate bdrv_aio_cancel with bdrv_aio_cancel_async. So also
      update the test criteria accordingly.
      Signed-off-by: NFam Zheng <famz@redhat.com>
      Signed-off-by: NStefan Hajnoczi <stefanha@redhat.com>
      3391f5e5
  4. 09 7月, 2014 1 次提交
  5. 28 5月, 2014 1 次提交
    • F
      aio: Fix use-after-free in cancellation path · 271c0f68
      Fam Zheng 提交于
      The current flow of canceling a thread from THREAD_ACTIVE state is:
      
        1) Caller wants to cancel a request, so it calls thread_pool_cancel.
      
        2) thread_pool_cancel waits on the conditional variable
           elem->check_cancel.
      
        3) The worker thread changes state to THREAD_DONE once the task is
           done, and notifies elem->check_cancel to allow thread_pool_cancel
           to continue execution, and signals the notifier (pool->notifier) to
           allow callback function to be called later. But because of the
           global mutex, the notifier won't get processed until step 4) and 5)
           are done.
      
        4) thread_pool_cancel continues, leaving the notifier signaled, it
           just returns to caller.
      
        5) Caller thinks the request is already canceled successfully, so it
           releases any related data, such as freeing elem->common.opaque.
      
        6) In the next main loop iteration, the notifier handler,
           event_notifier_ready, is called. It finds the canceled thread in
           THREAD_DONE state, so calls elem->common.cb, with an (likely)
           dangling opaque pointer. This is a use-after-free.
      
      Fix it by calling event_notifier_ready before leaving
      thread_pool_cancel.
      
      Test case update: This change will let cancel complete earlier than
      test-thread-pool.c expects, so update the code to check this case: if
      it's already done, done_cb sets .aiocb to NULL, skip calling
      bdrv_aio_cancel on them.
      Reported-by: NUlrich Obergfell <uobergfe@redhat.com>
      Suggested-by: NPaolo Bonzini <pbonzini@redhat.com>
      Signed-off-by: NFam Zheng <famz@redhat.com>
      Signed-off-by: NStefan Hajnoczi <stefanha@redhat.com>
      271c0f68
  6. 23 8月, 2013 1 次提交
  7. 19 8月, 2013 1 次提交
  8. 04 7月, 2013 1 次提交
  9. 15 3月, 2013 1 次提交
    • S
      threadpool: drop global thread pool · c4d9d196
      Stefan Hajnoczi 提交于
      Now that each AioContext has a ThreadPool and the main loop AioContext
      can be fetched with bdrv_get_aio_context(), we can eliminate the concept
      of a global thread pool from thread-pool.c.
      
      The submit functions must take a ThreadPool* argument.
      
      block/raw-posix.c and block/raw-win32.c use
      aio_get_thread_pool(bdrv_get_aio_context(bs)) to fetch the main loop's
      ThreadPool.
      
      tests/test-thread-pool.c must be updated to reflect the new
      thread_pool_submit() function prototypes.
      Signed-off-by: NStefan Hajnoczi <stefanha@redhat.com>
      Reviewed-by: NPaolo Bonzini <pbonzini@redhat.com>
      c4d9d196
  10. 19 12月, 2012 1 次提交
  11. 11 12月, 2012 1 次提交
  12. 27 11月, 2012 1 次提交
  13. 26 11月, 2012 1 次提交