реклама на сайте
подробности

 
 
> SD-карта работает наполовину, в чем дело?
alexPec
сообщение Nov 26 2012, 08:05
Сообщение #1


Профессионал
*****

Группа: Свой
Сообщений: 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-нет.

Вот честно, хз что еще смотреть. Вроде все уже прозрачно...
Эскизы прикрепленных изображений
Прикрепленное изображение
Прикрепленное изображение
 
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
gk2
сообщение Nov 26 2012, 21:05
Сообщение #2


Участник
*

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



Вот проект на котором пробовал этот контроллер. Плата Spartan-3E Starter Kit HW-SPAR3E-SK
с подпаяным SD разъемом. Процессор - софтпроцессор Lattice LM8, lm8_prg.s - программа на ассемблере LM8
(Он несложный, разобраться с последовательностью команд можно.)
Она инициализирует карту и читает 0 сектор выводя отладочные данные в COM порт.
Вот проверил сейчас с картой 512 МБ
term.txt - результат работы. SDHC под рукой нет, но инициализацию она тоже проходила, чтение не пробовал.
По записи, к сожалению, примеров нет, все это было 2 года назад и частично потерялось.

sd_clk - программируется, и может быть не больше чем половина вишбона

SD спецификация - файл Simplified_Physical_Layer_Spec-1.pdf в документации к исходникам контроллера

И да, тетрады поменяны при записи данных.
Три-стейт -если речь идет об sd_dat то надо, посмотрите в моем примере

Сообщение отредактировал gk2 - Nov 26 2012, 21:13
Прикрепленные файлы
Прикрепленный файл  lm8m_sd2.7z ( 139.82 килобайт ) Кол-во скачиваний: 66
 
Go to the top of the page
 
+Quote Post
alexPec
сообщение Nov 27 2012, 19:14
Сообщение #3


Профессионал
*****

Группа: Свой
Сообщений: 1 284
Регистрация: 9-04-06
Пользователь №: 15 968



Большое спасибо, gk2! C Вашим алгоритмом все получилось. Инициализация проходит как надо, хоть больших, хоть маленьких карт, клок оставил 20 МГЦ - с ним все работает. До данных не добрался еще, начинаю копать...
Go to the top of the page
 
+Quote Post
alexPec
сообщение Nov 28 2012, 14:19
Сообщение #4


Профессионал
*****

Группа: Свой
Сообщений: 1 284
Регистрация: 9-04-06
Пользователь №: 15 968



С данными вопрос возник: после чтения блока получаю блок данных, как положено, данные те что ожидаю, но после 1024 тактов (512 бай, по 2 тетрады на байт), а после еще 17 тетрад какой-то лабуды. Хотел было списать на CRC, но в спецификации вроде CRC16 - 4 тетрады. Пицепляю картинку сигналтапа (вверху видно что после 1024 - го такта сыплется еще что-то. Это что-то остается в FIFO, конечно можно его (фифо) чистить перед чтением, но охота разобраться, что это такое. Кто знает, поскажите пожалуйста.

UPD: Все, разобрался, CRC для каждой линии данных своя, 16-битная, все сходится.
Эскизы прикрепленных изображений
Прикрепленное изображение
Прикрепленное изображение
 
Go to the top of the page
 
+Quote Post
aaarrr
сообщение Nov 28 2012, 14:35
Сообщение #5


Гуру
******

Группа: Свой
Сообщений: 10 713
Регистрация: 11-12-04
Пользователь №: 1 448



Цитата(alexPec @ Nov 28 2012, 18:19) *
Хотел было списать на CRC, но в спецификации вроде CRC16 - 4 тетрады.

Для каждой линии 16.
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 22nd July 2025 - 03:12
Рейтинг@Mail.ru


Страница сгенерированна за 0.02413 секунд с 7
ELECTRONIX ©2004-2016