diff options
Diffstat (limited to 'drivers/firewire')
-rw-r--r-- | drivers/firewire/fw-ohci.c | 360 | ||||
-rw-r--r-- | drivers/firewire/fw-transaction.h | 3 |
2 files changed, 149 insertions, 214 deletions
diff --git a/drivers/firewire/fw-ohci.c b/drivers/firewire/fw-ohci.c index 37467923e98b..9e8a8f909303 100644 --- a/drivers/firewire/fw-ohci.c +++ b/drivers/firewire/fw-ohci.c | |||
@@ -112,25 +112,6 @@ struct context { | |||
112 | struct tasklet_struct tasklet; | 112 | struct tasklet_struct tasklet; |
113 | }; | 113 | }; |
114 | 114 | ||
115 | struct at_context { | ||
116 | struct fw_ohci *ohci; | ||
117 | dma_addr_t descriptor_bus; | ||
118 | dma_addr_t buffer_bus; | ||
119 | struct fw_packet *current_packet; | ||
120 | |||
121 | struct list_head list; | ||
122 | |||
123 | struct { | ||
124 | struct descriptor more; | ||
125 | __le32 header[4]; | ||
126 | struct descriptor last; | ||
127 | } d; | ||
128 | |||
129 | u32 regs; | ||
130 | |||
131 | struct tasklet_struct tasklet; | ||
132 | }; | ||
133 | |||
134 | #define it_header_sy(v) ((v) << 0) | 115 | #define it_header_sy(v) ((v) << 0) |
135 | #define it_header_tcode(v) ((v) << 4) | 116 | #define it_header_tcode(v) ((v) << 4) |
136 | #define it_header_channel(v) ((v) << 8) | 117 | #define it_header_channel(v) ((v) << 8) |
@@ -173,8 +154,8 @@ struct fw_ohci { | |||
173 | 154 | ||
174 | struct ar_context ar_request_ctx; | 155 | struct ar_context ar_request_ctx; |
175 | struct ar_context ar_response_ctx; | 156 | struct ar_context ar_response_ctx; |
176 | struct at_context at_request_ctx; | 157 | struct context at_request_ctx; |
177 | struct at_context at_response_ctx; | 158 | struct context at_response_ctx; |
178 | 159 | ||
179 | u32 it_context_mask; | 160 | u32 it_context_mask; |
180 | struct iso_context *it_context_list; | 161 | struct iso_context *it_context_list; |
@@ -210,6 +191,8 @@ static inline struct fw_ohci *fw_ohci(struct fw_card *card) | |||
210 | #define SELF_ID_BUF_SIZE 0x800 | 191 | #define SELF_ID_BUF_SIZE 0x800 |
211 | #define OHCI_TCODE_PHY_PACKET 0x0e | 192 | #define OHCI_TCODE_PHY_PACKET 0x0e |
212 | #define OHCI_VERSION_1_1 0x010010 | 193 | #define OHCI_VERSION_1_1 0x010010 |
194 | #define ISO_BUFFER_SIZE (64 * 1024) | ||
195 | #define AT_BUFFER_SIZE 4096 | ||
213 | 196 | ||
214 | static char ohci_driver_name[] = KBUILD_MODNAME; | 197 | static char ohci_driver_name[] = KBUILD_MODNAME; |
215 | 198 | ||
@@ -587,210 +570,166 @@ static void context_stop(struct context *ctx) | |||
587 | } | 570 | } |
588 | } | 571 | } |
589 | 572 | ||
590 | static void | 573 | struct driver_data { |
591 | do_packet_callbacks(struct fw_ohci *ohci, struct list_head *list) | 574 | struct fw_packet *packet; |
592 | { | 575 | }; |
593 | struct fw_packet *p, *next; | ||
594 | |||
595 | list_for_each_entry_safe(p, next, list, link) | ||
596 | p->callback(p, &ohci->card, p->ack); | ||
597 | } | ||
598 | |||
599 | static void | ||
600 | complete_transmission(struct fw_packet *packet, | ||
601 | int ack, struct list_head *list) | ||
602 | { | ||
603 | list_move_tail(&packet->link, list); | ||
604 | packet->ack = ack; | ||
605 | } | ||
606 | 576 | ||
607 | /* This function prepares the first packet in the context queue for | 577 | /* This function apppends a packet to the DMA queue for transmission. |
608 | * transmission. Must always be called with the ochi->lock held to | 578 | * Must always be called with the ochi->lock held to ensure proper |
609 | * ensure proper generation handling and locking around packet queue | 579 | * generation handling and locking around packet queue manipulation. */ |
610 | * manipulation. */ | 580 | static int |
611 | static void | 581 | at_context_queue_packet(struct context *ctx, struct fw_packet *packet) |
612 | at_context_setup_packet(struct at_context *ctx, struct list_head *list) | ||
613 | { | 582 | { |
614 | struct fw_packet *packet; | ||
615 | struct fw_ohci *ohci = ctx->ohci; | 583 | struct fw_ohci *ohci = ctx->ohci; |
584 | dma_addr_t d_bus, payload_bus; | ||
585 | struct driver_data *driver_data; | ||
586 | struct descriptor *d, *last; | ||
587 | __le32 *header; | ||
616 | int z, tcode; | 588 | int z, tcode; |
589 | u32 reg; | ||
617 | 590 | ||
618 | packet = fw_packet(ctx->list.next); | 591 | d = context_get_descriptors(ctx, 4, &d_bus); |
619 | 592 | if (d == NULL) { | |
620 | memset(&ctx->d, 0, sizeof ctx->d); | 593 | packet->ack = RCODE_SEND_ERROR; |
621 | if (packet->payload_length > 0) { | 594 | return -1; |
622 | packet->payload_bus = dma_map_single(ohci->card.device, | ||
623 | packet->payload, | ||
624 | packet->payload_length, | ||
625 | DMA_TO_DEVICE); | ||
626 | if (dma_mapping_error(packet->payload_bus)) { | ||
627 | complete_transmission(packet, RCODE_SEND_ERROR, list); | ||
628 | return; | ||
629 | } | ||
630 | |||
631 | ctx->d.more.control = | ||
632 | cpu_to_le16(descriptor_output_more | | ||
633 | descriptor_key_immediate); | ||
634 | ctx->d.more.req_count = cpu_to_le16(packet->header_length); | ||
635 | ctx->d.more.res_count = cpu_to_le16(packet->timestamp); | ||
636 | ctx->d.last.control = | ||
637 | cpu_to_le16(descriptor_output_last | | ||
638 | descriptor_irq_always | | ||
639 | descriptor_branch_always); | ||
640 | ctx->d.last.req_count = cpu_to_le16(packet->payload_length); | ||
641 | ctx->d.last.data_address = cpu_to_le32(packet->payload_bus); | ||
642 | z = 3; | ||
643 | } else { | ||
644 | ctx->d.more.control = | ||
645 | cpu_to_le16(descriptor_output_last | | ||
646 | descriptor_key_immediate | | ||
647 | descriptor_irq_always | | ||
648 | descriptor_branch_always); | ||
649 | ctx->d.more.req_count = cpu_to_le16(packet->header_length); | ||
650 | ctx->d.more.res_count = cpu_to_le16(packet->timestamp); | ||
651 | z = 2; | ||
652 | } | 595 | } |
653 | 596 | ||
597 | d[0].control = cpu_to_le16(descriptor_key_immediate); | ||
598 | d[0].res_count = cpu_to_le16(packet->timestamp); | ||
599 | |||
654 | /* The DMA format for asyncronous link packets is different | 600 | /* The DMA format for asyncronous link packets is different |
655 | * from the IEEE1394 layout, so shift the fields around | 601 | * from the IEEE1394 layout, so shift the fields around |
656 | * accordingly. If header_length is 8, it's a PHY packet, to | 602 | * accordingly. If header_length is 8, it's a PHY packet, to |
657 | * which we need to prepend an extra quadlet. */ | 603 | * which we need to prepend an extra quadlet. */ |
604 | |||
605 | header = (__le32 *) &d[1]; | ||
658 | if (packet->header_length > 8) { | 606 | if (packet->header_length > 8) { |
659 | ctx->d.header[0] = cpu_to_le32((packet->header[0] & 0xffff) | | 607 | header[0] = cpu_to_le32((packet->header[0] & 0xffff) | |
660 | (packet->speed << 16)); | 608 | (packet->speed << 16)); |
661 | ctx->d.header[1] = cpu_to_le32((packet->header[1] & 0xffff) | | 609 | header[1] = cpu_to_le32((packet->header[1] & 0xffff) | |
662 | (packet->header[0] & 0xffff0000)); | 610 | (packet->header[0] & 0xffff0000)); |
663 | ctx->d.header[2] = cpu_to_le32(packet->header[2]); | 611 | header[2] = cpu_to_le32(packet->header[2]); |
664 | 612 | ||
665 | tcode = (packet->header[0] >> 4) & 0x0f; | 613 | tcode = (packet->header[0] >> 4) & 0x0f; |
666 | if (TCODE_IS_BLOCK_PACKET(tcode)) | 614 | if (TCODE_IS_BLOCK_PACKET(tcode)) |
667 | ctx->d.header[3] = cpu_to_le32(packet->header[3]); | 615 | header[3] = cpu_to_le32(packet->header[3]); |
668 | else | 616 | else |
669 | ctx->d.header[3] = packet->header[3]; | 617 | header[3] = (__force __le32) packet->header[3]; |
618 | |||
619 | d[0].req_count = cpu_to_le16(packet->header_length); | ||
670 | } else { | 620 | } else { |
671 | ctx->d.header[0] = | 621 | header[0] = cpu_to_le32((OHCI1394_phy_tcode << 4) | |
672 | cpu_to_le32((OHCI1394_phy_tcode << 4) | | 622 | (packet->speed << 16)); |
673 | (packet->speed << 16)); | 623 | header[1] = cpu_to_le32(packet->header[0]); |
674 | ctx->d.header[1] = cpu_to_le32(packet->header[0]); | 624 | header[2] = cpu_to_le32(packet->header[1]); |
675 | ctx->d.header[2] = cpu_to_le32(packet->header[1]); | 625 | d[0].req_count = cpu_to_le16(12); |
676 | ctx->d.more.req_count = cpu_to_le16(12); | ||
677 | } | 626 | } |
678 | 627 | ||
679 | /* FIXME: Document how the locking works. */ | 628 | driver_data = (struct driver_data *) &d[3]; |
680 | if (ohci->generation == packet->generation) { | 629 | driver_data->packet = packet; |
681 | reg_write(ctx->ohci, command_ptr(ctx->regs), | 630 | |
682 | ctx->descriptor_bus | z); | 631 | if (packet->payload_length > 0) { |
683 | reg_write(ctx->ohci, control_set(ctx->regs), | 632 | payload_bus = |
684 | CONTEXT_RUN | CONTEXT_WAKE); | 633 | dma_map_single(ohci->card.device, packet->payload, |
685 | ctx->current_packet = packet; | 634 | packet->payload_length, DMA_TO_DEVICE); |
635 | if (dma_mapping_error(payload_bus)) { | ||
636 | packet->ack = RCODE_SEND_ERROR; | ||
637 | return -1; | ||
638 | } | ||
639 | |||
640 | d[2].req_count = cpu_to_le16(packet->payload_length); | ||
641 | d[2].data_address = cpu_to_le32(payload_bus); | ||
642 | last = &d[2]; | ||
643 | z = 3; | ||
686 | } else { | 644 | } else { |
687 | /* We dont return error codes from this function; all | 645 | last = &d[0]; |
688 | * transmission errors are reported through the | 646 | z = 2; |
689 | * callback. */ | ||
690 | complete_transmission(packet, RCODE_GENERATION, list); | ||
691 | } | 647 | } |
692 | } | ||
693 | 648 | ||
694 | static void at_context_stop(struct at_context *ctx) | 649 | last->control |= cpu_to_le16(descriptor_output_last | |
695 | { | 650 | descriptor_irq_always | |
696 | u32 reg; | 651 | descriptor_branch_always); |
697 | 652 | ||
698 | reg_write(ctx->ohci, control_clear(ctx->regs), CONTEXT_RUN); | 653 | /* FIXME: Document how the locking works. */ |
654 | if (ohci->generation != packet->generation) { | ||
655 | packet->ack = RCODE_GENERATION; | ||
656 | return -1; | ||
657 | } | ||
658 | |||
659 | context_append(ctx, d, z, 4 - z); | ||
699 | 660 | ||
661 | /* If the context isn't already running, start it up. */ | ||
700 | reg = reg_read(ctx->ohci, control_set(ctx->regs)); | 662 | reg = reg_read(ctx->ohci, control_set(ctx->regs)); |
701 | if (reg & CONTEXT_ACTIVE) | 663 | if ((reg & CONTEXT_ACTIVE) == 0) |
702 | fw_notify("Tried to stop context, but it is still active " | 664 | context_run(ctx, 0); |
703 | "(0x%08x).\n", reg); | 665 | |
666 | return 0; | ||
704 | } | 667 | } |
705 | 668 | ||
706 | static void at_context_tasklet(unsigned long data) | 669 | static int handle_at_packet(struct context *context, |
670 | struct descriptor *d, | ||
671 | struct descriptor *last) | ||
707 | { | 672 | { |
708 | struct at_context *ctx = (struct at_context *)data; | 673 | struct driver_data *driver_data; |
709 | struct fw_ohci *ohci = ctx->ohci; | ||
710 | struct fw_packet *packet; | 674 | struct fw_packet *packet; |
711 | LIST_HEAD(list); | 675 | struct fw_ohci *ohci = context->ohci; |
712 | unsigned long flags; | 676 | dma_addr_t payload_bus; |
713 | int evt; | 677 | int evt; |
714 | 678 | ||
715 | spin_lock_irqsave(&ohci->lock, flags); | 679 | if (last->transfer_status == 0) |
716 | 680 | /* This descriptor isn't done yet, stop iteration. */ | |
717 | packet = fw_packet(ctx->list.next); | 681 | return 0; |
718 | |||
719 | at_context_stop(ctx); | ||
720 | 682 | ||
721 | /* If the head of the list isn't the packet that just got | 683 | driver_data = (struct driver_data *) &d[3]; |
722 | * transmitted, the packet got cancelled before we finished | 684 | packet = driver_data->packet; |
723 | * transmitting it. */ | 685 | if (packet == NULL) |
724 | if (ctx->current_packet != packet) | 686 | /* This packet was cancelled, just continue. */ |
725 | goto skip_to_next; | 687 | return 1; |
726 | 688 | ||
727 | if (packet->payload_length > 0) { | 689 | payload_bus = le32_to_cpu(last->data_address); |
728 | dma_unmap_single(ohci->card.device, packet->payload_bus, | 690 | if (payload_bus != 0) |
691 | dma_unmap_single(ohci->card.device, payload_bus, | ||
729 | packet->payload_length, DMA_TO_DEVICE); | 692 | packet->payload_length, DMA_TO_DEVICE); |
730 | evt = le16_to_cpu(ctx->d.last.transfer_status) & 0x1f; | ||
731 | packet->timestamp = le16_to_cpu(ctx->d.last.res_count); | ||
732 | } | ||
733 | else { | ||
734 | evt = le16_to_cpu(ctx->d.more.transfer_status) & 0x1f; | ||
735 | packet->timestamp = le16_to_cpu(ctx->d.more.res_count); | ||
736 | } | ||
737 | |||
738 | if (evt < 16) { | ||
739 | switch (evt) { | ||
740 | case OHCI1394_evt_timeout: | ||
741 | /* Async response transmit timed out. */ | ||
742 | complete_transmission(packet, RCODE_CANCELLED, &list); | ||
743 | break; | ||
744 | |||
745 | case OHCI1394_evt_flushed: | ||
746 | /* The packet was flushed should give same | ||
747 | * error as when we try to use a stale | ||
748 | * generation count. */ | ||
749 | complete_transmission(packet, | ||
750 | RCODE_GENERATION, &list); | ||
751 | break; | ||
752 | |||
753 | case OHCI1394_evt_missing_ack: | ||
754 | /* Using a valid (current) generation count, | ||
755 | * but the node is not on the bus or not | ||
756 | * sending acks. */ | ||
757 | complete_transmission(packet, RCODE_NO_ACK, &list); | ||
758 | break; | ||
759 | |||
760 | default: | ||
761 | complete_transmission(packet, RCODE_SEND_ERROR, &list); | ||
762 | break; | ||
763 | } | ||
764 | } else | ||
765 | complete_transmission(packet, evt - 16, &list); | ||
766 | 693 | ||
767 | skip_to_next: | 694 | evt = le16_to_cpu(last->transfer_status) & 0x1f; |
768 | /* If more packets are queued, set up the next one. */ | 695 | packet->timestamp = le16_to_cpu(last->res_count); |
769 | if (!list_empty(&ctx->list)) | ||
770 | at_context_setup_packet(ctx, &list); | ||
771 | 696 | ||
772 | spin_unlock_irqrestore(&ohci->lock, flags); | 697 | switch (evt) { |
698 | case OHCI1394_evt_timeout: | ||
699 | /* Async response transmit timed out. */ | ||
700 | packet->ack = RCODE_CANCELLED; | ||
701 | break; | ||
773 | 702 | ||
774 | do_packet_callbacks(ohci, &list); | 703 | case OHCI1394_evt_flushed: |
775 | } | 704 | /* The packet was flushed should give same error as |
705 | * when we try to use a stale generation count. */ | ||
706 | packet->ack = RCODE_GENERATION; | ||
707 | break; | ||
776 | 708 | ||
777 | static int | 709 | case OHCI1394_evt_missing_ack: |
778 | at_context_init(struct at_context *ctx, struct fw_ohci *ohci, u32 regs) | 710 | /* Using a valid (current) generation count, but the |
779 | { | 711 | * node is not on the bus or not sending acks. */ |
780 | INIT_LIST_HEAD(&ctx->list); | 712 | packet->ack = RCODE_NO_ACK; |
713 | break; | ||
781 | 714 | ||
782 | ctx->descriptor_bus = | 715 | case ACK_COMPLETE + 0x10: |
783 | dma_map_single(ohci->card.device, &ctx->d, | 716 | case ACK_PENDING + 0x10: |
784 | sizeof ctx->d, DMA_TO_DEVICE); | 717 | case ACK_BUSY_X + 0x10: |
785 | if (dma_mapping_error(ctx->descriptor_bus)) | 718 | case ACK_BUSY_A + 0x10: |
786 | return -ENOMEM; | 719 | case ACK_BUSY_B + 0x10: |
720 | case ACK_DATA_ERROR + 0x10: | ||
721 | case ACK_TYPE_ERROR + 0x10: | ||
722 | packet->ack = evt - 0x10; | ||
723 | break; | ||
787 | 724 | ||
788 | ctx->regs = regs; | 725 | default: |
789 | ctx->ohci = ohci; | 726 | packet->ack = RCODE_SEND_ERROR; |
727 | break; | ||
728 | } | ||
790 | 729 | ||
791 | tasklet_init(&ctx->tasklet, at_context_tasklet, (unsigned long)ctx); | 730 | packet->callback(packet, &ohci->card, packet->ack); |
792 | 731 | ||
793 | return 0; | 732 | return 1; |
794 | } | 733 | } |
795 | 734 | ||
796 | #define header_get_destination(q) (((q) >> 16) & 0xffff) | 735 | #define header_get_destination(q) (((q) >> 16) & 0xffff) |
@@ -869,7 +808,7 @@ handle_local_lock(struct fw_ohci *ohci, struct fw_packet *packet, u32 csr) | |||
869 | } | 808 | } |
870 | 809 | ||
871 | static void | 810 | static void |
872 | handle_local_request(struct at_context *ctx, struct fw_packet *packet) | 811 | handle_local_request(struct context *ctx, struct fw_packet *packet) |
873 | { | 812 | { |
874 | u64 offset; | 813 | u64 offset; |
875 | u32 csr; | 814 | u32 csr; |
@@ -903,10 +842,10 @@ handle_local_request(struct at_context *ctx, struct fw_packet *packet) | |||
903 | } | 842 | } |
904 | 843 | ||
905 | static void | 844 | static void |
906 | at_context_transmit(struct at_context *ctx, struct fw_packet *packet) | 845 | at_context_transmit(struct context *ctx, struct fw_packet *packet) |
907 | { | 846 | { |
908 | LIST_HEAD(list); | ||
909 | unsigned long flags; | 847 | unsigned long flags; |
848 | int retval; | ||
910 | 849 | ||
911 | spin_lock_irqsave(&ctx->ohci->lock, flags); | 850 | spin_lock_irqsave(&ctx->ohci->lock, flags); |
912 | 851 | ||
@@ -917,13 +856,12 @@ at_context_transmit(struct at_context *ctx, struct fw_packet *packet) | |||
917 | return; | 856 | return; |
918 | } | 857 | } |
919 | 858 | ||
920 | list_add_tail(&packet->link, &ctx->list); | 859 | retval = at_context_queue_packet(ctx, packet); |
921 | if (ctx->list.next == &packet->link) | ||
922 | at_context_setup_packet(ctx, &list); | ||
923 | |||
924 | spin_unlock_irqrestore(&ctx->ohci->lock, flags); | 860 | spin_unlock_irqrestore(&ctx->ohci->lock, flags); |
925 | 861 | ||
926 | do_packet_callbacks(ctx->ohci, &list); | 862 | if (retval < 0) |
863 | packet->callback(packet, &ctx->ohci->card, packet->ack); | ||
864 | |||
927 | } | 865 | } |
928 | 866 | ||
929 | static void bus_reset_tasklet(unsigned long data) | 867 | static void bus_reset_tasklet(unsigned long data) |
@@ -977,8 +915,8 @@ static void bus_reset_tasklet(unsigned long data) | |||
977 | spin_lock_irqsave(&ohci->lock, flags); | 915 | spin_lock_irqsave(&ohci->lock, flags); |
978 | 916 | ||
979 | ohci->generation = generation; | 917 | ohci->generation = generation; |
980 | at_context_stop(&ohci->at_request_ctx); | 918 | context_stop(&ohci->at_request_ctx); |
981 | at_context_stop(&ohci->at_response_ctx); | 919 | context_stop(&ohci->at_response_ctx); |
982 | reg_write(ohci, OHCI1394_IntEventClear, OHCI1394_busReset); | 920 | reg_write(ohci, OHCI1394_IntEventClear, OHCI1394_busReset); |
983 | 921 | ||
984 | /* This next bit is unrelated to the AT context stuff but we | 922 | /* This next bit is unrelated to the AT context stuff but we |
@@ -1216,24 +1154,24 @@ static void ohci_send_response(struct fw_card *card, struct fw_packet *packet) | |||
1216 | static int ohci_cancel_packet(struct fw_card *card, struct fw_packet *packet) | 1154 | static int ohci_cancel_packet(struct fw_card *card, struct fw_packet *packet) |
1217 | { | 1155 | { |
1218 | struct fw_ohci *ohci = fw_ohci(card); | 1156 | struct fw_ohci *ohci = fw_ohci(card); |
1219 | LIST_HEAD(list); | 1157 | struct context *ctx = &ohci->at_request_ctx; |
1220 | unsigned long flags; | 1158 | struct driver_data *driver_data = packet->driver_data; |
1221 | 1159 | int retval = -ENOENT; | |
1222 | spin_lock_irqsave(&ohci->lock, flags); | ||
1223 | 1160 | ||
1224 | if (packet->ack == 0) { | 1161 | tasklet_disable(&ctx->tasklet); |
1225 | fw_notify("cancelling packet %p (header[0]=%08x)\n", | ||
1226 | packet, packet->header[0]); | ||
1227 | 1162 | ||
1228 | complete_transmission(packet, RCODE_CANCELLED, &list); | 1163 | if (packet->ack != 0) |
1229 | } | 1164 | goto out; |
1230 | 1165 | ||
1231 | spin_unlock_irqrestore(&ohci->lock, flags); | 1166 | driver_data->packet = NULL; |
1167 | packet->ack = RCODE_CANCELLED; | ||
1168 | packet->callback(packet, &ohci->card, packet->ack); | ||
1169 | retval = 0; | ||
1232 | 1170 | ||
1233 | do_packet_callbacks(ohci, &list); | 1171 | out: |
1172 | tasklet_enable(&ctx->tasklet); | ||
1234 | 1173 | ||
1235 | /* Return success if we actually cancelled something. */ | 1174 | return retval; |
1236 | return list_empty(&list) ? -ENOENT : 0; | ||
1237 | } | 1175 | } |
1238 | 1176 | ||
1239 | static int | 1177 | static int |
@@ -1314,8 +1252,6 @@ static int handle_ir_dualbuffer_packet(struct context *context, | |||
1314 | return 1; | 1252 | return 1; |
1315 | } | 1253 | } |
1316 | 1254 | ||
1317 | #define ISO_BUFFER_SIZE (64 * 1024) | ||
1318 | |||
1319 | static int handle_it_packet(struct context *context, | 1255 | static int handle_it_packet(struct context *context, |
1320 | struct descriptor *d, | 1256 | struct descriptor *d, |
1321 | struct descriptor *last) | 1257 | struct descriptor *last) |
@@ -1872,11 +1808,11 @@ pci_probe(struct pci_dev *dev, const struct pci_device_id *ent) | |||
1872 | ar_context_init(&ohci->ar_response_ctx, ohci, | 1808 | ar_context_init(&ohci->ar_response_ctx, ohci, |
1873 | OHCI1394_AsRspRcvContextControlSet); | 1809 | OHCI1394_AsRspRcvContextControlSet); |
1874 | 1810 | ||
1875 | at_context_init(&ohci->at_request_ctx, ohci, | 1811 | context_init(&ohci->at_request_ctx, ohci, AT_BUFFER_SIZE, |
1876 | OHCI1394_AsReqTrContextControlSet); | 1812 | OHCI1394_AsReqTrContextControlSet, handle_at_packet); |
1877 | 1813 | ||
1878 | at_context_init(&ohci->at_response_ctx, ohci, | 1814 | context_init(&ohci->at_response_ctx, ohci, AT_BUFFER_SIZE, |
1879 | OHCI1394_AsRspTrContextControlSet); | 1815 | OHCI1394_AsRspTrContextControlSet, handle_at_packet); |
1880 | 1816 | ||
1881 | reg_write(ohci, OHCI1394_ATRetries, | 1817 | reg_write(ohci, OHCI1394_ATRetries, |
1882 | OHCI1394_MAX_AT_REQ_RETRIES | | 1818 | OHCI1394_MAX_AT_REQ_RETRIES | |
diff --git a/drivers/firewire/fw-transaction.h b/drivers/firewire/fw-transaction.h index b0d057533fb0..e7301b83f91e 100644 --- a/drivers/firewire/fw-transaction.h +++ b/drivers/firewire/fw-transaction.h | |||
@@ -203,8 +203,6 @@ struct fw_packet { | |||
203 | size_t payload_length; | 203 | size_t payload_length; |
204 | u32 timestamp; | 204 | u32 timestamp; |
205 | 205 | ||
206 | dma_addr_t payload_bus; | ||
207 | |||
208 | /* This callback is called when the packet transmission has | 206 | /* This callback is called when the packet transmission has |
209 | * completed; for successful transmission, the status code is | 207 | * completed; for successful transmission, the status code is |
210 | * the ack received from the destination, otherwise it's a | 208 | * the ack received from the destination, otherwise it's a |
@@ -215,6 +213,7 @@ struct fw_packet { | |||
215 | fw_packet_callback_t callback; | 213 | fw_packet_callback_t callback; |
216 | int ack; | 214 | int ack; |
217 | struct list_head link; | 215 | struct list_head link; |
216 | void *driver_data; | ||
218 | }; | 217 | }; |
219 | 218 | ||
220 | struct fw_transaction { | 219 | struct fw_transaction { |