On Sun, 15 Jan 2017, Michael Schmitz wrote:
Am 15.01.2017 um 12:47 schrieb Finn Thain:
For the sake of discussion, I'll assume that the FDC driver will not
be using DMA. (Perhaps FDC and SCSI can share the ST-DMA chip, using
the present locking mechanism, but it would not simplify things much:
when IDE no longer participates in that locking mechanism then both
FDC and SCSI drivers have to solve the same issues.)
Correct - IIRC the FDC registers are also accessible 'through' the
ST-DMA registers only so the same problem WRT DMA status arises.
I had not considered that limitation.
What compiler are you using, BTW? Are you still using the gcc-4.6.3
m68k cross-compiler from kernel.org? I had to abandon it in order to
get my SCSI driver patches to work.
4.6.3 is the version I still use. You had trouble with that one? I
recall some discussion on gcc versions on the m68k list a while back,
just never seemed to see any problems...
... none that could be easily blamed on the compiler, anyway.
The gcc 4.6.3 issue affecting my builds was discussed back in
November. There are alternative compilers available:
http://marc.info/?l=linux-m68k&m=147859596303294&w=2
http://marc.info/?l=linux-m68k&m=147859567903210&w=2
I need to think about that some more - if no DMA is in progress we
can safely peek at the SCSI registers. So the logic could be changed
to test for DMA operation first, and just try and service the
interrupt if DMA wasn't active.
OK, so based on the above, we handle the possible IDE interrupt
(without checking DMA registers), handle the possible FDC interrupt
(again without checking DMA registers) and finally handle the possible
SCSI interrupt.
No, we can't check either FDC or SCSI interrupts (or indeed any chip
registers) without touching the ST-DMA. The moment we select a FDC or
SCSI register for read, DMA is terminated no questions asked.
Perhaps we can convert DMA operations to PDMA (by polling with local irqs
disabled) and avoid the whole problem of interrupt handlers executing
during DMA transfers. The docs suggest that it is doable.
"Poll or service the Disk Driver Controller interrupt on the MK68901 MFP
General Purpose I/O Register to detect the completion of a WD1772 FDC
command. Do not poll the FDC Busy or DMA Sector Count Zero status bits."
-- ST HW Spec, p. 36.
http://dev-docs.atariforge.org/files/ST_HW_Spec_1-7-1986.pdf
On page 18 there is an algorithm for floppy writes which is interesting.
I suspect that we will need to keep the FDC idle during SCSI transfers
(and vice versa) much as the present stdma.c lock does.
"The interrupt outputs of the internal floppy disk controller and the
external ACSI DMA port are logically OR'ed. The pin of the MFP GPIP will
read as a '0' if either the FDC or a selected ACSI device controller is
asserting its interrupt request."
-- ACSI/DMA Integration Guide, p.16.
http://dev-docs.atariforge.org/files/ACSI_DMA_Guide_6-28-1991.pdf
Polling the logically OR'ed interrupt sources to detect end-of-DMA will
not be reliable unless we disable those sources that aren't relevant.
Otherwise we access the DMA registers too early (which IIUC would kill the
transfer). I'm afraid we shall have to expect that a few transfers will be
interrupted by other devices in this way, and carefully check for this.
For example, the 5380 SCSI bus reset interrupt is not maskable, which
could affect FDC transfers. If this terminated the polling for DMA
completion, the FDC driver then has to access the FDC registers and
confirm that the transfer was not terminated early.
--
--
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