Re: mac scsi, ncr5380

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Finn Thain wrote:
Hi All,

Of late I've spent some time wrestling with mac_scsi. I've made some 
progress, but I'm uncertain as to how I should procede -- whatever I do, 
there will be implications for some other NCR5380 drivers.

mac_scsi actually works (once I fixed the enable_irq-before-request_irq 
bug -- already fixed in various other NCR5380 wrapper drivers ... sigh) 
but it only works in PIO mode. The PDMA read routine causes a bus error 
(The Guide to Mac Family Hardware says "if a read or write operation over 
the SCSI bus is not completed within certain time (different for different 
machines), the general logic IC asserts a bus error (/BERR) to the CPU.")
The driver tries to fall back to PIO mode when that happens.

The fall back succeeds only on the powerbook 190 and only if the code was 
compiled with gcc-3. It just hangs on the PB 150 and Mac II, though PIO 
works on those machines too when PDMA is disabled. So I think there's a 
race there somewhere. And PIO doesn't work anywhere once debugging printks 
are enabled.

All of which gives me little confidence in NCR5380.c.

(I tested those 3 machines because they have the 3 different kinds of 
VIA2. Logs can be found here
<http://www.telegraphics.com.au/~fthain/mac_scsi_logs/>
should anyone want to see them.)

There is so much duplication of code for the NCR5380 drivers -- sun3, 
atari, g_NCR5380, 2.4 & 2.2 branches in the mac68k CVS -- that I don't 
know where to start looking for fixes.

Thinking that the bug would be trivial, I started out writing cleanup 
patches for the existing mac_scsi.c/NCR5380.c combination. But the more I 
think about it, the less I want to go in that direction.

Now I'm thinking that mac_scsi should adopt the atari core, since that 
appears to be the better maintained contender. Michael, does that sound 
sensible? Does it have working PDMA?

Another thing, should we look at merging sun3_NCR5380.c and 
atari_NCR5380.c? The diff is huge, but that is because of the code style 
and formatting cleanups in atari_NCR5380.c. The functional differencess 
are few and far between.

If we can get to a working, common sun3/atari/mac core, I could then look 
at minimising C preprocessor abuse in favour of a cleaner link-time/ops 
struct abstraction layer -- with some assistance from Micheal and Sam: I'm 
assuming that there is a cut somewhere that would make for a broadly 
useful interface. Does this make sense?

Merging core 5380 drivers could _maybe_ go further if those responsible 
for them were interested, but I would not want to bite off more than 
atari/mac/sun3 at first. As to the rest, here's a list of all the relevant 
#includes (this really needs to be converted to a graphical representation 
somehow..) I don't know who maintains all of these 5380 drivers.

files that include NCR5380.c --
./drivers/scsi/arm/cumana_1.c
./drivers/scsi/arm/oak.c
./drivers/scsi/dmx3191d.c
./drivers/scsi/dtc.c
./drivers/scsi/g_NCR5380.c
./drivers/scsi/mac_scsi.c
./drivers/scsi/pas16.c
./drivers/scsi/t128.c

files that include NCR5380.h --
./drivers/scsi/arm/cumana_1.c
./drivers/scsi/arm/oak.c
./drivers/scsi/atari_scsi.c
./drivers/scsi/dmx3191d.c
./drivers/scsi/dtc.c
./drivers/scsi/g_NCR5380.c
./drivers/scsi/mac_scsi.c
./drivers/scsi/pas16.c
./drivers/scsi/sun3_scsi.c 
./drivers/scsi/sun3_scsi_vme.c
./drivers/scsi/t128.c

files that include atari_NCR5380.c --
./drivers/scsi/atari_scsi.c

files that include atari_scsi.h --
./drivers/scsi/atari_scsi.c

files that include dtc.h --
./drivers/scsi/dtc.c

files that include g_NCR5380.c --
./drivers/scsi/g_NCR5380_mmio.c

files that include g_NCR5380.h --
./drivers/scsi/g_NCR5380.c

files that include mac_scsi.h --
./drivers/scsi/mac_scsi.c

files that include pas16.h --
./drivers/scsi/pas16.c

files that include sun3_NCR5380.c --
./drivers/scsi/sun3_scsi.c
./drivers/scsi/sun3_scsi_vme.c

files that include sun3_scsi.h --
./drivers/scsi/sun3_scsi.c
./drivers/scsi/sun3_scsi_vme.c

files that include t128.h --
./drivers/scsi/t128.c

Note that this include graph is post-patching: I moved the #include 
"NCR5380.h" out of sun3_scsi.h and into sun3_scsi.c and sun3_scsi_vme.c so 
that the graph was more shallow and more symmetrical (that patch is at 
<http://www.telegraphics.com.au/~fthain/patches_wip/>
I'll send some of these patches for the 2.6.28 merge window.)

Regards,

Finn
--
Dear Finn

From a SCSI generic point of view. The current xxx_NCR5380 remind me allot
of the old ESP drivers stack. At-least at the surface level of the patches
I sent for both these drivers. I was lucky, at the end, to only send the
xxx_NCR5380 patches, because, as strongly recommended by Christoph Hellwig
(CCed), the old ESP stack was brilliantly replaced by a new one. That is 1/10
the size of the old one, and currently supports most of the interesting devices
out there. My unsent patches was a catalyst, for the now broken old-driver-stack,
to be removed quickly. And it seems every one is happy.

My point being, If you are looking to do a major cleanup work, on all these
1/2 forks. Maybe give a hard thought on just trashing the all thing and crafting
a completely new stack, 1/10 the size and much simpler, modern, and maintainable.

From what I understand, (And again I do not), the ESP sounds a lot like the
NCR5380. I would craft a very similar copy of the new ESP stack, with it's
central library and function-vector registration, The scsi-generic part is
all there, in full glory. Then one concentrated effort should go into the
basic/general chip programing, which lots of it could be ripped from current
code, and the different platform implementation becomes one liners, if the new
ESP stack is any indication.

From my passed experience, there becomes a source code state when a rewrite is
less effort then any cleanup or enhancements. From the small changes I had to do
to the xxx_NCR5380 family of drivers, my guts feeling scream "rewrite", so here I
voice them. In the mid/long-term you will work much less. And be much more
satisfied from the results.

Good lock
Boaz
--
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

[Index of Archives]     [Video for Linux]     [Yosemite News]     [Linux S/390]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux