Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Хранение параметров в EEPROM. Контрольная сумма
Форум разработчиков электроники ELECTRONIX.ru > Сайт и форум > В помощь начинающему > Программирование
yurmala
Приветствую! Планируется хранить некие настройки во внешнем EEPROM.
Естественно возник вопрос о гарантии достоверности прочитанных параметров. Всякое ведь может быть? Правильно?
Какой вариант для этого оптимален?
1) Подсчет одной контрольной суммы на весь массив параметров (записанных данных) и запись его в начало EEPROM перед массивом параметров.
2) Отдельная CRC Для каждого параметра (например +1 байт к каждому параметру размерностью U32).
3) ?

Правильно ли хранить CRC Тоже в EEPROM, если как раз в чтении из EEPROM "мы слегка сомневаемся"?
Какой алгоритм CRC (реализацию на Си) порекомендуете?
Какие еще есть ньюансы при хранении параметров в EEPROM?

Заранее спасибо за помощь.
sergeeff
На мой взгляд вариантов два:
- eeprom исправна;
- eeprom неисправна (читает/пишет с ошибками, и ее надо менять).

CRC массива данных ответит на этот вопрос.
yurmala
Цитата(sergeeff @ Apr 27 2011, 13:03) *
На мой взгляд вариантов два:
- eeprom исправна;
- eeprom неисправна (читает/пишет с ошибками, и ее надо менять).

CRC массива данных ответит на этот вопрос.


спасибо за ответ.

Т.е. наверное принципиально достаточно после инициализации EEPROM проверить тестовой записью/чтением (1-2 раза) определенных значений и проверкой, чтобы сделать заключение о работе памяти и дальше не заморачиваться?
vvs157
Цитата(yurmala @ Apr 27 2011, 11:28) *
Т.е. наверное принципиально достаточно после инициализации EEPROM проверить тестовой записью/чтением (1-2 раза) определенных значений и проверкой, чтобы сделать заключение о работе памяти и дальше не заморачиваться?
А писать-то зачем? Надо только проверять правильности записи после внесения изменений. Если параметры меняются часто, то предпочтительно писать CRC для каждого параметра, так как ресурс на запись у EEPROM не бесконечен.
Ruslan1
Цитата(yurmala @ Apr 27 2011, 09:10) *
Приветствую! Планируется хранить некие настройки во внешнем EEPROM.
Естественно возник вопрос о гарантии достоверности прочитанных параметров. Всякое ведь может быть? Правильно?
Какой вариант для этого оптимален?
1) Подсчет одной контрольной суммы на весь массив параметров (записанных данных) и запись его в начало EEPROM перед массивом параметров.
2) Отдельная CRC Для каждого параметра (например +1 байт к каждому параметру размерностью U32).
3) ?

Правильно ли хранить CRC Тоже в EEPROM, если как раз в чтении из EEPROM "мы слегка сомневаемся"?
Какой алгоритм CRC (реализацию на Си) порекомендуете?
Какие еще есть ньюансы при хранении параметров в EEPROM?

Заранее спасибо за помощь.

Правильно все-таки говорить о просто контрольной сумме, а CRC это ее частный случай.

1. Нужно защититься от тривиальной ситуации "со всех адресов EEPROM читается одно и то же". Для этого в EEPROM должна быть записана какая-нибудь фраза, наличие которой проверяется програмой, ну скажем фраза "EEPROM"
2. Считаете контрольную сумму (КС) всей EEPROM и сравниваете с КС, записанной в той же EEPROM, если совпадает-то все в порядке.

Защищать по частям или нет- зависит от того, возможна ли работоспособность прибора при частичном слете EEPROM. То есть если возможно разделение данных на критичные и некритичные- то лучше защищать с помощью КС отдельно каждую область.

Насчет алгоритма подсчета КС- лучше всего CRC. как считать-зависит от того какой алгоритм быстрее работает на вашем железе. Некоторые микроконтроллеры имеют аппаратный вычислитель контрольных сумм, если это есть- однозначно нужно использовать.
Если считать программно CRC, то как правило табличное вычисление быстрее, но опять же смотреть нужно насколько. часто выигрыш незначительный и можно просто циклом посчитать.
demiurg_spb
Можно просто применить избыточность (например троекратную (нечётную в общем случае)) писать всё в трёх экземплярах,
а за валидный результат принимать чаще повторяющееся значение.
ИМХО так просто и надёжно.
Я такой принцип применял несколько раз в особо параноидальных случаях - работает отлично.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.