diff options
Diffstat (limited to 'drivers/firewire/ohci.c')
-rw-r--r-- | drivers/firewire/ohci.c | 17 |
1 files changed, 2 insertions, 15 deletions
diff --git a/drivers/firewire/ohci.c b/drivers/firewire/ohci.c index c0572283b93e..8f1e3ce930d6 100644 --- a/drivers/firewire/ohci.c +++ b/drivers/firewire/ohci.c | |||
@@ -1329,21 +1329,8 @@ static int at_context_queue_packet(struct context *ctx, | |||
1329 | DESCRIPTOR_IRQ_ALWAYS | | 1329 | DESCRIPTOR_IRQ_ALWAYS | |
1330 | DESCRIPTOR_BRANCH_ALWAYS); | 1330 | DESCRIPTOR_BRANCH_ALWAYS); |
1331 | 1331 | ||
1332 | /* | 1332 | /* FIXME: Document how the locking works. */ |
1333 | * If the controller and packet generations don't match, we need to | 1333 | if (ohci->generation != packet->generation) { |
1334 | * bail out and try again. If IntEvent.busReset is set, the AT context | ||
1335 | * is halted, so appending to the context and trying to run it is | ||
1336 | * futile. Most controllers do the right thing and just flush the AT | ||
1337 | * queue (per section 7.2.3.2 of the OHCI 1.1 specification), but | ||
1338 | * some controllers (like a JMicron JMB381 PCI-e) misbehave and wind | ||
1339 | * up stalling out. So we just bail out in software and try again | ||
1340 | * later, and everyone is happy. | ||
1341 | * FIXME: Test of IntEvent.busReset may no longer be necessary since we | ||
1342 | * flush AT queues in bus_reset_tasklet. | ||
1343 | * FIXME: Document how the locking works. | ||
1344 | */ | ||
1345 | if (ohci->generation != packet->generation || | ||
1346 | reg_read(ohci, OHCI1394_IntEventSet) & OHCI1394_busReset) { | ||
1347 | if (packet->payload_mapped) | 1334 | if (packet->payload_mapped) |
1348 | dma_unmap_single(ohci->card.device, payload_bus, | 1335 | dma_unmap_single(ohci->card.device, payload_bus, |
1349 | packet->payload_length, DMA_TO_DEVICE); | 1336 | packet->payload_length, DMA_TO_DEVICE); |