From: Oleg Nesterov <oleg@tv-sign.ru>
To: Andrew Morton <akpm@osdl.org>
Cc: Thomas Graf <tgraf@suug.ch>,
Shailabh Nagar <nagar@watson.ibm.com>,
Balbir Singh <balbir@in.ibm.com>, Jay Lan <jlan@sgi.com>,
linux-kernel@vger.kernel.org
Subject: [PATCH 1/2] taskstats: factor out reply assembling
Date: Wed, 1 Nov 2006 21:26:11 +0300 [thread overview]
Message-ID: <20061101182611.GA447@oleg> (raw)
Introduce mk_reply() helper which does all nla_put()s on reply.
Saves 453 bytes and a preparation for the next patch.
Signed-off-by: Oleg Nesterov <oleg@tv-sign.ru>
taskstats.c | 55 ++++++++++++++++++++++++++++---------------------------
1 files changed, 28 insertions(+), 27 deletions(-)
--- STATS/kernel/taskstats.c~5_factor 2006-10-31 16:33:56.000000000 +0300
+++ STATS/kernel/taskstats.c 2006-11-01 14:00:03.000000000 +0300
@@ -348,6 +348,25 @@ static int parse(struct nlattr *na, cpum
return ret;
}
+static int mk_reply(struct sk_buff *skb, int type, u32 pid, struct taskstats *stats)
+{
+ struct nlattr *na;
+ int aggr;
+
+ aggr = TASKSTATS_TYPE_AGGR_TGID;
+ if (type == TASKSTATS_TYPE_PID)
+ aggr = TASKSTATS_TYPE_AGGR_PID;
+
+ na = nla_nest_start(skb, aggr);
+ NLA_PUT_U32(skb, type, pid);
+ NLA_PUT_TYPE(skb, struct taskstats, TASKSTATS_TYPE_STATS, *stats);
+ nla_nest_end(skb, na);
+
+ return 0;
+nla_put_failure:
+ return -1;
+}
+
static int taskstats_user_cmd(struct sk_buff *skb, struct genl_info *info)
{
int rc = 0;
@@ -355,7 +374,6 @@ static int taskstats_user_cmd(struct sk_
struct taskstats stats;
void *reply;
size_t size;
- struct nlattr *na;
cpumask_t mask;
rc = parse(info->attrs[TASKSTATS_CMD_ATTR_REGISTER_CPUMASK], &mask);
@@ -387,27 +405,21 @@ static int taskstats_user_cmd(struct sk_
if (rc < 0)
goto err;
- na = nla_nest_start(rep_skb, TASKSTATS_TYPE_AGGR_PID);
- NLA_PUT_U32(rep_skb, TASKSTATS_TYPE_PID, pid);
- NLA_PUT_TYPE(rep_skb, struct taskstats, TASKSTATS_TYPE_STATS,
- stats);
+ if (mk_reply(rep_skb, TASKSTATS_TYPE_PID, pid, &stats))
+ goto nla_put_failure;
} else if (info->attrs[TASKSTATS_CMD_ATTR_TGID]) {
u32 tgid = nla_get_u32(info->attrs[TASKSTATS_CMD_ATTR_TGID]);
rc = fill_tgid(tgid, NULL, &stats);
if (rc < 0)
goto err;
- na = nla_nest_start(rep_skb, TASKSTATS_TYPE_AGGR_TGID);
- NLA_PUT_U32(rep_skb, TASKSTATS_TYPE_TGID, tgid);
- NLA_PUT_TYPE(rep_skb, struct taskstats, TASKSTATS_TYPE_STATS,
- stats);
+ if (mk_reply(rep_skb, TASKSTATS_TYPE_TGID, tgid, &stats))
+ goto nla_put_failure;
} else {
rc = -EINVAL;
goto err;
}
- nla_nest_end(rep_skb, na);
-
return send_reply(rep_skb, info->snd_pid);
nla_put_failure:
@@ -451,7 +463,6 @@ void taskstats_exit(struct task_struct *
void *reply;
size_t size;
int is_thread_group;
- struct nlattr *na;
if (!family_registered)
return;
@@ -486,27 +497,17 @@ void taskstats_exit(struct task_struct *
if (rc < 0)
goto err_skb;
- na = nla_nest_start(rep_skb, TASKSTATS_TYPE_AGGR_PID);
- NLA_PUT_U32(rep_skb, TASKSTATS_TYPE_PID, (u32)tsk->pid);
- NLA_PUT_TYPE(rep_skb, struct taskstats, TASKSTATS_TYPE_STATS,
- *tidstats);
- nla_nest_end(rep_skb, na);
-
- if (!is_thread_group)
- goto send;
+ if (mk_reply(rep_skb, TASKSTATS_TYPE_PID, tsk->pid, tidstats))
+ goto nla_put_failure;
/*
* Doesn't matter if tsk is the leader or the last group member leaving
*/
- if (!group_dead)
+ if (!is_thread_group || !group_dead)
goto send;
- na = nla_nest_start(rep_skb, TASKSTATS_TYPE_AGGR_TGID);
- NLA_PUT_U32(rep_skb, TASKSTATS_TYPE_TGID, (u32)tsk->tgid);
- /* No locking needed for tsk->signal->stats since group is dead */
- NLA_PUT_TYPE(rep_skb, struct taskstats, TASKSTATS_TYPE_STATS,
- *tsk->signal->stats);
- nla_nest_end(rep_skb, na);
+ if (mk_reply(rep_skb, TASKSTATS_TYPE_TGID, tsk->tgid, tsk->signal->stats))
+ goto nla_put_failure;
send:
send_cpu_listeners(rep_skb, listeners);
next reply other threads:[~2006-11-01 18:26 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-11-01 18:26 Oleg Nesterov [this message]
2006-11-01 20:31 ` [PATCH 1/2] taskstats: factor out reply assembling Shailabh Nagar
2006-11-02 5:13 ` Balbir Singh
2006-11-02 13:22 ` Oleg Nesterov
2006-11-02 13:44 ` Balbir Singh
2006-11-02 10:34 ` Thomas Graf
2006-11-02 12:37 ` Shailabh Nagar
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20061101182611.GA447@oleg \
--to=oleg@tv-sign.ru \
--cc=akpm@osdl.org \
--cc=balbir@in.ibm.com \
--cc=jlan@sgi.com \
--cc=linux-kernel@vger.kernel.org \
--cc=nagar@watson.ibm.com \
--cc=tgraf@suug.ch \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.