diff options
author | Eric Sandeen <sandeen@redhat.com> | 2011-02-03 14:33:15 -0500 |
---|---|---|
committer | Theodore Ts'o <tytso@mit.edu> | 2011-02-03 14:33:15 -0500 |
commit | 8f1f745331c1b560f53c0d60e55a4f4f43f7cce5 (patch) | |
tree | d8db8e0e1a067012795372e38fce09dec6bc575a /fs/ext4/xattr.c | |
parent | 1bae4ce27c9c90344f23c65ea6966c50ffeae2f5 (diff) | |
download | kernel_goldelico_gta04-8f1f745331c1b560f53c0d60e55a4f4f43f7cce5.zip kernel_goldelico_gta04-8f1f745331c1b560f53c0d60e55a4f4f43f7cce5.tar.gz kernel_goldelico_gta04-8f1f745331c1b560f53c0d60e55a4f4f43f7cce5.tar.bz2 |
ext4: fix panic on module unload when stopping lazyinit thread
https://bugzilla.kernel.org/show_bug.cgi?id=27652
If the lazyinit thread is running, the teardown function
ext4_destroy_lazyinit_thread() has problems:
ext4_clear_request_list();
while (ext4_li_info->li_task) {
wake_up(&ext4_li_info->li_wait_daemon);
wait_event(ext4_li_info->li_wait_task,
ext4_li_info->li_task == NULL);
}
Clearing the request list will cause the thread to exit and free
ext4_li_info, so then we're waiting on something which is getting
freed.
Fix this up by making the thread respond to kthread_stop, and exit,
without the need to wait for that exit in some other homegrown way.
Cc: stable@kernel.org
Reported-and-Tested-by: Tao Ma <boyu.mt@taobao.com>
Signed-off-by: Eric Sandeen <sandeen@redhat.com>
Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
Diffstat (limited to 'fs/ext4/xattr.c')
0 files changed, 0 insertions, 0 deletions