CompactFlash on PCMCIA problems
eckhardt at satorlaser.com
Mon Apr 11 03:35:38 EDT 2005
I'm trying to code the glue to connect the vanilla ATA drivers with a CF card
connected to an Au1100 (a MIPS based system-on-a-chip with an integrated
PCMCIA controller) in order to mount a root-filesystem from it. I managed to
access the CIS parts of the card but then the problems start: the area where
I'd expect to find the ATA controller's registers mirrors every byte twice,
just as if the address used was first shifted by one.
Here's a sketch of what I'm doing:
1. Setup SYS_PINFUNC so the PCMCIA interface is used
2. Setup GPIO and GPIO2, they are used for e.g. card detection and power
3. apply power to card via GPIO
4. reset card via GPIO, waiting for it to finish
5. ioremap all three PCMCIA_*_PHYS_ADDR ranges
6. parse CIS in ioremapped PCMCIA_ATTR_PHYS_ADDR
7. setup CISREG_CCSR with 0x00, in particular to reset CCSR_POWER_DOWN
8. setup CISREG_COR with 0x01, configuration #1 is the contiguous memory
configuration parsed from the CIS
At this moment, I think I should be able to talk to the ATA controller via the
first few bytes of the ioremapped PCMCIA_IO_PHYS_ADDR, but that area has this
weird mirrored byte behaviour which I don't understand.
Another thing I don't fully understand yet is the meaning of the three memory
areas. These are called 'IO', 'attrib' and 'mem'. The 'attrib' area contains
the CIS and presents no problem. The 'IO' area is where I'd expect to find
the ATA controller's registers. Now, what I don't understand is the meaning
of the 'mem' area (PCMCIA_MEM_PHYS_ADDR). The documents I found on the web
always referred to a 'common memory' area, but funnily they also only
distinguished between two areas!?
Yet another thing I'm missing is the meaning of CISREG_IOBASE_* and
CISREG_IOSIZE. When exactly and how do I have to setup those?
I'm pretty lost, I have tried everything I could think of without any success.
I also sent this to the Linux/MIPS mailinglist, but without any further
Please CC me on reply - I read the the list on the web, but I can't reply to
that without breaking threads.
 is a particular size required? Also, I used ioremap_nocache(), does that
matter or should I use plain ioremap()?
 yes, it might be more interesting to use one of the non-contiguous modes,
but that still doesn't solve my problems.
 Note: some parts of this have nothing to do with PCMCIA in general, but
rather with the setup of my board. GPIO mean 'general purpose IO', pins on
the chip used either as IO pins or to drive a special interface like PCMCIA.
More information about the linux-pcmcia