- don't stop the caching thread until btrfs_commit_super return.
- if caching is interrupted by umount, set last to (u64)-1.
  otherwise the un-scanned range of block group will be considered
  as free extent.
Signed-off-by: Chris Mason <chris.mason@oracle.com>
                        printk(KERN_ERR "btrfs: commit super ret %d\n", ret);
        }
 
+       fs_info->closing = 2;
+       smp_mb();
+
        if (fs_info->delalloc_bytes) {
                printk(KERN_INFO "btrfs: at unmount delalloc count %llu\n",
                       (unsigned long long)fs_info->delalloc_bytes);
 
 
        while (1) {
                smp_mb();
-               if (block_group->fs_info->closing)
+               if (block_group->fs_info->closing > 1) {
+                       last = (u64)-1;
                        break;
+               }
 
                leaf = path->nodes[0];
                slot = path->slots[0];