From 46051cf8ad1437d7c0d4da33ead1e915611dde67 Mon Sep 17 00:00:00 2001 From: Pravin B Shelar Date: Mon, 20 Oct 2014 15:05:56 -0700 Subject: [PATCH] datapath: Replace __force type cast with rcu_dereference_raw(). rcu_dereference_raw() api is cleaner way of accessing RCU pointer when no locking is required. Signed-off-by: Pravin B Shelar Acked-by: Andy Zhou --- datapath/datapath.c | 2 +- datapath/flow_table.c | 8 ++++---- datapath/vport.c | 2 +- 3 files changed, 6 insertions(+), 6 deletions(-) diff --git a/datapath/datapath.c b/datapath/datapath.c index 31db569aa99..e53c5d52d60 100644 --- a/datapath/datapath.c +++ b/datapath/datapath.c @@ -1204,7 +1204,7 @@ static int ovs_flow_cmd_del(struct sk_buff *skb, struct genl_info *info) ovs_flow_tbl_remove(&dp->table, flow); ovs_unlock(); - reply = ovs_flow_cmd_alloc_info((const struct sw_flow_actions __force *)flow->sf_acts, + reply = ovs_flow_cmd_alloc_info(rcu_dereference_raw(flow->sf_acts), info, false); if (likely(reply)) { diff --git a/datapath/flow_table.c b/datapath/flow_table.c index 4efef134799..9656cfe0441 100644 --- a/datapath/flow_table.c +++ b/datapath/flow_table.c @@ -146,11 +146,11 @@ static void flow_free(struct sw_flow *flow) { int node; - kfree((struct sw_flow_actions __force *)flow->sf_acts); + kfree(rcu_dereference_raw(flow->sf_acts)); for_each_node(node) if (flow->stats[node]) kmem_cache_free(flow_stats_cache, - (struct flow_stats __force *)flow->stats[node]); + rcu_dereference_raw(flow->stats[node])); kmem_cache_free(flow_cache, flow); } @@ -334,10 +334,10 @@ static void table_instance_destroy(struct table_instance *ti, bool deferred) * error path. */ void ovs_flow_tbl_destroy(struct flow_table *table) { - struct table_instance *ti = (struct table_instance __force *)table->ti; + struct table_instance *ti = rcu_dereference_raw(table->ti); free_percpu(table->mask_cache); - kfree((struct mask_array __force *)table->mask_array); + kfree(rcu_dereference_raw(table->mask_array)); table_instance_destroy(ti, false); } diff --git a/datapath/vport.c b/datapath/vport.c index fd5290342e1..18f39569fdc 100644 --- a/datapath/vport.c +++ b/datapath/vport.c @@ -166,7 +166,7 @@ struct vport *ovs_vport_alloc(int priv_size, const struct vport_ops *ops, */ void ovs_vport_free(struct vport *vport) { - kfree((struct vport_portids __force *)vport->upcall_portids); + kfree(rcu_dereference_raw(vport->upcall_portids)); free_percpu(vport->percpu_stats); kfree(vport); }