Difference between revisions of "Minimig Harddisc"
Jump to navigation
Jump to search
(→Software aspect: +floppy characteristics) |
(→Software aspect: sw solution) |
||
Line 46: | Line 46: | ||
[http://www.iki.fi/mkl/ide/ P-ATA interface for the MC68000 cpu socket]<br> | [http://www.iki.fi/mkl/ide/ P-ATA interface for the MC68000 cpu socket]<br> | ||
+ | Software hardfile support suggestion: | ||
+ | :Define "struct adfTYPE dh0;" | ||
+ | :Update User() to handle selection 'dh0' aswell. Current implementation decides you ALWAYS want 'df0' | ||
+ | :Make HandleFpgaCmd() to take more parameters and make them variable size per request. | ||
+ | :Modify ReadTrack() such that it doesn't presume 11 sectors per track. | ||
+ | :Make a SectorToFpga() function that don't stuff sector header formatting into the transfered sector. | ||
+ | :The rest is to make the FPGA to present the SPI transfered sectors to appear magicly from the Gayle ide controller via SPI. | ||
[http://portal.acm.org/ft_gateway.cfm?id=358425&type=pdf&coll=ACM&dl=ACM&CFID=15151515&CFTOKEN=6184618 | [http://portal.acm.org/ft_gateway.cfm?id=358425&type=pdf&coll=ACM&dl=ACM&CFID=15151515&CFTOKEN=6184618 |
Revision as of 08:05, 24 August 2007
Contents
SCSI
P-ATA
- Gayle style IDE is very simple, i've been looking into it. though bluea would probably be the best person to ask about it, he has it working on natami i believe. Most of the signals come straight from the CPU, which means very few FPGA pins will be needed.
- from what i can see, the only lines that dont come straight from the CPU are.
- IDE_CS1
- IDE_CS2 (usually only used by IDE doublers, can probably be left out)
- IDE_IRQ (not needed when interfacing drives to MCU's, not sure whether scsi.device needs it)
- IOWR
- IORD
- WAIT
- what do you know... exactly 6 extra lines
- The data lines are byte swapped
- And IDE_A0 - IDE_A2 are mapped to A2 - A4
- finally, IDE_LED, optionally goes to an LED.
- an IDE only mode compact flash port, could easily be added to the bottom side of the board. :Giving us access to 1.8" hard drives.
freqmax: Internal P-ATA connector pinout
- out: CS1, CS2,IOWR, IORD
- in: IRQ,
- hmm? WAIT
S-ATA
Software aspect
- UAE's Hardfile format. In addition to UAE's normal hardfile format (that works as a simplepartition) UAE also has the option of making an entire HD image, including RDB.
- Starting from kickstart 37.300 (I think it's Rom 2.05, earlier releases had a bug and didn't detect it) the controller is supported and code is built-in in the rom.
- For kickstart 1.3 I guess that a driver would be required, simulating an autoconfig HD controller or maybe it would be enough to extract the rom from KS and make a custom 1.3 rom... but I guess I could live without HD emulation on OS1.3 since OS 2.05/3.1 could be loaded in the same board with just a reset.
- I guess Gayle emulation would be perfect. Maybe Thomas Hirsch aka "bluea" could give some hints. He has implemented Gayle emulation for his NatAmi project. I don't know if he'll release some code. Anyway here you have some interesting info about Gayle:
- http://www.amiga.org/modules/newbb/viewtopic.php?topic_id=31439&forum=8#forumpost378020
- He got it working. According to him "I implemented the A4000 and A1200-Gayle registers as a Chip-Select logic for an 2.5" harddisk. So I can boot from that drive."
- -edit- BTW, if a 16 or 32MB memory chip was used there would be room to have 2MB of chip, 8MB of fast and also some "slow-ranger-pseudofast" ram. In addition to the FPGA code and AmigaOS Rom (the fpga code could be changed to accept 1MB roms like CD32/A1200) the rest of ram could be used as buffers for the hardfile. That way disk access shouldn't be too slow.
alexh 060603:
http://groups.google.co.uk/group/fa.linux.680x0/browse_thread/thread/33e6f8f26d5bc63c/16cd017fdd8c71e2?lnk=st&q=amiga+gayle+address+register&rnum=1&hl=en#16cd017fdd8c71e2
mrmkl 070803:
http://aminet.net/search?query=hddmem
P-ATA interface for the MC68000 cpu socket
Software hardfile support suggestion:
- Define "struct adfTYPE dh0;"
- Update User() to handle selection 'dh0' aswell. Current implementation decides you ALWAYS want 'df0'
- Make HandleFpgaCmd() to take more parameters and make them variable size per request.
- Modify ReadTrack() such that it doesn't presume 11 sectors per track.
- Make a SectorToFpga() function that don't stuff sector header formatting into the transfered sector.
- The rest is to make the FPGA to present the SPI transfered sectors to appear magicly from the Gayle ide controller via SPI.
Timating file access time of floppy disks, acm.org]
Floppy characteristics powerspec.com Track-to-Track is ~3 ms