Hello, I am using ARM (CortexA9)development board which has SPI controller running at 5MHz. I want to interface MMC card on SPI bus. I have made changes to my board.c file to include the mmc_spi driver and mentioned the Chip select, mode (MODE 0) and frequency of operation (started with 40kHz). The initial card detection goes well. However, there are CRC errors when the block layer tries to read the partition table. I have attached log for reference. The card gets detected on Linux/Windows PC. The card is formatted with DOS partition (single partition). Linus kernel Version 4.4.16 Please help me regarding this issue. Regards, Amit.
[ 137.404003] mmc0: clock 0Hz busmode 2 powermode 1 cs 1 Vdd 23 width 0 timing 0 [ 137.404027] mmc_spi spi1.1: mmc_spi: power up (23) [ 137.404040] mmc_spi spi1.1: Initial signal voltage of 3.3v [ 137.415403] mmc0: clock 400000Hz busmode 2 powermode 2 cs 1 Vdd 23 width 0 timing 0 [ 137.415424] mmc_spi spi1.1: mmc_spi: power on (23) [ 137.415659] mmc_spi spi1.1: setup: unsupported mode bits 4 [ 137.422135] mmc_spi spi1.1: can't change chip-select polarity [ 137.428436] mmc_spi spi1.1: mmc_spi: clock to 400000 Hz, 0 [ 137.445411] mmc_spi spi1.1: SD/MMC host mmc0, no DMA, no WP, no poweroff [ 137.445434] mmc0: mmc_rescan_try_freq: trying to init card at 400000 Hz [ 137.445446] mmc0: starting CMD52 arg 00000c00 flags 00000195 [ 137.445463] mmc_spi spi1.1: mmc_spi: CMD52, resp R2/R5 [ 137.445585] mmc_spi spi1.1: ... CMD52 response SPI_R2/R5: resp ff04 00000000 [ 137.445602] mmc0: req done (CMD52): -38: 0000ff04 00000000 00000000 00000000 [ 137.445616] mmc0: starting CMD52 arg 80000c08 flags 00000195 [ 137.445630] mmc_spi spi1.1: mmc_spi: CMD52, resp R2/R5 [ 137.445741] mmc_spi spi1.1: ... CMD52 response SPI_R2/R5: resp ff04 00000000 [ 137.445756] mmc0: req done (CMD52): -38: 0000ff04 00000000 00000000 00000000 [ 137.445770] mmc0: starting CMD0 arg 00000000 flags 000000c0 [ 137.445782] mmc_spi spi1.1: mmc_spi: CMD0, resp R1 [ 137.445889] mmc_spi spi1.1: ... CMD0 response SPI_R1: resp 0001 00000000 [ 137.445904] mmc0: req done (CMD0): 0: 00000001 00000000 00000000 00000000 [ 137.446914] mmc0: starting CMD8 arg 000001aa flags 000002f5 [ 137.446927] mmc_spi spi1.1: mmc_spi: CMD8, resp R3/R4/R7 [ 137.447049] mmc_spi spi1.1: ... CMD8 response SPI_R3/R4/R: resp 0001 000001aa [ 137.447064] mmc0: req done (CMD8): 0: 00000001 000001aa 00000000 00000000 [ 137.447078] mmc0: starting CMD5 arg 00000000 flags 000002e1 [ 137.447090] mmc_spi spi1.1: mmc_spi: CMD5, resp R3/R4/R7 [ 137.447212] mmc_spi spi1.1: ... CMD5 response SPI_R3/R4/R: resp 0005 ffffffff [ 137.447227] mmc0: req done (CMD5): -38: 00000005 ffffffff 00000000 00000000 [ 137.447241] mmc0: starting CMD55 arg 00000000 flags 000000f5 [ 137.447253] mmc_spi spi1.1: mmc_spi: CMD55, resp R1 [ 137.447360] mmc_spi spi1.1: ... CMD55 response SPI_R1: resp 0001 00000000 [ 137.447375] mmc0: req done (CMD55): 0: 00000001 00000000 00000000 00000000 [ 137.447388] mmc0: starting CMD41 arg 00000000 flags 000000e1 [ 137.447400] mmc_spi spi1.1: mmc_spi: CMD41, resp R1 [ 137.447507] mmc_spi spi1.1: ... CMD41 response SPI_R1: resp 0001 00000000 [ 137.447521] mmc0: req done (CMD41): 0: 00000001 00000000 00000000 00000000 [ 137.447536] mmc0: starting CMD0 arg 00000000 flags 000000c0 [ 137.447548] mmc_spi spi1.1: mmc_spi: CMD0, resp R1 [ 137.447656] mmc_spi spi1.1: ... CMD0 response SPI_R1: resp 0001 00000000 [ 137.447670] mmc0: req done (CMD0): 0: 00000001 00000000 00000000 00000000 [ 137.448680] mmc0: starting CMD58 arg 00000000 flags 00000280 [ 137.448692] mmc_spi spi1.1: mmc_spi: CMD58, resp R3/R4/R7 [ 137.448814] mmc_spi spi1.1: ... CMD58 response SPI_R3/R4/: resp 0001 00ff8000 [ 137.448829] mmc0: req done (CMD58): 0: 00000001 00ff8000 00000000 00000000 [ 137.448842] mmc0: starting CMD0 arg 00000000 flags 000000c0 [ 137.448854] mmc_spi spi1.1: mmc_spi: CMD0, resp R1 [ 137.448961] mmc_spi spi1.1: ... CMD0 response SPI_R1: resp 0001 00000000 [ 137.448976] mmc0: req done (CMD0): 0: 00000001 00000000 00000000 00000000 [ 137.449986] mmc0: starting CMD8 arg 000001aa flags 000002f5 [ 137.449998] mmc_spi spi1.1: mmc_spi: CMD8, resp R3/R4/R7 [ 137.450120] mmc_spi spi1.1: ... CMD8 response SPI_R3/R4/R: resp 0001 000001aa [ 137.450134] mmc0: req done (CMD8): 0: 00000001 000001aa 00000000 00000000 [ 137.450147] mmc0: starting CMD55 arg 00000000 flags 000000f5 [ 137.450160] mmc_spi spi1.1: mmc_spi: CMD55, resp R1 [ 137.450267] mmc_spi spi1.1: ... CMD55 response SPI_R1: resp 0001 00000000 [ 137.450282] mmc0: req done (CMD55): 0: 00000001 00000000 00000000 00000000 [ 137.450294] mmc0: starting CMD41 arg 40000000 flags 000000e1 [ 137.450307] mmc_spi spi1.1: mmc_spi: CMD41, resp R1 [ 137.450414] mmc_spi spi1.1: ... CMD41 response SPI_R1: resp 0000 00000000 [ 137.450428] mmc0: req done (CMD41): 0: 00000000 00000000 00000000 00000000 [ 137.450444] mmc0: starting CMD10 arg 00000000 flags 000000b5 [ 137.450454] mmc0: blksz 16 blocks 1 flags 00000200 tsac 0 ms nsac 64 [ 137.450467] mmc_spi spi1.1: mmc_spi: CMD10, resp R1 [ 137.450544] mmc_spi spi1.1: ... CMD10 response SPI_R1: resp 0000 00000000 [ 137.450554] mmc_spi spi1.1: mmc_spi: read block, 16 bytes [ 137.450714] mmc0: req done (CMD10): 0: 00000000 00000000 00000000 00000000 [ 137.450723] mmc0: 16 bytes transferred: 0 [ 137.450747] mmc0: starting CMD9 arg 00000000 flags 000000b5 [ 137.450757] mmc0: blksz 16 blocks 1 flags 00000200 tsac 0 ms nsac 64 [ 137.450770] mmc_spi spi1.1: mmc_spi: CMD9, resp R1 [ 137.450850] mmc_spi spi1.1: ... CMD9 response SPI_R1: resp 0000 00000000 [ 137.450860] mmc_spi spi1.1: mmc_spi: read block, 16 bytes [ 137.451018] mmc0: req done (CMD9): 0: 00000000 00000000 00000000 00000000 [ 137.451026] mmc0: 16 bytes transferred: 0 [ 137.451043] mmc0: starting CMD55 arg 00000000 flags 00000095 [ 137.451055] mmc_spi spi1.1: mmc_spi: CMD55, resp R1 [ 137.451163] mmc_spi spi1.1: ... CMD55 response SPI_R1: resp 0000 00000000 [ 137.451178] mmc0: req done (CMD55): 0: 00000000 00000000 00000000 00000000 [ 137.451193] mmc0: starting CMD51 arg 00000000 flags 000000b5 [ 137.451203] mmc0: blksz 8 blocks 1 flags 00000200 tsac 100 ms nsac 0 [ 137.451216] mmc_spi spi1.1: mmc_spi: CMD51, resp R1 [ 137.451294] mmc_spi spi1.1: ... CMD51 response SPI_R1: resp 0000 00000000 [ 137.451304] mmc_spi spi1.1: mmc_spi: read block, 8 bytes [ 137.451969] mmc0: req done (CMD51): 0: 00000000 00000000 00000000 00000000 [ 137.451978] mmc0: 8 bytes transferred: 0 [ 137.451996] mmc0: starting CMD55 arg 00000000 flags 00000095 [ 137.452009] mmc_spi spi1.1: mmc_spi: CMD55, resp R1 [ 137.452117] mmc_spi spi1.1: ... CMD55 response SPI_R1: resp 0000 00000000 [ 137.452132] mmc0: req done (CMD55): 0: 00000000 00000000 00000000 00000000 [ 137.452145] mmc0: starting CMD13 arg 00000000 flags 000001b5 [ 137.452155] mmc0: blksz 64 blocks 1 flags 00000200 tsac 100 ms nsac 0 [ 137.452168] mmc_spi spi1.1: mmc_spi: CMD13, resp R2/R5 [ 137.452285] mmc_spi spi1.1: ... CMD13 response SPI_R2/R5: resp 0000 00000000 [ 137.452294] mmc_spi spi1.1: mmc_spi: read block, 64 bytes [ 137.452664] mmc0: req done (CMD13): 0: 00000000 00000000 00000000 00000000 [ 137.452672] mmc0: 64 bytes transferred: 0 [ 137.452690] mmc0: starting CMD6 arg 00fffff0 flags 000000b5 [ 137.452700] mmc0: blksz 64 blocks 1 flags 00000200 tsac 100 ms nsac 0 [ 137.452712] mmc_spi spi1.1: mmc_spi: CMD6, resp R1 [ 137.452790] mmc_spi spi1.1: ... CMD6 response SPI_R1: resp 0000 00000000 [ 137.452799] mmc_spi spi1.1: mmc_spi: read block, 64 bytes [ 137.453474] mmc0: req done (CMD6): 0: 00000000 00000000 00000000 00000000 [ 137.453483] mmc0: 64 bytes transferred: 0 [ 137.453499] mmc0: starting CMD59 arg 00000001 flags 00000080 [ 137.453512] mmc_spi spi1.1: mmc_spi: CMD59, resp R1 [ 137.453619] mmc_spi spi1.1: ... CMD59 response SPI_R1: resp 0000 00000000 [ 137.453634] mmc0: req done (CMD59): 0: 00000000 00000000 00000000 00000000 [ 137.453646] mmc0: host does not support reading read-only switch, assuming write-enable [ 137.453657] mmc0: clock 5000000Hz busmode 2 powermode 2 cs 1 Vdd 23 width 0 timing 0 [ 137.453668] mmc_spi spi1.1: mmc_spi: clock to 5000000 Hz, 0 [ 137.453688] mmc0: new SDHC card on SPI [ 137.454593] mmcblk0: mmc0:0000 SD8GB 7.42 GiB [ 137.455555] mmc0: starting CMD18 arg 00000000 flags 000000b5 [ 137.455567] mmc0: blksz 512 blocks 8 flags 00000200 tsac 100 ms nsac 0 [ 137.455577] mmc0: CMD12 arg 00000000 flags 00000095 [ 137.455594] mmc_spi spi1.1: mmc_spi: CMD18, resp R1 [ 137.455685] mmc_spi spi1.1: ... CMD18 response SPI_R1: resp 0000 00000000 [ 137.455696] mmc_spi spi1.1: mmc_spi: read block, 512 bytes [ 137.458447] mmc_spi spi1.1: read - crc error: crc_val=0x20fe, computed=0x341d len=512 [ 137.458457] mmc_spi spi1.1: read status -84 [ 137.458466] mmc_spi spi1.1: mmc_spi: CMD12, resp R1B [ 137.458619] mmc_spi spi1.1: ... CMD12 response SPI_R1B: resp 0000 00000000 [ 137.458631] mmc_spi spi1.1: mmc_spi: CMD18, resp R1 [ 137.458709] mmc_spi spi1.1: ... CMD18 response SPI_R1: resp 0000 00000000 [ 137.458719] mmc_spi spi1.1: mmc_spi: read block, 512 bytes [ 137.461139] mmc_spi spi1.1: read - crc error: crc_val=0x2020, computed=0x341d len=512 [ 137.461149] mmc_spi spi1.1: read status -84 [ 137.461158] mmc_spi spi1.1: mmc_spi: CMD12, resp R1B [ 137.461310] mmc_spi spi1.1: ... CMD12 response SPI_R1B: resp 0000 00000000 [ 137.461322] mmc_spi spi1.1: mmc_spi: CMD18, resp R1 [ 137.461400] mmc_spi spi1.1: ... CMD18 response SPI_R1: resp 0000 00000000 [ 137.461410] mmc_spi spi1.1: mmc_spi: read block, 512 bytes [ 137.463825] mmc_spi spi1.1: read - crc error: crc_val=0x2020, computed=0x341d len=512 [ 137.463834] mmc_spi spi1.1: read status -84 [ 137.463843] mmc_spi spi1.1: mmc_spi: CMD12, resp R1B [ 137.463993] mmc_spi spi1.1: ... CMD12 response SPI_R1B: resp 0000 00000000 [ 137.464005] mmc_spi spi1.1: mmc_spi: CMD18, resp R1 [ 137.464082] mmc_spi spi1.1: ... CMD18 response SPI_R1: resp 0000 00000000 [ 137.464092] mmc_spi spi1.1: mmc_spi: read block, 512 bytes [ 137.466577] mmc_spi spi1.1: read - crc error: crc_val=0x2020, computed=0x341d len=512 [ 137.466586] mmc_spi spi1.1: read status -84 [ 137.466595] mmc_spi spi1.1: mmc_spi: CMD12, resp R1B [ 137.466749] mmc_spi spi1.1: ... CMD12 response SPI_R1B: resp 0000 00000000 [ 137.466761] mmc_spi spi1.1: mmc_spi: CMD18, resp R1 [ 137.466840] mmc_spi spi1.1: ... CMD18 response SPI_R1: resp 0000 00000000 [ 137.466850] mmc_spi spi1.1: mmc_spi: read block, 512 bytes [ 137.469290] mmc_spi spi1.1: read - crc error: crc_val=0x2020, computed=0x341d len=512 [ 137.469300] mmc_spi spi1.1: read status -84 [ 137.469308] mmc_spi spi1.1: mmc_spi: CMD12, resp R1B [ 137.469459] mmc_spi spi1.1: ... CMD12 response SPI_R1B: resp 0000 00000000 [ 137.469471] mmc_spi spi1.1: mmc_spi: CMD18, resp R1 [ 137.469548] mmc_spi spi1.1: ... CMD18 response SPI_R1: resp 0000 00000000 [ 137.469558] mmc_spi spi1.1: mmc_spi: read block, 512 bytes [ 137.472017] mmc_spi spi1.1: read - crc error: crc_val=0x2020, computed=0x341d len=512 [ 137.472026] mmc_spi spi1.1: read status -84 [ 137.472035] mmc_spi spi1.1: mmc_spi: CMD12, resp R1 [ 137.472143] mmc_spi spi1.1: ... CMD12 response SPI_R1: resp 0000 00000000 [ 137.472160] mmc0: req done (CMD18): 0: 00000000 00000000 00000000 00000000 [ 137.472169] mmc0: 0 bytes transferred: -84 [ 137.472178] mmc0: (CMD12): 0: 00000000 00000000 00000000 00000000 [ 137.472200] mmc0: starting CMD13 arg 00000000 flags 00000195 [ 137.472214] mmc_spi spi1.1: mmc_spi: CMD13, resp R2/R5 [ 137.472327] mmc_spi spi1.1: ... CMD13 response SPI_R2/R5: resp 0000 00000000 [ 137.472342] mmc0: req done (CMD13): 0: 00000000 00000000 00000000 00000000 [ 137.472357] mmcblk0: error -84 transferring data, sector 0, nr 8, cmd response 0x0, card status 0x0 [ 137.472373] mmc0: clock 0Hz busmode 2 powermode 0 cs 1 Vdd 0 width 0 timing 0
_______________________________________________ Kernelnewbies mailing list Kernelnewbies@xxxxxxxxxxxxxxxxx https://lists.kernelnewbies.org/mailman/listinfo/kernelnewbies