|
SD-карта работает наполовину, в чем дело? |
|
|
|
Nov 26 2012, 08:05
|
Профессионал
    
Группа: Свой
Сообщений: 1 284
Регистрация: 9-04-06
Пользователь №: 15 968

|
Добрый день всем. Взял с оперкорес контроллер SD карт. Прицепил, контроллер вроде все как надо на шину SD выдает, а вот карта на один запрос отвечает, на другой нет. Кто работал, подскажите куда копать. Я бы свалил на кривые руки, которые прикручивали wishbone корку к ниосу, но сигналы смотрю на шине SD сигналтапом, и они вроде как в порядке... Вот две картинки: первая - посылаю команду CMD8 (первый байт 0х48) и получаю ответ от SD. Ответ - по спецификации, правильный. Точно таким же макаром посылаю CMD2 (первый байт 0х42)- чтение CID - ответа нет, при этом на шине SD (вторая картинка) вроде все ОК. Частота шины 20 МГц. Деления сверху соответствуют тактам клока. Верхний сигнал - разрешение выхода CMD. Пробовал так: CMD8->CMD8->CMD2 - на 8 ответ есть, на 2 нет CMD8->CMD2->CMD8 - опять на cmd8 отвечает в обоих случаях, на cmd2-нет. Вот честно, хз что еще смотреть. Вроде все уже прозрачно...
Эскизы прикрепленных изображений
|
|
|
|
|
 |
Ответов
|
Nov 26 2012, 10:34
|
Участник

Группа: Участник
Сообщений: 34
Регистрация: 16-01-09
Пользователь №: 43 460

|
После CMD8 надо ACMD41 и только потом CMD2 . Инициализация проводится на частоте идущей на карту 100 - 400 КГц Посмотрите SD спецификацию (она идет с исходниками контроллера) там есть рисунки диаграм инициализации. Речь идет об этом контроллере ? http://opencores.org/project,sdcard_mass_storage_controllerЕсли используется вариант 8-битный, то там есть ошибочка - при записи перепутаны тетрады в байте а в остальном работает.
|
|
|
|
|
Nov 26 2012, 13:05
|
Профессионал
    
Группа: Свой
Сообщений: 1 284
Регистрация: 9-04-06
Пользователь №: 15 968

|
Цитата(gk2 @ Nov 26 2012, 14:34)  После CMD8 надо ACMD41 и только потом CMD2 . Инициализация проводится на частоте идущей на карту 100 - 400 КГц Посмотрите SD спецификацию (она идет с исходниками контроллера) там есть рисунки диаграм инициализации. Речь идет об этом контроллере ? http://opencores.org/project,sdcard_mass_storage_controllerЕсли используется вариант 8-битный, то там есть ошибочка - при записи перепутаны тетрады в байте а в остальном работает. Большое спасибо, сейчас попробую. Про 100-400 кгц упустил, перевыкурю спецификацию. А можно ссылки на исходники контроллера (от спецификации)? В моей спецификации нет таких ... Контроллер - да, в точку, он самый, 8-битный. Только не заметил я перемену тетрад, команда нормально проходит, это в данных? А разве не учтено в контроллере 100-400 кГц? там ведь клок всегда один - вишбоновский, не переключается. Если не жалко, можете скинуть исходники инициализации и чтения / записи ? И еще при компиляции у меня он сказал, что три-стейт выходы на данные нет необходимости ставить... Еще не разбирался с этим, не дошел, у вас не было такого?
|
|
|
|
|
Nov 26 2012, 21:25
|
Профессионал
    
Группа: Свой
Сообщений: 1 284
Регистрация: 9-04-06
Пользователь №: 15 968

|
В общем, все равно на CMD2 не отвечает. Делаю сейчас так как написано в спецификации, Card Initialization and identification process:
CMD0 -> жду таймаут, ответа нет CMD8 -> получаю ответ "compatible voltage and check pattern correct" CMD55 -> получаю ответ R1, в регистре card status = 0x00000120 имею следующее: поле current_state =0 (Idle), Ready for data = 1, APP_CMD=1. Остальные биты в нуле. CMD41 -> получаю ответ R3, ответ OCR=0xff800001, т.е. busy=1 (не занята), CCS=1 (high capacity card), диапазон питаний 3.5-3.6В CMD2 -> Нет ответа CMD3 -> Нет ответа
Что теперь не так?
PS Частоту не менял, так на 20 МГц и читаю, но вроде ответы то адекватные до CMD2... PPS Пока писал, gk2 прислал проект, огромное спасибо, посмотрю, сравню.
|
|
|
|
Сообщений в этой теме
alexPec SD-карта работает наполовину Nov 26 2012, 08:05 Mikhalych Цитата(alexPec @ Nov 26 2012, 12:05) Проб... Nov 26 2012, 09:21 alexPec Цитата(Mikhalych @ Nov 26 2012, 13:21) Та... Nov 26 2012, 09:39  Mikhalych Цитата(alexPec @ Nov 26 2012, 13:39) Если... Nov 26 2012, 10:26 gk2 Вот проект на котором пробовал этот контроллер. Пл... Nov 26 2012, 21:05 alexPec Большое спасибо, gk2! C Вашим алгоритмом все п... Nov 27 2012, 19:14  alexPec С данными вопрос возник: после чтения блока получа... Nov 28 2012, 14:19   aaarrr Цитата(alexPec @ Nov 28 2012, 18:19) Хоте... Nov 28 2012, 14:35
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|