[PATCH] SPI SD-Card: setup valid CRC-7 for STOP_TRANSMISSION command.
Pavel Pisa
ppisa4lists at pikron.com
Fri Oct 4 07:34:38 UTC 2013
From: Pavel Pisa <ppisa at pikron.com>
STOP_TRANSMISSION command is used to finish READ_MULTIPLE_BLOCK
command and its format is regular command format.
It requires valid CRC-7 to have effect at least on
some card brands else it is ignored and attempt
to issue next READ or WRITE commands results in
illegal command condition (0x04) preceded by strange
(0x3f) for tested card.
Signed-off-by: Pavel Pisa <ppisa at pikron.com>
---
c/src/libchip/i2c/spi-sd-card.c | 4 ++++
1 file changed, 4 insertions(+)
diff --git a/c/src/libchip/i2c/spi-sd-card.c b/c/src/libchip/i2c/spi-sd-card.c
index 5a30451..89d5fb5 100644
--- a/c/src/libchip/i2c/spi-sd-card.c
+++ b/c/src/libchip/i2c/spi-sd-card.c
@@ -501,8 +501,12 @@ static int sd_card_send_register_command( sd_card_driver_entry *e, uint32_t comm
static int sd_card_stop_multiple_block_read( sd_card_driver_entry *e)
{
int rv = 0;
+ uint8_t crc7;
SD_CARD_COMMAND_SET_COMMAND( e->command, SD_CARD_CMD_STOP_TRANSMISSION);
+ SD_CARD_COMMAND_SET_ARGUMENT( e->command, 0);
+ crc7 = sd_card_compute_crc7( e->command + 1, 5);
+ SD_CARD_COMMAND_SET_CRC7( e->command, crc7);
rv = rtems_libi2c_write_bytes( e->bus, e->command, SD_CARD_COMMAND_SIZE);
RTEMS_CHECK_RV( rv, "Write stop transfer token");
--
1.7.10.4
More information about the devel
mailing list