diff options
author | Bartlomiej Zolnierkiewicz <bzolnier@gmail.com> | 2008-12-29 14:27:30 -0500 |
---|---|---|
committer | Bartlomiej Zolnierkiewicz <bzolnier@gmail.com> | 2008-12-29 14:27:30 -0500 |
commit | 44e312310889145b47311a311d3faf2488349116 (patch) | |
tree | bd4881b0bf875be77a75f57f097584610a78c1bd | |
parent | 1f473e9c92ea458e60494561a2065a358b7239bb (diff) |
ide: __ide_port_unregister_devices() doesn't need an ide_lock held
[ and ide_cfg_mtx mutex provides a sufficient protection for callers ]
Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
-rw-r--r-- | drivers/ide/ide.c | 7 |
1 files changed, 0 insertions, 7 deletions
diff --git a/drivers/ide/ide.c b/drivers/ide/ide.c index 04f8f13cb9d7..bca6877ee6a5 100644 --- a/drivers/ide/ide.c +++ b/drivers/ide/ide.c | |||
@@ -130,7 +130,6 @@ static void ide_port_init_devices_data(ide_hwif_t *hwif) | |||
130 | } | 130 | } |
131 | } | 131 | } |
132 | 132 | ||
133 | /* Called with ide_lock held. */ | ||
134 | static void __ide_port_unregister_devices(ide_hwif_t *hwif) | 133 | static void __ide_port_unregister_devices(ide_hwif_t *hwif) |
135 | { | 134 | { |
136 | int i; | 135 | int i; |
@@ -139,10 +138,8 @@ static void __ide_port_unregister_devices(ide_hwif_t *hwif) | |||
139 | ide_drive_t *drive = &hwif->drives[i]; | 138 | ide_drive_t *drive = &hwif->drives[i]; |
140 | 139 | ||
141 | if (drive->dev_flags & IDE_DFLAG_PRESENT) { | 140 | if (drive->dev_flags & IDE_DFLAG_PRESENT) { |
142 | spin_unlock_irq(&ide_lock); | ||
143 | device_unregister(&drive->gendev); | 141 | device_unregister(&drive->gendev); |
144 | wait_for_completion(&drive->gendev_rel_comp); | 142 | wait_for_completion(&drive->gendev_rel_comp); |
145 | spin_lock_irq(&ide_lock); | ||
146 | } | 143 | } |
147 | } | 144 | } |
148 | } | 145 | } |
@@ -150,11 +147,9 @@ static void __ide_port_unregister_devices(ide_hwif_t *hwif) | |||
150 | void ide_port_unregister_devices(ide_hwif_t *hwif) | 147 | void ide_port_unregister_devices(ide_hwif_t *hwif) |
151 | { | 148 | { |
152 | mutex_lock(&ide_cfg_mtx); | 149 | mutex_lock(&ide_cfg_mtx); |
153 | spin_lock_irq(&ide_lock); | ||
154 | __ide_port_unregister_devices(hwif); | 150 | __ide_port_unregister_devices(hwif); |
155 | hwif->present = 0; | 151 | hwif->present = 0; |
156 | ide_port_init_devices_data(hwif); | 152 | ide_port_init_devices_data(hwif); |
157 | spin_unlock_irq(&ide_lock); | ||
158 | mutex_unlock(&ide_cfg_mtx); | 153 | mutex_unlock(&ide_cfg_mtx); |
159 | } | 154 | } |
160 | EXPORT_SYMBOL_GPL(ide_port_unregister_devices); | 155 | EXPORT_SYMBOL_GPL(ide_port_unregister_devices); |
@@ -192,12 +187,10 @@ void ide_unregister(ide_hwif_t *hwif) | |||
192 | 187 | ||
193 | mutex_lock(&ide_cfg_mtx); | 188 | mutex_lock(&ide_cfg_mtx); |
194 | 189 | ||
195 | spin_lock_irq(&ide_lock); | ||
196 | if (hwif->present) { | 190 | if (hwif->present) { |
197 | __ide_port_unregister_devices(hwif); | 191 | __ide_port_unregister_devices(hwif); |
198 | hwif->present = 0; | 192 | hwif->present = 0; |
199 | } | 193 | } |
200 | spin_unlock_irq(&ide_lock); | ||
201 | 194 | ||
202 | ide_proc_unregister_port(hwif); | 195 | ide_proc_unregister_port(hwif); |
203 | 196 | ||