|
SD card on SPI, как организовать общение c SD картой по SPI ? |
|
|
|
Aug 6 2009, 17:46
|
Участник

Группа: Участник
Сообщений: 15
Регистрация: 29-09-05
Из: Москва
Пользователь №: 9 094

|
Вопрос таков: все ли SPI у SD карт одинаковые ? Столкнулся со следующей проблемой: пытался инициализировать SD карту (взял 2 разные, как оказалось ответы на команды инициализации CMD8, ACMD41 и CMD55 у них тоже разные).
одна (от NOKIA) говорит что много ошибок а вот от Kingston на CMD55 (55+0x40) выдаёт 5 (Idle + Error Comand) так же как и на ACMD41 и CMD1
(может я что не так делаю) ?
Алгоритм инициализации следующий:
1. отправляю 16 байт 0xFF 2. отправляю CMD0 получаю 1 3. отправляю CMD1 или CMD55 + ACMD41(0xC0+41) - получаю 5 на каждую команду
при отправке всех команд CS опускается и поднимается после нескольких опытов карточка стала возвращать 0xe0 на все команды
Вопрос: может проще MMC использовать ?
|
|
|
|
3 страниц
1 2 3 >
|
 |
Ответов
(1 - 34)
|
Aug 7 2009, 06:47
|
Участник

Группа: Участник
Сообщений: 15
Регистрация: 29-09-05
Из: Москва
Пользователь №: 9 094

|
Цитата(sergeeff @ Aug 6 2009, 22:47)  Зайдите на сайт Atmel'а. Там в разделе 32-разрядных ARM'ов есть свежие библиотеки, в том числе и по работе с SD. У меня проблем с инициализацией карт не возникало. работа с картой производилась по SPI ?
|
|
|
|
|
Aug 24 2009, 15:17
|
Группа: Участник
Сообщений: 10
Регистрация: 2-08-09
Пользователь №: 51 706

|
Я как раз тоже занялся изучением SD и мини-SD карт. Шастаю по интернету, никак не могу найти документ с полным описанием того как они работают (одна реклама). Поделитесь подобным документом, прочитав который, можно будет освоить работу с SD-картами. Заранее спасибо.
|
|
|
|
|
Aug 24 2009, 21:09
|
Группа: Участник
Сообщений: 10
Регистрация: 2-08-09
Пользователь №: 51 706

|
Огромное вам спасибо. Просто опытному разработчику сразу в голову приходит нужно решение, а когда начинаешь, то так легко запутаться Можете ответить ещё на один, последний вопрос. В чем разница между SD-card и MicroSD-card? Везде пишут, что разница только в габаритах, но так ли это? Волнует вопрос поддерживает ли Micrо-SD режим SPI?? А то фраза "опционально" очень смущает. Заранее спасибо за советы и помощь.
Сообщение отредактировал petrovichs - Aug 24 2009, 21:17
|
|
|
|
|
Aug 25 2009, 05:59
|

Ally
     
Группа: Модераторы
Сообщений: 6 232
Регистрация: 19-01-05
Пользователь №: 2 050

|
microSD Kingston-ы на 2 Гб поддерживают SPI. Проверено. За остальных сказать не могу. Но что точно можно сказать это то, что SD карты чувствительны к целостности сигналов и как и все микрухи не любят овершутингов и фазовых сдвигов клока. Поэтому стоит тестировать всегда на минимальной скорости и с последовательными резаками. Второе это то, что даже SD карты одного производителя и типономинала но сделанные в тайване и в японии могут по разному реагировать на всякие вольности в протоколе. Был случай когда японские карты не читались к картридерах оставшихся от тайваньских. Есть другой USB кардридер, так тот тоже иные карты берет сразу как их вставишь, а для других у кардридера надо питание перетыкать. Исследования показали что вроде как некоторые карты плохо реагируют на повторную команду CMD0. Цитата(petrovichs @ Aug 25 2009, 00:09)  Волнует вопрос поддерживает ли Micrо-SD режим SPI?? А то фраза "опционально" очень смущает.
|
|
|
|
|
Aug 25 2009, 19:25
|
Группа: Участник
Сообщений: 10
Регистрация: 2-08-09
Пользователь №: 51 706

|
Все-таки задам маленький последний вопросик. Если у микроконтроллера нет аппаратной поддержки интерфейса SD, то сложна ли программная её реализация?
|
|
|
|
|
Aug 25 2009, 22:06
|
Группа: Участник
Сообщений: 10
Регистрация: 2-08-09
Пользователь №: 51 706

