Commit 458c77f3 authored by Finn Thain's avatar Finn Thain Committed by Greg Kroah-Hartman

macintosh/via-cuda: Don't rely on Cuda to end a transfer

Certain Cuda transfers have to be ended by the driver. According
to Apple's open source Cuda driver, as found in mkLinux and XNU, this
applies to any "open ended request such as PRAM read". This fixes an
infinite polling loop in cuda_pram_read_byte().
Tested-by: default avatarStan Johnson <userm57@yahoo.com>
Signed-off-by: default avatarFinn Thain <fthain@telegraphics.com.au>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent aefcb746
...@@ -569,6 +569,7 @@ cuda_interrupt(int irq, void *arg) ...@@ -569,6 +569,7 @@ cuda_interrupt(int irq, void *arg)
unsigned char ibuf[16]; unsigned char ibuf[16];
int ibuf_len = 0; int ibuf_len = 0;
int complete = 0; int complete = 0;
bool full;
spin_lock_irqsave(&cuda_lock, flags); spin_lock_irqsave(&cuda_lock, flags);
...@@ -656,12 +657,13 @@ cuda_interrupt(int irq, void *arg) ...@@ -656,12 +657,13 @@ cuda_interrupt(int irq, void *arg)
break; break;
case reading: case reading:
if (reading_reply ? ARRAY_FULL(current_req->reply, reply_ptr) full = reading_reply ? ARRAY_FULL(current_req->reply, reply_ptr)
: ARRAY_FULL(cuda_rbuf, reply_ptr)) : ARRAY_FULL(cuda_rbuf, reply_ptr);
if (full)
(void)in_8(&via[SR]); (void)in_8(&via[SR]);
else else
*reply_ptr++ = in_8(&via[SR]); *reply_ptr++ = in_8(&via[SR]);
if (!TREQ_asserted(status)) { if (!TREQ_asserted(status) || full) {
if (mcu_is_egret) if (mcu_is_egret)
assert_TACK(); assert_TACK();
/* that's all folks */ /* that's all folks */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment