ide: fix accidental LOCKDEP breakage caused by local_irq_set() removal
commit 54cc1428cf
("ide: remove
local_irq_set() macro") accidentally replaced local_save_flags()
by local_irq_set() in ide_probe_port() and __ide_wait_stat()
which resulted in LOCKDEP breakage.
Reported-by: Larry Finger <Larry.Finger@lwfinger.net>
Tested-by: Larry Finger <Larry.Finger@lwfinger.net>
Signed-off-by: Bartlomiej Zolnierkiewicz <bzolnier@gmail.com>
This commit is contained in:
parent
a6525042bf
commit
9b896033aa
|
@ -493,7 +493,7 @@ static int __ide_wait_stat(ide_drive_t *drive, u8 good, u8 bad, unsigned long ti
|
||||||
stat = tp_ops->read_status(hwif);
|
stat = tp_ops->read_status(hwif);
|
||||||
|
|
||||||
if (stat & ATA_BUSY) {
|
if (stat & ATA_BUSY) {
|
||||||
local_irq_save(flags);
|
local_save_flags(flags);
|
||||||
local_irq_enable_in_hardirq();
|
local_irq_enable_in_hardirq();
|
||||||
timeout += jiffies;
|
timeout += jiffies;
|
||||||
while ((stat = tp_ops->read_status(hwif)) & ATA_BUSY) {
|
while ((stat = tp_ops->read_status(hwif)) & ATA_BUSY) {
|
||||||
|
|
|
@ -796,7 +796,7 @@ static int ide_probe_port(ide_hwif_t *hwif)
|
||||||
if (irqd)
|
if (irqd)
|
||||||
disable_irq(hwif->irq);
|
disable_irq(hwif->irq);
|
||||||
|
|
||||||
local_irq_save(flags);
|
local_save_flags(flags);
|
||||||
local_irq_enable_in_hardirq();
|
local_irq_enable_in_hardirq();
|
||||||
|
|
||||||
if (ide_port_wait_ready(hwif) == -EBUSY)
|
if (ide_port_wait_ready(hwif) == -EBUSY)
|
||||||
|
|
Loading…
Reference in New Issue