Hi Michael, On Sun, Mar 4, 2018 at 1:21 AM, Michael Schmitz <schmitz...@gmail.com> wrote: > that's odd - the DMA setup code in the old ESP drivers does program the > full 32 bit addresses on DMA set-up. No masking off to 24 bit. > > All boards except for the Fastlane are ZorroII. Writes to the DMA > registers are done byte-wise there (only on the Fastlane, the target > address is written as one longword), so this suggests there is a limit > to the data bus width, but doesn't speak to the address bus width. > > I'm sure Amigas weren't limited to 16 MB of RAM (pretty certain kullervo > had 32 or 64 MB). No evidence of Amiga SCSI ever using a DMA bounce > buffer (as we've had to use on Atari). How would the old SCSI drivers > have worked, if DMA can't address the full 32 bit space?
The Fastlane is indeed a Zorro III board, that fits into a Zorro III expansion slot. However, the other boards supported by your new zorro_esp driver are not Zorro II expansion boards. They fit in the CPU expansion slot, and thus have full access to all memory. They just use the Zorro AutoConfig protocol for discovery. I don't know how their expansion ROMs look like. They may identify as either a Zorro II or Zorro III board, depending on how much address space they need for their registers. Given SCSI doesn't need much, most probably look like a Zorro II board. Google found the following lszorro output: 00: Phase 5 Blizzard 2060 [Accelerator] Type: Zorro II Address: 00ea0000 (00020000 bytes) Serial number: 00000000 Slot address: 00ea Slot size: 0002 elgar:~# lszorro -vv 00: Phase 5 Blizzard 1220/CyberStorm [Accelerator and SCSI Host Adapter] Type: Zorro II Address: 00e90000 (00010000 bytes) Serial number: 00000000 Slot address: 00e9 Slot size: 0001 which confirms that they identify as Zorro II boards. So the Zorro driver core can set their DMA masks to 24-bit, but the driver can safely override it to 32-bit. > Am 03.03.2018 um 22:31 schrieb Geert Uytterhoeven: >> On Sat, Mar 3, 2018 at 12:08 AM, Christoph Hellwig <h...@lst.de> wrote: >>> Assuming all zorro devices can deal fine with a 32-bit dma mask: >> >> No they don't. Zorro II has a 24-bit bus, Zorro III has a 32-bit bus. >> So it should be something like: >> >> switch (z->rom.er_Type & ERT_TYPEMASK) { >> case ERT_ZORROIII: >> z->dev.coherent_dma_mask = DMA_BIT_MASK(32); >> break; >> case ERT_ZORROII: >> default: >> z->dev.coherent_dma_mask = DMA_BIT_MASK(24); >> break; >> } >> >> Other types are not defined, but I have no idea how expansion boards for >> the original Amiga 1000 ("Zorro I") are represented. As that one had a 24-bit >> bus, using 24 for the default should be fine. Gr{oetje,eeting}s, Geert -- Geert Uytterhoeven -- There's lots of Linux beyond ia32 -- ge...@linux-m68k.org In personal conversations with technical people, I call myself a hacker. But when I'm talking to journalists I just say "programmer" or something like that. -- Linus Torvalds -- To unsubscribe from this list: send the line "unsubscribe linux-m68k" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html