|
@@ -1064,7 +1064,8 @@ static void ib_sa_remove_one(struct ib_device *device)
|
|
|
|
|
|
for (i = 0; i <= sa_dev->end_port - sa_dev->start_port; ++i) {
|
|
for (i = 0; i <= sa_dev->end_port - sa_dev->start_port; ++i) {
|
|
ib_unregister_mad_agent(sa_dev->port[i].agent);
|
|
ib_unregister_mad_agent(sa_dev->port[i].agent);
|
|
- kref_put(&sa_dev->port[i].sm_ah->ref, free_sm_ah);
|
|
|
|
|
|
+ if (sa_dev->port[i].sm_ah)
|
|
|
|
+ kref_put(&sa_dev->port[i].sm_ah->ref, free_sm_ah);
|
|
}
|
|
}
|
|
|
|
|
|
kfree(sa_dev);
|
|
kfree(sa_dev);
|