vhost_task: Handle SIGKILL by flushing work and exiting
authorMike Christie <michael.christie@oracle.com>
Sat, 16 Mar 2024 00:47:06 +0000 (19:47 -0500)
committerMichael S. Tsirkin <mst@redhat.com>
Wed, 22 May 2024 12:31:15 +0000 (08:31 -0400)
commitdb5247d9bf5c6ade9fd70b4e4897441e0269b233
treecfec480a97ddaaf073d69cf6ed272a2edf18ecb4
parentba704ff4e142fd3cfaf3379dd3b3b946754e06e3
vhost_task: Handle SIGKILL by flushing work and exiting

Instead of lingering until the device is closed, this has us handle
SIGKILL by:

1. marking the worker as killed so we no longer try to use it with
   new virtqueues and new flush operations.
2. setting the virtqueue to worker mapping so no new works are queued.
3. running all the exiting works.

Suggested-by: Edward Adam Davis <eadavis@qq.com>
Reported-and-tested-by: syzbot+98edc2df894917b3431f@syzkaller.appspotmail.com
Message-Id: <tencent_546DA49414E876EEBECF2C78D26D242EE50A@qq.com>
Signed-off-by: Mike Christie <michael.christie@oracle.com>
Message-Id: <20240316004707.45557-9-michael.christie@oracle.com>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
drivers/vhost/vhost.c
drivers/vhost/vhost.h
include/linux/sched/vhost_task.h
kernel/vhost_task.c