diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2009-12-11 18:22:27 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2009-12-11 18:22:27 -0500 |
commit | 5f1141eb352ea79d849920039503e40dd623fffa (patch) | |
tree | 1378b88a847c483933334d5c3695138bfa6c5a4d | |
parent | 880188b2433c3af51fa006207d9b13c70d2e5938 (diff) | |
parent | 8c0c0cc2d9f4c523fde04bdfe41e4380dec8ee54 (diff) |
Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394-2.6
* 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/ieee1394/linux1394-2.6:
firewire: ohci: handle receive packets with a data length of zero
-rw-r--r-- | drivers/firewire/ohci.c | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/drivers/firewire/ohci.c b/drivers/firewire/ohci.c index ae4556f0c0c1..96768e160866 100644 --- a/drivers/firewire/ohci.c +++ b/drivers/firewire/ohci.c | |||
@@ -2218,6 +2218,13 @@ static int ohci_queue_iso_receive_dualbuffer(struct fw_iso_context *base, | |||
2218 | page = payload >> PAGE_SHIFT; | 2218 | page = payload >> PAGE_SHIFT; |
2219 | offset = payload & ~PAGE_MASK; | 2219 | offset = payload & ~PAGE_MASK; |
2220 | rest = p->payload_length; | 2220 | rest = p->payload_length; |
2221 | /* | ||
2222 | * The controllers I've tested have not worked correctly when | ||
2223 | * second_req_count is zero. Rather than do something we know won't | ||
2224 | * work, return an error | ||
2225 | */ | ||
2226 | if (rest == 0) | ||
2227 | return -EINVAL; | ||
2221 | 2228 | ||
2222 | /* FIXME: make packet-per-buffer/dual-buffer a context option */ | 2229 | /* FIXME: make packet-per-buffer/dual-buffer a context option */ |
2223 | while (rest > 0) { | 2230 | while (rest > 0) { |
@@ -2271,7 +2278,7 @@ static int ohci_queue_iso_receive_packet_per_buffer(struct fw_iso_context *base, | |||
2271 | unsigned long payload) | 2278 | unsigned long payload) |
2272 | { | 2279 | { |
2273 | struct iso_context *ctx = container_of(base, struct iso_context, base); | 2280 | struct iso_context *ctx = container_of(base, struct iso_context, base); |
2274 | struct descriptor *d = NULL, *pd = NULL; | 2281 | struct descriptor *d, *pd; |
2275 | struct fw_iso_packet *p = packet; | 2282 | struct fw_iso_packet *p = packet; |
2276 | dma_addr_t d_bus, page_bus; | 2283 | dma_addr_t d_bus, page_bus; |
2277 | u32 z, header_z, rest; | 2284 | u32 z, header_z, rest; |
@@ -2309,8 +2316,9 @@ static int ohci_queue_iso_receive_packet_per_buffer(struct fw_iso_context *base, | |||
2309 | d->data_address = cpu_to_le32(d_bus + (z * sizeof(*d))); | 2316 | d->data_address = cpu_to_le32(d_bus + (z * sizeof(*d))); |
2310 | 2317 | ||
2311 | rest = payload_per_buffer; | 2318 | rest = payload_per_buffer; |
2319 | pd = d; | ||
2312 | for (j = 1; j < z; j++) { | 2320 | for (j = 1; j < z; j++) { |
2313 | pd = d + j; | 2321 | pd++; |
2314 | pd->control = cpu_to_le16(DESCRIPTOR_STATUS | | 2322 | pd->control = cpu_to_le16(DESCRIPTOR_STATUS | |
2315 | DESCRIPTOR_INPUT_MORE); | 2323 | DESCRIPTOR_INPUT_MORE); |
2316 | 2324 | ||