aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/firewire/fw-ohci.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/firewire/fw-ohci.c')
-rw-r--r--drivers/firewire/fw-ohci.c46
1 files changed, 22 insertions, 24 deletions
diff --git a/drivers/firewire/fw-ohci.c b/drivers/firewire/fw-ohci.c
index ea43a5ed18cf..57eba7002b60 100644
--- a/drivers/firewire/fw-ohci.c
+++ b/drivers/firewire/fw-ohci.c
@@ -96,9 +96,9 @@ typedef int (*descriptor_callback_t)(struct context *ctx,
96 struct descriptor *d, 96 struct descriptor *d,
97 struct descriptor *last); 97 struct descriptor *last);
98struct context { 98struct context {
99 struct fw_ohci *ohci; 99 struct fw_ohci *ohci;
100 u32 regs; 100 u32 regs;
101 101
102 struct descriptor *buffer; 102 struct descriptor *buffer;
103 dma_addr_t buffer_bus; 103 dma_addr_t buffer_bus;
104 size_t buffer_size; 104 size_t buffer_size;
@@ -109,10 +109,8 @@ struct context {
109 109
110 descriptor_callback_t callback; 110 descriptor_callback_t callback;
111 111
112 struct tasklet_struct tasklet; 112 struct tasklet_struct tasklet;
113}; 113};
114
115
116 114
117struct at_context { 115struct at_context {
118 struct fw_ohci *ohci; 116 struct fw_ohci *ohci;
@@ -434,7 +432,7 @@ ar_context_init(struct ar_context *ctx, struct fw_ohci *ohci, u32 regs)
434 432
435 return 0; 433 return 0;
436} 434}
437 435
438static void context_tasklet(unsigned long data) 436static void context_tasklet(unsigned long data)
439{ 437{
440 struct context *ctx = (struct context *) data; 438 struct context *ctx = (struct context *) data;
@@ -1269,7 +1267,7 @@ ohci_enable_phys_dma(struct fw_card *card, int node_id, int generation)
1269 spin_unlock_irqrestore(&ohci->lock, flags); 1267 spin_unlock_irqrestore(&ohci->lock, flags);
1270 return retval; 1268 return retval;
1271} 1269}
1272 1270
1273static int handle_ir_bufferfill_packet(struct context *context, 1271static int handle_ir_bufferfill_packet(struct context *context,
1274 struct descriptor *d, 1272 struct descriptor *d,
1275 struct descriptor *last) 1273 struct descriptor *last)
@@ -1324,7 +1322,7 @@ static int handle_it_packet(struct context *context,
1324{ 1322{
1325 struct iso_context *ctx = 1323 struct iso_context *ctx =
1326 container_of(context, struct iso_context, context); 1324 container_of(context, struct iso_context, context);
1327 1325
1328 if (last->transfer_status == 0) 1326 if (last->transfer_status == 0)
1329 /* This descriptor isn't done yet, stop iteration. */ 1327 /* This descriptor isn't done yet, stop iteration. */
1330 return 0; 1328 return 0;
@@ -1352,8 +1350,8 @@ ohci_allocate_iso_context(struct fw_card *card, int type,
1352 list = ohci->it_context_list; 1350 list = ohci->it_context_list;
1353 callback = handle_it_packet; 1351 callback = handle_it_packet;
1354 } else { 1352 } else {
1355 mask = &ohci->ir_context_mask; 1353 mask = &ohci->ir_context_mask;
1356 list = ohci->ir_context_list; 1354 list = ohci->ir_context_list;
1357 if (header_size > 0) 1355 if (header_size > 0)
1358 callback = handle_ir_dualbuffer_packet; 1356 callback = handle_ir_dualbuffer_packet;
1359 else 1357 else
@@ -1373,11 +1371,11 @@ ohci_allocate_iso_context(struct fw_card *card, int type,
1373 if (index < 0) 1371 if (index < 0)
1374 return ERR_PTR(-EBUSY); 1372 return ERR_PTR(-EBUSY);
1375 1373
1376 if (type == FW_ISO_CONTEXT_TRANSMIT) 1374 if (type == FW_ISO_CONTEXT_TRANSMIT)
1377 regs = OHCI1394_IsoXmitContextBase(index); 1375 regs = OHCI1394_IsoXmitContextBase(index);
1378 else 1376 else
1379 regs = OHCI1394_IsoRcvContextBase(index); 1377 regs = OHCI1394_IsoRcvContextBase(index);
1380 1378
1381 ctx = &list[index]; 1379 ctx = &list[index];
1382 memset(ctx, 0, sizeof *ctx); 1380 memset(ctx, 0, sizeof *ctx);
1383 ctx->header_length = 0; 1381 ctx->header_length = 0;
@@ -1404,7 +1402,7 @@ ohci_allocate_iso_context(struct fw_card *card, int type,
1404 1402
1405static int ohci_start_iso(struct fw_iso_context *base, s32 cycle) 1403static int ohci_start_iso(struct fw_iso_context *base, s32 cycle)
1406{ 1404{
1407 struct iso_context *ctx = container_of(base, struct iso_context, base); 1405 struct iso_context *ctx = container_of(base, struct iso_context, base);
1408 struct fw_ohci *ohci = ctx->context.ohci; 1406 struct fw_ohci *ohci = ctx->context.ohci;
1409 u32 cycle_match = 0, mode; 1407 u32 cycle_match = 0, mode;
1410 int index; 1408 int index;
@@ -1439,7 +1437,7 @@ static int ohci_start_iso(struct fw_iso_context *base, s32 cycle)
1439static int ohci_stop_iso(struct fw_iso_context *base) 1437static int ohci_stop_iso(struct fw_iso_context *base)
1440{ 1438{
1441 struct fw_ohci *ohci = fw_ohci(base->card); 1439 struct fw_ohci *ohci = fw_ohci(base->card);
1442 struct iso_context *ctx = container_of(base, struct iso_context, base); 1440 struct iso_context *ctx = container_of(base, struct iso_context, base);
1443 int index; 1441 int index;
1444 1442
1445 if (ctx->base.type == FW_ISO_CONTEXT_TRANSMIT) { 1443 if (ctx->base.type == FW_ISO_CONTEXT_TRANSMIT) {
@@ -1458,7 +1456,7 @@ static int ohci_stop_iso(struct fw_iso_context *base)
1458static void ohci_free_iso_context(struct fw_iso_context *base) 1456static void ohci_free_iso_context(struct fw_iso_context *base)
1459{ 1457{
1460 struct fw_ohci *ohci = fw_ohci(base->card); 1458 struct fw_ohci *ohci = fw_ohci(base->card);
1461 struct iso_context *ctx = container_of(base, struct iso_context, base); 1459 struct iso_context *ctx = container_of(base, struct iso_context, base);
1462 unsigned long flags; 1460 unsigned long flags;
1463 int index; 1461 int index;
1464 1462
@@ -1485,7 +1483,7 @@ ohci_queue_iso_transmit(struct fw_iso_context *base,
1485 struct fw_iso_buffer *buffer, 1483 struct fw_iso_buffer *buffer,
1486 unsigned long payload) 1484 unsigned long payload)
1487{ 1485{
1488 struct iso_context *ctx = container_of(base, struct iso_context, base); 1486 struct iso_context *ctx = container_of(base, struct iso_context, base);
1489 struct descriptor *d, *last, *pd; 1487 struct descriptor *d, *last, *pd;
1490 struct fw_iso_packet *p; 1488 struct fw_iso_packet *p;
1491 __le32 *header; 1489 __le32 *header;
@@ -1575,7 +1573,7 @@ ohci_queue_iso_transmit(struct fw_iso_context *base,
1575 1573
1576 return 0; 1574 return 0;
1577} 1575}
1578 1576
1579static int 1577static int
1580setup_wait_descriptor(struct context *ctx) 1578setup_wait_descriptor(struct context *ctx)
1581{ 1579{
@@ -1609,7 +1607,7 @@ ohci_queue_iso_receive_dualbuffer(struct fw_iso_context *base,
1609 dma_addr_t d_bus, page_bus; 1607 dma_addr_t d_bus, page_bus;
1610 u32 z, header_z, length, rest; 1608 u32 z, header_z, length, rest;
1611 int page, offset; 1609 int page, offset;
1612 1610
1613 /* FIXME: Cycle lost behavior should be configurable: lose 1611 /* FIXME: Cycle lost behavior should be configurable: lose
1614 * packet, retransmit or terminate.. */ 1612 * packet, retransmit or terminate.. */
1615 1613
@@ -1641,7 +1639,7 @@ ohci_queue_iso_receive_dualbuffer(struct fw_iso_context *base,
1641 db->first_req_count = cpu_to_le16(p->header_length); 1639 db->first_req_count = cpu_to_le16(p->header_length);
1642 db->first_res_count = db->first_req_count; 1640 db->first_res_count = db->first_req_count;
1643 db->first_buffer = cpu_to_le32(d_bus + sizeof *db); 1641 db->first_buffer = cpu_to_le32(d_bus + sizeof *db);
1644 1642
1645 if (offset + rest < PAGE_SIZE) 1643 if (offset + rest < PAGE_SIZE)
1646 length = rest; 1644 length = rest;
1647 else 1645 else
@@ -1675,7 +1673,7 @@ ohci_queue_iso_receive_bufferfill(struct fw_iso_context *base,
1675 dma_addr_t d_bus, page_bus; 1673 dma_addr_t d_bus, page_bus;
1676 u32 length, rest; 1674 u32 length, rest;
1677 int page, offset; 1675 int page, offset;
1678 1676
1679 page = payload >> PAGE_SHIFT; 1677 page = payload >> PAGE_SHIFT;
1680 offset = payload & ~PAGE_MASK; 1678 offset = payload & ~PAGE_MASK;
1681 rest = packet->payload_length; 1679 rest = packet->payload_length;
@@ -1691,7 +1689,7 @@ ohci_queue_iso_receive_bufferfill(struct fw_iso_context *base,
1691 d->control = cpu_to_le16(descriptor_input_more | 1689 d->control = cpu_to_le16(descriptor_input_more |
1692 descriptor_status | 1690 descriptor_status |
1693 descriptor_branch_always); 1691 descriptor_branch_always);
1694 1692
1695 if (offset + rest < PAGE_SIZE) 1693 if (offset + rest < PAGE_SIZE)
1696 length = rest; 1694 length = rest;
1697 else 1695 else