|
Я понял, значит если нет аппаратного SD-интерфейса, тогда только SPI остается.
|
|
|
|
|
Sep 8 2009, 14:54
|

Гуру
     
Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244

|
Цитата(Ndf @ Sep 8 2009, 13:59)  Подскажите в чем может быть проблема? В Вашем железе и/или диаграмме.... 20MHz это вообще обыденная частота. А конкретную, Вы можете и у карточки спросить  - читайте документацию. P.S. Надеюсь, Вы не пытаетесь сразу ДО инициализации работать на мегагерцах?
--------------------
Feci, quod potui, faciant meliora potentes
|
|
|
|
|
Sep 9 2009, 11:15
|
Частый гость
 
Группа: Свой
Сообщений: 101
Регистрация: 22-08-07
Пользователь №: 29 977

|
Цитата(zltigo @ Sep 8 2009, 18:54)  ...читайте документацию. P.S. Надеюсь, Вы не пытаетесь сразу ДО инициализации работать на мегагерцах? Прочитал MultiMediaCard™ User’s Manual Hitachi - нет там (или не заметил) такого регистра в котором хранилось бы заводское значение макс частоты для девайса.Единственное что нашел:"there are two communication protocol modes—MMC (MultiMediaCard™) mode and SPI mode. The maximum clock operating frequency in both modes is 20 MHz". Также сказано (ежу понятно), что после инициализации можно повысить Fclk до 20Мгц, так и делаю: CMD0->CMD1->[responce=0 - увеличиваю Fclk с 400кГц->1Мгц]->mmc_set_block_length(512)->....ошибка. Может какую команду еще пропустил? Если работать на той же скорости то все нормально.
|
|
|
|
|
Sep 11 2009, 13:04
|
Частый гость
 
Группа: Свой
Сообщений: 101
Регистрация: 22-08-07
Пользователь №: 29 977

|
Отвечу сам себе... причину нашел  , и она кроется где то в недрах DMA режима. Дело в том что в исходнике от Analog Device почему то используется SPI в DMA chain mode with interrupts, т.е. модулю DMA нужно сообщить адрес первого байта команды, кол-во байт, назначить процедуру прерывания, куда попадаем после приема очередного байта. Такой код предназначен для работы в фоновом режиме и использует всю мощь проца,но с другой создает много проблем - например DMA работает только с внутренней памятью, и имеет свои заморочки которые часто заканчиваются зависанием проца (например когда несколько модулей его используют одновременно). На экране осциллографа все выглядит так как должно быть, но карта постоянно выдает ошибки. В общем отключил я все эти навороты, написал блокирующую процедуру вывода в SPI и все заработало вплоть до 20 Мгц CLK
Сообщение отредактировал Ndf - Sep 11 2009, 13:05
|
|
|
|
|
Jan 19 2013, 12:09
|

Гуру
     
Группа: Свой
Сообщений: 2 015
Регистрация: 23-01-07
Из: Москва
Пользователь №: 24 702

|
Цитата(Ndf @ Sep 10 2009, 16:36)  Прочитал еще раз spec... да, действительно, после ответа R1 на CMD9, клоки снимать не надо так как MMC/SD карта следом отправляет данные CSD регистра. Скажите , в каком документе написано как читать CSD в режиме SPI ? Уже третий день мучаюсь : Принимаю всё что карта ответила на CMD9 , 21 байт он начала и до того как пошли FF. Пытаюсь увидеть последовательность байтов как в CSD Version 1.0 (карта 1Гб) : 1 байт 0, 2,3 байт хх 4 байт 32 или 5А Но не вижу что бы 0 шёл на три байта раньше 0x32
--------------------
Если у Вас нет практического опыта в данной теме- не вступайте в дискуссию и не пишите никаких теоретических рассуждений! Заранее спасибо !
|
|
|
|
|
Jan 20 2013, 11:58
|
Частый гость
 
Группа: Участник
Сообщений: 147
Регистрация: 18-05-12
Пользователь №: 71 915

