Hi Finn,
Incidentially - did you work on the Mac 5380 SCSI code recently? Does it
work with full error handling capability in its current state?
I got as far as confirming the reports of working mac_scsi on the IIfx. It
fails on every other model. I didn't really investigate error handling.
OK so it works in principle but error handling may still be in need of
updating.
The explanation was that PDMA isn't relevant to the IIfx so the driver
runs in PIO mode (should be DMA but that has not yet been implemented
successfully).
Gives me something to fall back to, at least...
I begin to feel the only way to make the Falcon SCSI code work again is
a clean restart ...
That was also my feeling when we discussed this some years ago*.
I do well remember we talked about that - since mac_scsi uses mainline
NCR5380.c I think you are in better shape already. No other driver uses
anything close to PDMA but I cannot see what should be wrong there.
I'm told that mac_scsi PDMA worked for either mac68k or mainline 2.2
kernels and so I tend to think that a rewrite would likely suffer from the
same PDMA bug. I really need to investigate that bug.
There are still good reasons for a rewrite but I don't have the necessary
understanding of the SCSI subsystem nor the time to tackle those issues.
The Falcon driver worked in 2.2 and 2.4 and even as recent as 2.6.18 but
broke in later 2.6 releases. Error handling changes, running the
coroutine as delayed task instead of immediate soft interrupt and
replacement of the big kernel lock by subsystem locking have all changed
since. Some of that has been taken care of in NCR5380.c from what I've
seen. atari_NCR5380.c still uses global locking, manually delays the
task queue and fiddles with the queue pointers explicitly. I'll have to
go over the whole file manually and make it as close to NCR5380.c as I
can while still keeping the Falcon specific bits in.
But if someone else were to rewrite the core 5380 driver as was done with
esp_scsi.c then I would be willing to tackle the mac portion (the
equivalent of mac_esp.c)...
I lack an understanding of how the current SCSI error handling code is
supposed to work - that part still needs to be done for NCR5380.c but
I'm at a loss to find a good example of a current SCSI driver to look at.
All I manage so far is get the kernel to lock up solid once a request
times out, but I've pretty much started from scratch so there will be
bits missing to be patched.
Cheers,
Michael
--
To unsubscribe from this list: send the line "unsubscribe linux-m68k" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html