|
|
|
|
|
|
|
|
|
|
xen-devel
[Xen-devel] [PATCH 6/12] Make kthreads freezable
Kernel threads need to be aware of freeze request, by
checking in each loop. xenbus/xenwatch threads are bit
special with PF_NOFREEZE, since we're sure that they
do nothing to block other native device drivers.
Signed-off-by Ke Yu <ke.yu@xxxxxxxxx>
Signed-off-by Kevin Tian <kevin.tian@xxxxxxxxx>
diff -r 46d6f357aa97 linux-2.6-xen-sparse/drivers/xen/blkback/blkback.c
--- a/linux-2.6-xen-sparse/drivers/xen/blkback/blkback.c Tue Feb
13 13:37:10 2007 +0800
+++ b/linux-2.6-xen-sparse/drivers/xen/blkback/blkback.c Tue Feb
13 13:47:46 2007 +0800
@@ -208,6 +208,9 @@ int blkif_schedule(void *arg)
printk(KERN_DEBUG "%s: started\n", current->comm);
while (!kthread_should_stop()) {
+ if(try_to_freeze())
+ continue;
+
wait_event_interruptible(
blkif->wq,
blkif->waiting_reqs || kthread_should_stop());
diff -r 46d6f357aa97 linux-2.6-xen-sparse/drivers/xen/xenbus/xenbus_xs.c
--- a/linux-2.6-xen-sparse/drivers/xen/xenbus/xenbus_xs.c Tue Feb
13 13:37:10 2007 +0800
+++ b/linux-2.6-xen-sparse/drivers/xen/xenbus/xenbus_xs.c Tue Feb
13 13:47:46 2007 +0800
@@ -717,6 +717,7 @@ static int xenwatch_thread(void *unused)
struct list_head *ent;
struct xs_stored_msg *msg;
+ current->flags |= PF_NOFREEZE;
for (;;) {
wait_event_interruptible(watch_events_waitq,
!list_empty(&watch_events));
@@ -813,6 +814,7 @@ static int xenbus_thread(void *unused)
{
int err;
+ current->flags |= PF_NOFREEZE;
for (;;) {
err = process_msg();
if (err)
make_kthread_freezable.patch
Description: make_kthread_freezable.patch
_______________________________________________
Xen-devel mailing list
Xen-devel@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-devel
|
<Prev in Thread] |
Current Thread |
[Next in Thread> |
- [Xen-devel] [PATCH 6/12] Make kthreads freezable,
Tian, Kevin <=
|
|
|
|
|