aboutsummaryrefslogtreecommitdiffstats
path: root/net/core/scm.c
diff options
context:
space:
mode:
authorAl Viro <viro@zeniv.linux.org.uk>2012-06-24 10:03:05 +0400
committerAl Viro <viro@zeniv.linux.org.uk>2012-07-22 23:58:00 +0400
commit6120d3dbb1220792ebea88cd475e1ec8f8620a93 (patch)
tree0ca01ed01651ddb1f54f6fe43c2288acb8d361c3 /net/core/scm.c
parentaio: now fput() is OK from interrupt context; get rid of manual delayed __fput() (diff)
downloadlinux-dev-6120d3dbb1220792ebea88cd475e1ec8f8620a93.tar.xz
linux-dev-6120d3dbb1220792ebea88cd475e1ec8f8620a93.zip
get rid of ->scm_work_list
recursion in __scm_destroy() will be cut by delaying final fput() Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'net/core/scm.c')
-rw-r--r--net/core/scm.c22
1 files changed, 3 insertions, 19 deletions
diff --git a/net/core/scm.c b/net/core/scm.c
index 611c5efd4cb0..8f6ccfd68ef4 100644
--- a/net/core/scm.c
+++ b/net/core/scm.c
@@ -109,25 +109,9 @@ void __scm_destroy(struct scm_cookie *scm)
if (fpl) {
scm->fp = NULL;
- if (current->scm_work_list) {
- list_add_tail(&fpl->list, current->scm_work_list);
- } else {
- LIST_HEAD(work_list);
-
- current->scm_work_list = &work_list;
-
- list_add(&fpl->list, &work_list);
- while (!list_empty(&work_list)) {
- fpl = list_first_entry(&work_list, struct scm_fp_list, list);
-
- list_del(&fpl->list);
- for (i=fpl->count-1; i>=0; i--)
- fput(fpl->fp[i]);
- kfree(fpl);
- }
-
- current->scm_work_list = NULL;
- }
+ for (i=fpl->count-1; i>=0; i--)
+ fput(fpl->fp[i]);
+ kfree(fpl);
}
}
EXPORT_SYMBOL(__scm_destroy);