[U-Boot] gen-atmel-mci driver bug?
Jan Pohanka
xhpohanka at gmail.com
Wed Jun 1 15:00:37 CEST 2011
Hello,
I'm playing with mmc/sd card on a custom board with at91sam9g20 processor.
U-boot v2011.3 now runs well as I added support for AT45DB041 dataflash,
which is used on my board. It's size is only 512kB so I need sd card for
Linux image and rootfs. Unfortunately I still can't get mmc/sd suport
working. I have a micro sd (not hc) card connected to a MCI interface port
A.
It seems that it is correctly detected and initialized,
U-Boot> mmcinfo
mci: bus_hz is 132096000, setting clock 150000 Hz, block size 512
mci: setting clock 258000 Hz, block size 512
mci: bus_hz is 132096000, setting clock 0 Hz, block size 512
mci: setting clock 258000 Hz, block size 512
mci: bus_hz is 132096000, setting clock 258000 Hz, block size 512
mci: setting clock 258000 Hz, block size 512
Device: mci
Manufacturer ID: 3
OEM: 5344
Name: SU02G
Tran Speed: 25000000
Rd Block Len: 512
SD version 2.0
High Capacity: No
Capacity: 1977614336
Bus Width: 4-bit
U-Boot> fatinfo mmc 0
Interface: MMC
Device 0: Vendor: Man 035344 Snr 413f90a9 Rev: 8.0 Prod: SU02G
Type: Removable Hard Disk
Capacity: 1886.0 MB = 1.8 GB (3862528 x 512)
Partition 1: Filesystem: FAT16 " "
but there is some problem with block reading. When I try to read 1 block
using eg. mmc read 0 0xaddr 0 1 it works and correct data are returned,
but when reading more blocks
U-Boot> mmc read 0 0xaddr 0 3,
U-Boot> mmc read 0 0x20000000 5 3
MMC read: dev # 0, block # 5, count 3 ... mci: bus_hz is 132096000,
setting clock 150002
mci: setting clock 258000 Hz, block size 512
mci: bus_hz is 132096000, setting clock 25000000 Hz, block size 512
mci: setting clock 22016000 Hz, block size 512
mci: bus_hz is 132096000, setting clock 258000 Hz, block size 512
mci: setting clock 258000 Hz, block size 512
gen_atmel_mci: CMDR 000d1052 (18) ARGR 00000a00 (SR: 0000c0d7) XFER DTIP
never unset, ignoring.
the read function returns still the same data from the starting block (as
I see from debug info) and it hangs then on polling while (!((status =
readl(&mci->sr)) & MMCI_BIT(CMDRDY))); in gen-atmel-mci.c.
I have tried to search the source of problem, but I was not successful
yet. I'm not very familiar with u-boot code so I can be missing something
obvious.
Does please someone has any solution?
Here is my config regarding mmc
/* SD/MMC card */
#define CONFIG_MMC 1
#define CONFIG_GENERIC_MMC 1
#define CONFIG_GENERIC_ATMEL_MCI 1
#define CONFIG_ATMEL_MCI_PORTA 1
#define CONFIG_CMD_MMC 1
The same situation is on at91sam9260ek board, except that the card is on
MCI port B. Reinhard Meyer stated that he has mmc working on this board...
best regards
Jan
--
Tato zpráva byla vytvořena převratným poštovním klientem Opery:
http://www.opera.com/mail/
More information about the U-Boot
mailing list