X-Git-Url: http://pilppa.org/gitweb/?a=blobdiff_plain;f=fs%2Fsync.c;h=7abc65fbf21df8455400e9757751f8069cd29f28;hb=ef5ddd3d591399f2c722a77bce543d20bef31663;hp=a16d53e5fe9d68a5a4f6b000fd1366e9fb91e167;hpb=a5e0e970c06065a14844b406a0c2a59776a1ccc6;p=linux-2.6-omap-h63xx.git diff --git a/fs/sync.c b/fs/sync.c index a16d53e5fe9..7abc65fbf21 100644 --- a/fs/sync.c +++ b/fs/sync.c @@ -25,7 +25,7 @@ static void do_sync(unsigned long wait) { wakeup_pdflush(0); sync_inodes(0); /* All mappings, inodes and their blockdevs */ - DQUOT_SYNC(NULL); + vfs_dq_sync(NULL); sync_supers(); /* Write the superblocks */ sync_filesystems(0); /* Start syncing the filesystems */ sync_filesystems(wait); /* Waitingly sync the filesystems */ @@ -42,9 +42,21 @@ SYSCALL_DEFINE0(sync) return 0; } +static void do_sync_work(struct work_struct *work) +{ + do_sync(0); + kfree(work); +} + void emergency_sync(void) { - pdflush_operation(do_sync, 0); + struct work_struct *work; + + work = kmalloc(sizeof(*work), GFP_ATOMIC); + if (work) { + INIT_WORK(work, do_sync_work); + schedule_work(work); + } } /*