* [B.A.T.M.A.N.] [PATCHv2] batman-adv: don't use call_rcu if not needed
@ 2013-05-06 22:29 Antonio Quartulli
2013-05-12 7:30 ` Marek Lindner
0 siblings, 1 reply; 2+ messages in thread
From: Antonio Quartulli @ 2013-05-06 22:29 UTC (permalink / raw)
To: b.a.t.m.a.n; +Cc: Antonio Quartulli
batadv_tt_global_entry_free_ref uses call_rcu to schedule a
function which will only free the global entry itself.
For this reason call_rcu is useless and kfree_rcu can be
used to simplify the code.
Signed-off-by: Antonio Quartulli <ordex@autistici.org>
---
v2:
- removed one useless container_of in compat.c
compat.c | 9 +++++++++
translation-table.c | 20 ++++++--------------
2 files changed, 15 insertions(+), 14 deletions(-)
diff --git a/compat.c b/compat.c
index 1f3a39d..da556a4 100644
--- a/compat.c
+++ b/compat.c
@@ -27,6 +27,15 @@
#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 0, 0)
+void batadv_free_rcu_tt_global_entry(struct rcu_head *rcu)
+{
+ struct batadv_tt_global_entry *global;
+
+ global = container_of(rcu, struct batadv_tt_global_entry, common.rcu);
+
+ kfree(global);
+}
+
void batadv_free_rcu_gw_node(struct rcu_head *rcu)
{
struct batadv_gw_node *gw_node;
diff --git a/translation-table.c b/translation-table.c
index df6b5cd..44e7789 100644
--- a/translation-table.c
+++ b/translation-table.c
@@ -117,25 +117,17 @@ batadv_tt_local_entry_free_ref(struct batadv_tt_local_entry *tt_local_entry)
kfree_rcu(tt_local_entry, common.rcu);
}
-static void batadv_tt_global_entry_free_rcu(struct rcu_head *rcu)
-{
- struct batadv_tt_common_entry *tt_common_entry;
- struct batadv_tt_global_entry *tt_global_entry;
-
- tt_common_entry = container_of(rcu, struct batadv_tt_common_entry, rcu);
- tt_global_entry = container_of(tt_common_entry,
- struct batadv_tt_global_entry, common);
-
- kfree(tt_global_entry);
-}
-
+/**
+ * batadv_tt_global_entry_free_ref - decrement the refcounter for a
+ * tt_global_entry and possibly free it
+ * @tt_global_entry: the object to free
+ */
static void
batadv_tt_global_entry_free_ref(struct batadv_tt_global_entry *tt_global_entry)
{
if (atomic_dec_and_test(&tt_global_entry->common.refcount)) {
batadv_tt_global_del_orig_list(tt_global_entry);
- call_rcu(&tt_global_entry->common.rcu,
- batadv_tt_global_entry_free_rcu);
+ kfree_rcu(tt_global_entry, common.rcu);
}
}
--
1.8.1.5
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [B.A.T.M.A.N.] [PATCHv2] batman-adv: don't use call_rcu if not needed
2013-05-06 22:29 [B.A.T.M.A.N.] [PATCHv2] batman-adv: don't use call_rcu if not needed Antonio Quartulli
@ 2013-05-12 7:30 ` Marek Lindner
0 siblings, 0 replies; 2+ messages in thread
From: Marek Lindner @ 2013-05-12 7:30 UTC (permalink / raw)
To: b.a.t.m.a.n; +Cc: Antonio Quartulli
On Tuesday, May 07, 2013 06:29:22 Antonio Quartulli wrote:
> batadv_tt_global_entry_free_ref uses call_rcu to schedule a
> function which will only free the global entry itself.
>
> For this reason call_rcu is useless and kfree_rcu can be
> used to simplify the code.
>
> Signed-off-by: Antonio Quartulli <ordex@autistici.org>
> ---
>
> v2:
> - removed one useless container_of in compat.c
>
> compat.c | 9 +++++++++
> translation-table.c | 20 ++++++--------------
> 2 files changed, 15 insertions(+), 14 deletions(-)
Applied in revision 1bd8161.
Thanks,
Marek
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2013-05-12 7:30 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2013-05-06 22:29 [B.A.T.M.A.N.] [PATCHv2] batman-adv: don't use call_rcu if not needed Antonio Quartulli
2013-05-12 7:30 ` Marek Lindner
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox