*** This bug is a duplicate of bug 1840076 ***
    https://bugs.launchpad.net/bugs/1840076

Link correction for master branch:
  * Bionic - 
https://kernel.ubuntu.com/git/ubuntu/ubuntu-bionic.git/commit/?h=master&id=683f56d305988dda311e928fba080edb758c8d13
  * Eoan - 
https://kernel.ubuntu.com/git/ubuntu/ubuntu-eoan.git/commit/?h=master&id=d10e0cc113c9e1b64b5c6e3db37b5c839794f3df

-- 
You received this bug notification because you are a member of Kernel
Packages, which is subscribed to linux in Ubuntu.
https://bugs.launchpad.net/bugs/1844421

Title:
  Linux VM deadlock during migration

Status in linux package in Ubuntu:
  Confirmed

Bug description:
  The following program will cause a Linux VM running under Xen to
  deadlock if a suspend/migrate is attempted:

  -----
  import pyxs.client
  import time

  c = pyxs.client.Client(xen_bus_path="/dev/xen/xenbus")
  c.connect()
  c.transaction()

  while True:
      time.sleep(1000)
  -----

  When control/shutdown == "suspend", the kernel calls do_suspend()
  which does a number of steps including freezing processes. It then
  calls xs_suspend() to suspend xenstore, which takes some locks and
  waits for all transactions to complete so that no new activity can
  start while the VM is suspending:

  -----
  xs_suspend():
        mutex_lock(&xs_state.transaction_mutex);
        wait_event(xs_state.transaction_wq,
                   atomic_read(&xs_state.transaction_count) == 0); <-- the 
xenwatch thread is waiting here
        down_write(&xs_state.watch_mutex);
        mutex_lock(&xs_state.request_mutex);
        mutex_lock(&xs_state.response_mutex);
  -----

  The xenwatch thread is waiting for all outstanding transactions to
  complete. However, by this point the processes have been frozen so any
  outstanding transactions won't complete.

  This affects all versions of Linux back to at least v3.2, but has been
  fixed in v5.2-rc3 (see
  
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?id=867cefb4cb1012f42cada1c7d1f35ac8dd276071)

  A backport to released Ubuntu kernels is requested.

To manage notifications about this bug go to:
https://bugs.launchpad.net/ubuntu/+source/linux/+bug/1844421/+subscriptions

-- 
Mailing list: https://launchpad.net/~kernel-packages
Post to     : kernel-packages@lists.launchpad.net
Unsubscribe : https://launchpad.net/~kernel-packages
More help   : https://help.launchpad.net/ListHelp

Reply via email to