diff options
Diffstat (limited to 'fs/xfs/linux-2.6/xfs_super.c')
-rw-r--r-- | fs/xfs/linux-2.6/xfs_super.c | 36 |
1 files changed, 9 insertions, 27 deletions
diff --git a/fs/xfs/linux-2.6/xfs_super.c b/fs/xfs/linux-2.6/xfs_super.c index 910e43bfc95b..0da87bfc9999 100644 --- a/fs/xfs/linux-2.6/xfs_super.c +++ b/fs/xfs/linux-2.6/xfs_super.c | |||
@@ -72,6 +72,7 @@ | |||
72 | #include <linux/mount.h> | 72 | #include <linux/mount.h> |
73 | #include <linux/mempool.h> | 73 | #include <linux/mempool.h> |
74 | #include <linux/writeback.h> | 74 | #include <linux/writeback.h> |
75 | #include <linux/kthread.h> | ||
75 | 76 | ||
76 | STATIC struct quotactl_ops linvfs_qops; | 77 | STATIC struct quotactl_ops linvfs_qops; |
77 | STATIC struct super_operations linvfs_sops; | 78 | STATIC struct super_operations linvfs_sops; |
@@ -516,25 +517,16 @@ xfssyncd( | |||
516 | { | 517 | { |
517 | long timeleft; | 518 | long timeleft; |
518 | vfs_t *vfsp = (vfs_t *) arg; | 519 | vfs_t *vfsp = (vfs_t *) arg; |
519 | struct list_head tmp; | ||
520 | struct vfs_sync_work *work, *n; | 520 | struct vfs_sync_work *work, *n; |
521 | LIST_HEAD (tmp); | ||
521 | 522 | ||
522 | daemonize("xfssyncd"); | ||
523 | |||
524 | vfsp->vfs_sync_work.w_vfs = vfsp; | ||
525 | vfsp->vfs_sync_work.w_syncer = vfs_sync_worker; | ||
526 | vfsp->vfs_sync_task = current; | ||
527 | wmb(); | ||
528 | wake_up(&vfsp->vfs_wait_sync_task); | ||
529 | |||
530 | INIT_LIST_HEAD(&tmp); | ||
531 | timeleft = (xfs_syncd_centisecs * HZ) / 100; | 523 | timeleft = (xfs_syncd_centisecs * HZ) / 100; |
532 | for (;;) { | 524 | for (;;) { |
533 | set_current_state(TASK_INTERRUPTIBLE); | 525 | set_current_state(TASK_INTERRUPTIBLE); |
534 | timeleft = schedule_timeout(timeleft); | 526 | timeleft = schedule_timeout(timeleft); |
535 | /* swsusp */ | 527 | /* swsusp */ |
536 | try_to_freeze(); | 528 | try_to_freeze(); |
537 | if (vfsp->vfs_flag & VFS_UMOUNT) | 529 | if (kthread_should_stop()) |
538 | break; | 530 | break; |
539 | 531 | ||
540 | spin_lock(&vfsp->vfs_sync_lock); | 532 | spin_lock(&vfsp->vfs_sync_lock); |
@@ -563,10 +555,6 @@ xfssyncd( | |||
563 | } | 555 | } |
564 | } | 556 | } |
565 | 557 | ||
566 | vfsp->vfs_sync_task = NULL; | ||
567 | wmb(); | ||
568 | wake_up(&vfsp->vfs_wait_sync_task); | ||
569 | |||
570 | return 0; | 558 | return 0; |
571 | } | 559 | } |
572 | 560 | ||
@@ -574,13 +562,11 @@ STATIC int | |||
574 | linvfs_start_syncd( | 562 | linvfs_start_syncd( |
575 | vfs_t *vfsp) | 563 | vfs_t *vfsp) |
576 | { | 564 | { |
577 | int pid; | 565 | vfsp->vfs_sync_work.w_syncer = vfs_sync_worker; |
578 | 566 | vfsp->vfs_sync_work.w_vfs = vfsp; | |
579 | pid = kernel_thread(xfssyncd, (void *) vfsp, | 567 | vfsp->vfs_sync_task = kthread_run(xfssyncd, vfsp, "xfssyncd"); |
580 | CLONE_VM | CLONE_FS | CLONE_FILES); | 568 | if (IS_ERR(vfsp->vfs_sync_task)) |
581 | if (pid < 0) | 569 | return -PTR_ERR(vfsp->vfs_sync_task); |
582 | return -pid; | ||
583 | wait_event(vfsp->vfs_wait_sync_task, vfsp->vfs_sync_task); | ||
584 | return 0; | 570 | return 0; |
585 | } | 571 | } |
586 | 572 | ||
@@ -588,11 +574,7 @@ STATIC void | |||
588 | linvfs_stop_syncd( | 574 | linvfs_stop_syncd( |
589 | vfs_t *vfsp) | 575 | vfs_t *vfsp) |
590 | { | 576 | { |
591 | vfsp->vfs_flag |= VFS_UMOUNT; | 577 | kthread_stop(vfsp->vfs_sync_task); |
592 | wmb(); | ||
593 | |||
594 | wake_up_process(vfsp->vfs_sync_task); | ||
595 | wait_event(vfsp->vfs_wait_sync_task, !vfsp->vfs_sync_task); | ||
596 | } | 578 | } |
597 | 579 | ||
598 | STATIC void | 580 | STATIC void |