diff --git a/fs/eventpoll.c b/fs/eventpoll.c index e0decff22ae2..351b82212e32 100644 --- a/fs/eventpoll.c +++ b/fs/eventpoll.c @@ -1994,10 +1994,10 @@ static int ep_loop_check_proc(void *priv, void *cookie, int call_nests) * not already there, and calling reverse_path_check() * during ep_insert(). */ - if (list_empty(&epi->ffd.file->f_tfile_llink)) { - get_file(epi->ffd.file); - list_add(&epi->ffd.file->f_tfile_llink, - &tfile_check_list); + if (list_empty_careful(&epi->ffd.file->f_tfile_llink)) { + // if(get_file(epi->ffd.file)) + list_add(&epi->ffd.file->f_tfile_llink, + &tfile_check_list); } } } @@ -2042,7 +2042,7 @@ static void clear_tfile_check_list(void) file = list_first_entry(&tfile_check_list, struct file, f_tfile_llink); list_del_init(&file->f_tfile_llink); - fput(file); + // fput_(file); } INIT_LIST_HEAD(&tfile_check_list); } @@ -2206,8 +2206,8 @@ int do_epoll_ctl(int epfd, int op, int fd, struct epoll_event *epds, if (ep_loop_check(ep, tf.file) != 0) goto error_tgt_fput; } else { - get_file(tf.file); - list_add(&tf.file->f_tfile_llink, + // if(get_file(tf.file)) + list_add(&tf.file->f_tfile_llink, &tfile_check_list); } error = epoll_mutex_lock(&ep->mtx, 0, nonblock);