Jump to content

    

Пропадают данные с microSD

1. Адрес должен быть выровнен на границу сектора.

Как записать произвольный байт? Типа отправить весь сектор где иные байты задать erase-default-value?

Естественно.

 

2. Записать можно только сектор целиком.

см. п.1

см.п.1

 

Мне представляется NAND как хранилище данных с корректирующими кодами размером с сектор.

Это можно проверить. И если так - тогда просто накапливать данные в ОЗУ до полного сектора.

Share this post


Link to post
Share on other sites

jcxz, у меня буфер в ОЗУ размером с запись, т.е 256 байт.

Вы, по сути, предлагаете писать страницей, под которую нужно постоянно держать буфер в ОЗУ,

которого у меня в обрез. Но это уже детали реализации, которые сейчас не существенны,

мне бы проблему пропадания данных решить...

 

Кстати, у меня sd карта сидит на spi, к которому подключено еще 2 устройства, cs у карты, разумеется, свой.

Может ли "паразитное" тактирование карты(при поднятом cs) при обращении к другим устройствам на шине приводить

к нарушениям в логике работы карты(зависаниям, пропаданиям данных)? Кто нибудь сталкивался?

Share this post


Link to post
Share on other sites
Может ли "паразитное" тактирование карты(при поднятом cs)

А зачем у Вас это тактирование при поднятом CS?

Если на других устройствах поднят CS, то обычно не должно. Хотя это зависит от того, как реагируют на CS те устройства (см. доки на них). Обычно при поднятом CS слэйв-устройства не должны никак реагировать на любые внешние сигналы.

Share this post


Link to post
Share on other sites
Может ли "паразитное" тактирование карты(при поднятом cs) при обращении к другим устройствам на шине приводить

к нарушениям в логике работы карты(зависаниям, пропаданиям данных)? Кто нибудь сталкивался?

К разнообразным нарушениям работы может приводить отсутствие этого тактирования после снятия CS, когда карта еще не перевела выход в Z.

То есть правильная последовательность: сняли CS - выдали "холостой" байт. Это выполняется?

Share this post


Link to post
Share on other sites

jcxz, под "паразитным" тактированием я имел в виду клоки при обращении к другим устройствам на шине,

когда cs карты поднят.

 

aaarrr, да, выполняется. Вы не сталкивались на практике с произвольным пропаданием данных?

 

Share this post


Link to post
Share on other sites
aaarrr, да, выполняется. Вы не сталкивались на практике с произвольным пропаданием данных?

Нет. Но никогда и не вешал карту на одну шину с другими устройствами. Маловероятно, что это

является причиной такого поведения, больше похоже на аппаратную проблему - питание, целостность

сигналов. Контроль CRC включен?

Share this post


Link to post
Share on other sites
Кстати, у меня sd карта сидит на spi, к которому подключено еще 2 устройства, cs у карты, разумеется, свой.

Может ли "паразитное" тактирование карты(при поднятом cs) при обращении к другим устройствам на шине приводить

к нарушениям в логике работы карты(зависаниям, пропаданиям данных)? Кто нибудь сталкивался?

Достаточны ли паузы после кадра с одного устройства и до другого кадра на другое устройство? Ведь после снятия CS абонент должен перевести свой выход в 3-е состояние... И для этого нужно время. Есть ли подпор по входной шине данных?

Share this post


Link to post
Share on other sites
Контроль CRC включен?

 

Который включается 59-й командой? Да, включен.

 

Насчет аппаратной проблемы я думал, но фронты нормальные, питание в норме,

да и карты других вендоров работают нормально...

 

Достаточны ли паузы после кадра с одного устройства и до другого кадра на другое устройство? Ведь после снятия CS абонент должен перевести свой выход в 3-е состояние... И для этого нужно время. Есть ли подпор по входной шине данных?

 

В последнем эксперименте я оставил на шине только sd карту. Проблема осталась...

Подтяжки есть.

Share this post


Link to post
Share on other sites
В последнем эксперименте я оставил на шине только sd карту. Проблема осталась...

Вы бы хоть описали - как пишете и что пишете? А то может быть Вы пишете один и тот же сектор, и на картах где есть "Wear leveling" оно спасает от его протирания, а попалась такая, которая не умеет "Wear leveling" - и беда.

Но это уже детали реализации, которые сейчас не существенны,мне бы проблему пропадания данных решить...

Без знания этих деталей Вам тут никто не сможет помочь. Угадает разве что....

Чем больше деталей - тем выше вероятность помощи. Как то так.

Share this post


Link to post
Share on other sites

А отдельно от своего устройства пробовали карты гонять в таком же режиме (т.е. записали 256 байт - сбросили кэш)?

Может, карты сами по себе бракованные.

Share this post


Link to post
Share on other sites
А отдельно от своего устройства пробовали карты гонять в таком же режиме (т.е. записали 256 байт - сбросили кэш)?

Может, карты сами по себе бракованные.

 

Я уже ранее предлагал это ТСу, проверить сами карты на работоспособность, проверил он или нет - непонятно...

Share this post


Link to post
Share on other sites
Я уже ранее предлагал это ТСу, проверить сами карты на работоспособность, проверил он или нет - непонятно...

 

Проверял той программой, которую вы советовали. Прогнал несколько раз, все нормально.

В цикле она работать не умеет.

 

А отдельно от своего устройства пробовали карты гонять в таком же режиме (т.е. записали 256 байт - сбросили кэш)?

Может, карты сами по себе бракованные.

 

Что значить "сбросить кэш"?

 

Вы бы хоть описали - как пишете и что пишете? А то может быть Вы пишете один и тот же сектор, и на картах где есть "Wear leveling" оно спасает от его протирания, а попалась такая, которая не умеет "Wear leveling" - и беда.

 

Пишутся несколько типов записей 128, 256 и 512 байт. Каждый тип пишется в свою область, области выровнены по границе блока.

Естественно, запись НЕ происходит в один сектор, ее адрес постоянно инкрементируется. Области кольцевые, но глюк случается,

когда закольцовка еще не произошла. Пропадание данных происходит строго в тот момент, когда карта зависает.

 

Пока склоняюсь к мысли, что карта не совсем корректно работает в spi режиме. Других мыслей пока нет.

Карты других вендоров работают нормально.

 

Share this post


Link to post
Share on other sites
Что значить "сбросить кэш"?

На всех современных ОС записи на диск буферизируются, поэтому для достижения такого же эффекта износа,

как в устройстве, оперирующем блоками по 256 байт, нужно после каждой операции записи принудительно сбрасывать

буфер на диск.

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
Sign in to follow this