diff options
author | Kristian Høgsberg <krh@redhat.com> | 2007-03-28 14:26:10 -0400 |
---|---|---|
committer | Stefan Richter <stefanr@s5r6.in-berlin.de> | 2007-03-28 15:37:54 -0400 |
commit | 8a2f7d932fc6a4881ff837738e23b41a1c228338 (patch) | |
tree | f8dd2b550d8b5d2462b64e1d1595493f227a9060 /drivers | |
parent | ef370ee74b7a9cb769d50bfb73b4023ee3e37719 (diff) |
firewire: Fix start on cycle 0 for IT, implement start on cycle for IR.
Signed-off-by: Kristian Høgsberg <krh@redhat.com>
Signed-off-by: Stefan Richter <stefanr@s5r6.in-berlin.de>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/firewire/fw-ohci.c | 22 |
1 files changed, 13 insertions, 9 deletions
diff --git a/drivers/firewire/fw-ohci.c b/drivers/firewire/fw-ohci.c index afd18173cca1..b941239671d6 100644 --- a/drivers/firewire/fw-ohci.c +++ b/drivers/firewire/fw-ohci.c | |||
@@ -1362,28 +1362,32 @@ static int ohci_start_iso(struct fw_iso_context *base, | |||
1362 | { | 1362 | { |
1363 | struct iso_context *ctx = container_of(base, struct iso_context, base); | 1363 | struct iso_context *ctx = container_of(base, struct iso_context, base); |
1364 | struct fw_ohci *ohci = ctx->context.ohci; | 1364 | struct fw_ohci *ohci = ctx->context.ohci; |
1365 | u32 cycle_match = 0; | 1365 | u32 control, match; |
1366 | int index; | 1366 | int index; |
1367 | 1367 | ||
1368 | if (ctx->base.type == FW_ISO_CONTEXT_TRANSMIT) { | 1368 | if (ctx->base.type == FW_ISO_CONTEXT_TRANSMIT) { |
1369 | index = ctx - ohci->it_context_list; | 1369 | index = ctx - ohci->it_context_list; |
1370 | if (cycle > 0) | 1370 | match = 0; |
1371 | cycle_match = IT_CONTEXT_CYCLE_MATCH_ENABLE | | 1371 | if (cycle >= 0) |
1372 | match = IT_CONTEXT_CYCLE_MATCH_ENABLE | | ||
1372 | (cycle & 0x7fff) << 16; | 1373 | (cycle & 0x7fff) << 16; |
1373 | 1374 | ||
1374 | reg_write(ohci, OHCI1394_IsoXmitIntEventClear, 1 << index); | 1375 | reg_write(ohci, OHCI1394_IsoXmitIntEventClear, 1 << index); |
1375 | reg_write(ohci, OHCI1394_IsoXmitIntMaskSet, 1 << index); | 1376 | reg_write(ohci, OHCI1394_IsoXmitIntMaskSet, 1 << index); |
1376 | context_run(&ctx->context, cycle_match); | 1377 | context_run(&ctx->context, match); |
1377 | } else { | 1378 | } else { |
1378 | index = ctx - ohci->ir_context_list; | 1379 | index = ctx - ohci->ir_context_list; |
1380 | control = IR_CONTEXT_DUAL_BUFFER_MODE | IR_CONTEXT_ISOCH_HEADER; | ||
1381 | match = (tags << 28) | (sync << 8) | ctx->base.channel; | ||
1382 | if (cycle >= 0) { | ||
1383 | match |= (cycle & 0x07fff) << 12; | ||
1384 | control |= IR_CONTEXT_CYCLE_MATCH_ENABLE; | ||
1385 | } | ||
1379 | 1386 | ||
1380 | reg_write(ohci, OHCI1394_IsoRecvIntEventClear, 1 << index); | 1387 | reg_write(ohci, OHCI1394_IsoRecvIntEventClear, 1 << index); |
1381 | reg_write(ohci, OHCI1394_IsoRecvIntMaskSet, 1 << index); | 1388 | reg_write(ohci, OHCI1394_IsoRecvIntMaskSet, 1 << index); |
1382 | reg_write(ohci, context_match(ctx->context.regs), | 1389 | reg_write(ohci, context_match(ctx->context.regs), match); |
1383 | (tags << 28) | (sync << 8) | ctx->base.channel); | 1390 | context_run(&ctx->context, control); |
1384 | context_run(&ctx->context, | ||
1385 | IR_CONTEXT_DUAL_BUFFER_MODE | | ||
1386 | IR_CONTEXT_ISOCH_HEADER); | ||
1387 | } | 1391 | } |
1388 | 1392 | ||
1389 | return 0; | 1393 | return 0; |