diff --git a/fcst/ft_sess.c b/fcst/ft_sess.c index b506c463a..02f9dd9e8 100644 --- a/fcst/ft_sess.c +++ b/fcst/ft_sess.c @@ -78,6 +78,18 @@ static struct ft_tport *ft_tport_create(struct fc_lport *lport) return tport; } +#if LINUX_VERSION_CODE < KERNEL_VERSION(3, 0, 0) +/* + * Free tport via RCU. + */ +static void ft_tport_rcu_free(struct rcu_head *rcu) +{ + struct ft_tport *tport = container_of(rcu, struct ft_tport, rcu); + + kfree(tport); +} +#endif + /* * Delete target local port, if any, associated with the local port. * Caller holds ft_lport_lock. @@ -95,7 +107,11 @@ static void ft_tport_delete(struct ft_tport *tport) BUG_ON(tport != lport->prov[FC_TYPE_FCP]); rcu_assign_pointer(lport->prov[FC_TYPE_FCP], NULL); tport->lport = NULL; +#if LINUX_VERSION_CODE >= KERNEL_VERSION(3, 0, 0) kfree_rcu(tport, rcu); +#else + call_rcu(&tport->rcu, ft_tport_rcu_free); +#endif ft_tport_count--; }