Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 118547
b: refs/heads/master
c: 3b53fbf
h: refs/heads/master
i:
  118545: 59653c1
  118543: deaaab1
v: v3
  • Loading branch information
David S. Miller committed Nov 6, 2008
1 parent c9d56ce commit 19c2839
Show file tree
Hide file tree
Showing 4 changed files with 27 additions and 6 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 518a09ef11f8454f4676125d47c3e775b300c6a5
refs/heads/master: 3b53fbf4314594fa04544b02b2fc6e607912da18
2 changes: 2 additions & 0 deletions trunk/include/linux/sched.h
Original file line number Diff line number Diff line change
Expand Up @@ -1349,6 +1349,8 @@ struct task_struct {
*/
unsigned long timer_slack_ns;
unsigned long default_timer_slack_ns;

struct list_head *scm_work_list;
};

/*
Expand Down
5 changes: 3 additions & 2 deletions trunk/include/net/scm.h
Original file line number Diff line number Diff line change
Expand Up @@ -14,8 +14,9 @@

struct scm_fp_list
{
int count;
struct file *fp[SCM_MAX_FD];
struct list_head list;
int count;
struct file *fp[SCM_MAX_FD];
};

struct scm_cookie
Expand Down
24 changes: 21 additions & 3 deletions trunk/net/core/scm.c
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,7 @@ static int scm_fp_copy(struct cmsghdr *cmsg, struct scm_fp_list **fplp)
if (!fpl)
return -ENOMEM;
*fplp = fpl;
INIT_LIST_HEAD(&fpl->list);
fpl->count = 0;
}
fpp = &fpl->fp[fpl->count];
Expand Down Expand Up @@ -106,9 +107,25 @@ void __scm_destroy(struct scm_cookie *scm)

if (fpl) {
scm->fp = NULL;
for (i=fpl->count-1; i>=0; i--)
fput(fpl->fp[i]);
kfree(fpl);
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;
}
}
}

Expand Down Expand Up @@ -284,6 +301,7 @@ struct scm_fp_list *scm_fp_dup(struct scm_fp_list *fpl)

new_fpl = kmalloc(sizeof(*fpl), GFP_KERNEL);
if (new_fpl) {
INIT_LIST_HEAD(&new_fpl->list);
for (i=fpl->count-1; i>=0; i--)
get_file(fpl->fp[i]);
memcpy(new_fpl, fpl, sizeof(*fpl));
Expand Down

0 comments on commit 19c2839

Please sign in to comment.