|
может поможет - вот рабочий код: Код enum sd_type {SD_NONE, SD_V1, SD_V2, MMC_V3}; enum {CSD_V1=0, CSD_V2=1}; enum { CMD0=0,CMD1=1,CMD2=2,CMD8=8,CMD9=9,CMD10=10,CMD13=13,CMD16=16,CMD17=17, CMD55=55,CMD58=58,CMD59=59,ACMD41=41 }; enum { R1_READY=0x00, R1_IDLE=0x01, R1_ERASE_RESET=0x02, R1_CMD_ILLEGAL=0x04, R1_CMD_CRC=0x08, R1_ERASE_SEQ=0x10, R1_ADDR=0x20, R1_PARAM=0x40 }; U8 sd_get_CSD(void) { sd_cs(0); sd_cmd_NoCRC(CMD9, 0x00000000, 0x57); sd.r1 = (sd_get_R1() == R1_READY); if (sd.r1) { sd.r1 = sd_get_buf(&sd.csd[0], 16, 0xFE); sd_update_csd(); } return sd.r1; } void sd_cmd_NoCRC(U8 cmd, U32 data, U8 crc) { spi_tx_U8_MSB(0xFF); spi_tx_U8_MSB(0x40 | cmd); spi_tx_U8_MSB(data >> 24); spi_tx_U8_MSB(data >> 16); spi_tx_U8_MSB(data >> 8); spi_tx_U8_MSB(data); spi_tx_U8_MSB((crc << 1) | 1); } U8 sd_get_R1(void) { U8 r1 = 0; U16 to = SD_CMD_TIMEOUT; do { r1 = spi_tx_U8_MSB(0xFF); } while (--to && (r1 == 0xFF)); sd.r1 = r1; return r1; } U8 sd_get_buf(U8 *buf, U16 len, U8 token) { U8 r1 = 0; U16 to = SD_CMD_TIMEOUT; do { r1 = (spi_tx_U8_MSB(0xFF) == token); } while (--to && !r1); if (r1) { spi_rx_buf_MSB(buf, len);
//skip CRC spi_tx_U8_MSB(0xFF); spi_tx_U8_MSB(0xFF); } return r1; } void sd_update_csd(void) { sd.sectors = 0; if (sd_ok()) { sd.ver = sd.csd[0] >> 6; if (sd.ver == CSD_V1) { U32 size = 1UL << (sd.csd[5] & 0xF); size *= 1UL << (((sd.csd[9] & 0x3) << 1) + (sd.csd[10] >> 7) + 2); size *= (U32)((((U16)(sd.csd[6] & 3)) << 10) + ((U16)sd.csd[7] << 2) + ((U16)(sd.csd[8] & 0xC0) >> 6) + 1); sd.sectors = size >> 9; } else if (sd.ver == CSD_V2) { sd.sectors = ((((U32)(sd.csd[7] & 0x3F)) << 16) + (((U32)sd.csd[8]) << 8) + (U32)sd.csd[9]) << 10; } } }
Сообщение отредактировал polyname - Jan 20 2013, 12:00
|
|
|
|
|
Jul 23 2014, 19:46
|
Гуру
     
Группа: Свой
Сообщений: 2 724
Регистрация: 14-05-07
Из: Ярославль, Россия
Пользователь №: 27 702

|
Цитата(ohmjke @ Jul 23 2014, 15:19)  Пишу на SDHC блок и после этого читаю его. После записи сначала жду токена Data response со значением Data accepted - все ОК, получаю его сразу после второго байта CRC16. Затем, как я понял, карта шлёт busy байты в виде нулей, типа происходит запись из буфера в саму flash. Но эти busy заканчиваются только через 6-10 мс! Неужели, так и должно быть? Если так ждать после записи каждого байта, то получится максимальная скорость не более 100кБ/сек - бред.
Сейчас ещё раз глянул анализатором сразу после подачи питания - так busy длится вообще 20мс... Ага. И при чтении может быть весело: Цитата SP uSD 16GB <0.5ms – 4562197; <1.0ms - 52698; <2.0ms - 4683; <5.0ms - 2; <10 ms - 1; <20 ms - 18; <50 ms - 1971; >50 ms - 4; max - 59.9 ms Карта непрерывно читается. Измеряется время ожидания начала данных. После тире указано число случаев для данного диапазона. Для этой карты было 4 случая, когда данные были не готовы дольше 50 мс. Максимальное время ожидания почти 60 мс. Самая беда в том, что чтение начинает тормозить в среднем по 46 мс но на протяжении секунды: Цитата <51254590:43.9ms-12075> <+40:44.3ms-12147> <+50:44.1ms-12123> <+40:44.2ms-12139> <+50:44.1ms-12113> <+50:44.1ms-12091> <+40:44.1ms-12111> <+50:43.9ms-12057> <+50:47.4ms-13023> <+50:43.8ms-12001> <+40:45.8ms-12577> <+50:45.8ms-12573> <+70:45.5ms-12501> <+50:45.7ms-12541> <+40:45.7ms-12551> <+50:45.4ms-12467> <+70:46.0ms-12649> <+40:45.8ms-12573> <+50:46.3ms-12711> <+30:26.5ms-7271> <+40:27.5ms-7541> Тут формат такое <реальное время или смещение в мс от последнего события : время ожидания данных - число байт переданных в карту до момента ответа>
|
|
|
|
|
Jul 25 2014, 06:41
|
Частый гость
 
Группа: Свой
Сообщений: 101
Регистрация: 22-08-07
Пользователь №: 29 977

|
Цитата(ohmjke @ Jul 23 2014, 15:19)  Пишу на SDHC блок и после этого читаю его. После записи сначала жду токена Data response со значением Data accepted - все ОК, получаю его сразу после второго байта CRC16. Затем, как я понял, карта шлёт busy байты в виде нулей, типа происходит запись из буфера в саму flash. Но эти busy заканчиваются только через 6-10 мс! Неужели, так и должно быть? Если так ждать после записи каждого байта, то получится максимальная скорость не более 100кБ/сек - бред. Сейчас ещё раз глянул анализатором сразу после подачи питания - так busy длится вообще 20мс... Так и должно быть (у меня размер сектора 512 байт). Причем я не заметил чтобы SPI mode работал медленнее SD mode в режиме записи.
|
|
|
|
|
Feb 19 2016, 10:24
|
Профессионал
    
Группа: Свой
Сообщений: 1 404
Регистрация: 11-03-11
Из: Минск, Беларусь
Пользователь №: 63 539

|
Цитата(Ruslan-maniak @ Feb 19 2016, 12:21)  Помогите, товарищи. Третий день не могу запустить нормально SD карту. Работаю по SPI. Инициализация проходит нормально. Также OCR считывается вполне адекватным {0x80, 0xFF, 0x80, 0x00}. Но абсолютно на все остальные команды карта отвечает 0x05: и чтение CSD, и CID, и просто блоков памяти. Ничего не получается. Карта в картридере работает адекаватно. Если не ошибаюсь, то для некоторых команд ответ идёт не сразу, а надо вычитать несколько пустых (0xFF) байт. Может в этом проблема?
|
|
|
|
|
Feb 20 2016, 08:17
|
Гуру
     
Группа: Свой
Сообщений: 2 724
Регистрация: 14-05-07
Из: Ярославль, Россия
Пользователь №: 27 702

|
Цитата(Ruslan-maniak @ Feb 20 2016, 09:17)  CMD41 c аргументом 0x04000000 Это неверно. Посмотрите внимательно аргументы команды ACMD41. Цитата Followings are general rules of the argument of ACMD41: (1) If the voltage window field (bit 23-0) in the argument is set to zero, it is called "inquiry CMD41" that does not start initialization and is use for getting OCR. The inquiry ACMD41 shall ignore the other field (bit 31-24) in the argument. (2) If the voltage window field (bit 23-0) in the argument is set to non-zero at the first time, it is called "first ACMD41" that starts initialization. The other field (bit 31-24) in the argument is effective. (3) The argument of following ACMD41 shall be the same as that of the first ACMD41. При нулевом OCR инициализация не должна стартовать. Нулевой OCR можно использовать для получения правильного OCR.
|
|
|
|
|
Jul 28 2016, 17:17
|
Местный
  
Группа: Участник
Сообщений: 294
Регистрация: 5-08-14
Из: Ярославль
Пользователь №: 82 466

|
Здравствуйте. Чтобы не плодить темы, напишу сюда. Второй день пытаюсь завести SD-карту на SPI и не получается. Всё делаю по инструкции, но карта на CMD0 отвечает не 0x01. Вот скриншот логического анализатора, микроконтроллер принимает те же данные, что и на картинке. Прошу пояснить в чём я неправ.  Нашел причину, прошу прощения за глупый вопрос, не увидел, что CS падает на середине посылки, проверялся не то флаг в SPI периферии.
Сообщение отредактировал p_kav - Jul 28 2016, 20:41
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|