Commit ef60cd13 authored by Sebastian Ott's avatar Sebastian Ott Committed by Heiko Carstens

[S390] cio: fix double unregistering of subchannels

In some cases where the channel subsystem decides to drop a subchannel
device device_unregister may be called twice, which results in an oops.
The patch prevents this by only unregistering registered devices.
Signed-off-by: default avatarSebastian Ott <sebott@linux.vnet.ibm.com>
Signed-off-by: default avatarHeiko Carstens <heiko.carstens@de.ibm.com>
Signed-off-by: default avatarMartin Schwidefsky <schwidefsky@de.ibm.com>
parent e0bc2495
...@@ -164,7 +164,8 @@ static int css_sch_device_register(struct subchannel *sch) ...@@ -164,7 +164,8 @@ static int css_sch_device_register(struct subchannel *sch)
void css_sch_device_unregister(struct subchannel *sch) void css_sch_device_unregister(struct subchannel *sch)
{ {
mutex_lock(&sch->reg_mutex); mutex_lock(&sch->reg_mutex);
device_unregister(&sch->dev); if (device_is_registered(&sch->dev))
device_unregister(&sch->dev);
mutex_unlock(&sch->reg_mutex); mutex_unlock(&sch->reg_mutex);
} }
EXPORT_SYMBOL_GPL(css_sch_device_unregister); EXPORT_SYMBOL_GPL(css_sch_device_unregister);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment