|
Увеличение количества циклов записи в EEPROM, как правильно программно? |
|
|
|
Mar 21 2007, 07:56
|
Местный
  
Группа: Свой
Сообщений: 303
Регистрация: 3-03-05
Пользователь №: 3 044

|
... Выделяем кусок ЭПРОМ, в котором храним счетчик ... При каждом сохранении в старых ячейках пишем $FF а в новых счетчик ... При чтениии от начала ищем not $FF и тем самымым выходим на запись. ... Таким образом при счетчике в 4 байта и перезаписи с частотой 1 Гц всей памяти хватит на 148 суток. Не густо. Код FM25256 256K bit Ferroelectric Nonvolatile RAM • Organized as 32,768 x 8 bits • Virtually Unlimited Endurance (10^14 Cycles) • 10 Year Data Retention •Very Fast Serial Peripheral Interface - SPI • Up to 15 MHz Frequency
--------------------
Опыт - чудесная вещь: легко использовать, можно продать, трудно пропить.
|
|
|
|
|
Mar 21 2007, 09:53
|
Знающий
   
Группа: Свой
Сообщений: 709
Регистрация: 3-05-05
Пользователь №: 4 693

|
Цитата(CDT @ Mar 21 2007, 07:56)  Код FM25256 • Virtually Unlimited Endurance (10^14 Cycles) Да, ФРАМ здесь самато. Реально ресурс, коншна, гораздо меньше. На Телесиське проскакивала цыфра 1е9, вырванная с кровью из интимного места техподдержки. Кроме того, у ФРАМ чтение разрушающее. Т.е. его ресурс как ПЗУ сильно ограничен. В отличие от режима ОЗУ или ЕЕПРОМ-флэш. Там наоборот.
|
|
|
|
|
Mar 21 2007, 10:14
|
Гуру
     
Группа: Свой
Сообщений: 2 702
Регистрация: 14-07-06
Пользователь №: 18 823

|
Цитата(smk @ Mar 20 2007, 21:31)  В программе используется переменная "char n". Всякий раз при включении она инкременируется и по достижении определенного значения - обнуляется. Чтение-запись происходит примерно 1 раз в секунду. При количестве циклов 100 000, надолго одной ячейки не хватит. Есть необходимость писать поочередно во все ячейки EEPROM. Как это сделать правильно, при условии что между любыми двумя циклами чтения-записи контроллер отправляется в "powerdown". Кто-то делал подобное? Как это можно сделать вообще, ведь адрес тоже нужно где-то помнить? Буду крайне признателен за подсказки и примеры!  1. Обычно делают так, чтобы данные в EEPROM записывались только при выключении питания. Если питание не батарейное, то нет проблем. Если батарейное... Наверно, тоже возможно - проснуться, проверить напряжение на батарее и, если мало, то сохраниться. Только нужно сделать программнй гистерезис, чтобы не было проблем при питании близком к критическому. 2. Цитата Выделяем кусок ЭПРОМ, в котором храним счетчик ... При каждом сохранении в старых ячейках пишем $FF а в новых счетчик ... При чтениии от начала ищем not $FF и тем самымым выходим на запись.
... Таким образом при счетчике в 4 байта и перезаписи с частотой 1 Гц всей памяти хватит на 148 суток. Не густо. Это неэффективный путь, так как ресурс ячейки используется не полностью. Нужно писать не char, а int. Тогда младший байт будет перезаписан 65000 раз. Или комбинировать предложенное использование кода Грея с адресацией.
--------------------
Уходя, оставьте свет...
|
|
|
|
|
Mar 21 2007, 11:30
|

За битами по регистрам гоняюсь
  
Группа: Свой
Сообщений: 457
Регистрация: 24-04-06
Из: Таганрог
Пользователь №: 16 446

|
Цитата(mse @ Mar 21 2007, 09:53)  ...Кроме того, у ФРАМ чтение разрушающее. Т.е. его ресурс как ПЗУ сильно ограничен. В отличие от режима ОЗУ или ЕЕПРОМ-флэш. Там наоборот. Почему это чтение с триггеров разрушающее?  И чем отличается режим ПЗУ от ОЗУ?
--------------------
Курсор влево, курсор вправо - считается хакерством. FORMAT C: производится без предупреждения
|
|
|
|
|
Mar 21 2007, 11:59
|
Знающий
   
Группа: Свой
Сообщений: 709
Регистрация: 3-05-05
Пользователь №: 4 693

|
Цитата(Nanobyte @ Mar 21 2007, 11:30)  Почему это чтение с триггеров разрушающее?  И чем отличается режим ПЗУ от ОЗУ? Если бы там были триггера, то она бы была золотая. Проскальзывал документ ихний про кол-во считываний без регенераццыи. Давно, правда. А вот этим и отличается: в ОЗУ пишем-читаем, а из ПЗУ тока читаем.
|
|
|
|
|
Mar 21 2007, 12:30
|

Гуру
     
Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095

|
Цитата(mse @ Mar 21 2007, 10:59)  Если бы там были триггера, то она бы была золотая. Проскальзывал документ ихний про кол-во считываний без регенераццыи. Давно, правда. Давно, потому и забылось, видать. Принцип там такой: при записи электрическим полем сдвигается атом в кристалле ферроэлектрика. При прохождении атомом энергетического барьера возникает импульс тока. В процессе чтения также прикладывают поле. Если зарегистрирован импульс - значит бит был запрограммирован. Но атом в процессе этого чтения уже занял исходное положение, информация разрушена (отсюда название "разрушающее чтение"). Поэтому считанное значение тут же аппаратно записывается обратно. FRAM technology basicsКстати поэтому для этих памятей ограничено (раньше было, во всяком случае) не количество записей, а количество обращений к ячейке. Ибо чтение = стирание + запись.
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
Mar 21 2007, 15:52
|

Частый гость
 
Группа: Свой
Сообщений: 175
Регистрация: 16-03-07
Из: Москва
Пользователь №: 26 228

|
to Сергей Борщ не в тему ветки, но про FRAM, не могли бы Вы прояснить, правильно ли я понимаю следующее: в доке на FM25256 (FRAM от Ramtron-а) написано 10^14 cycles, эти циклы складываются из числа записей х 1 + число чтений х2... При максимальной частоте доступа 15 MHz, если мы будем тупо по кругу читать один и тот же байт (я так понимаю это для FRAM хуже чем писать), выходит много лет, что бы ячейку убить.... т.е. память выходит практически вечная (в разумных пределах)... или я что-то не верно себе мыслю?
--------------------
Быстро, Дёшево, Качественно-выбери любые 2 пункта
|
|
|
|
|
Mar 21 2007, 16:16
|

Гуру
     
Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095

|
Цитата(rumit2000 @ Mar 21 2007, 14:52)  в доке на FM25256 (FRAM от Ramtron-а) написано 10^14 cycles, эти циклы складываются из числа записей х 1 + число чтений х2... Я так понял что число записей*1 + число чтений *1. Цитата(rumit2000 @ Mar 21 2007, 14:52)  При максимальной частоте доступа 15 MHz, если мы будем тупо по кругу читать один и тот же байт (я так понимаю это для FRAM хуже чем писать), выходит много лет, что бы ячейку убить.... т.е. память выходит практически вечная Да, они так изначально и заявляли, что число обращений теоретически ограничено, но реально быстрее сдохнет сама микросхема из-за диффузии материала корпуса в кристалл, чем исчерпается ресурс. И что именно поэтому реального ресурса никто не знает - "убить пока не удалось"  Насчет "читать хуже чем писать" - мне кажется ей что чтение, что запись - то же яйцо только вид сбоку.
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
Mar 21 2007, 16:19
|

Частый гость
 
Группа: Свой
Сообщений: 175
Регистрация: 16-03-07
Из: Москва
Пользователь №: 26 228

|
Цитата(Сергей Борщ @ Mar 21 2007, 16:16)  Я так понял что число записей*1 + число чтений *1. Да, они так изначально и заявляли, что число обращений теоретически ограничено, но реально быстрее сдохнет сама микросхема из-за диффузии материала корпуса в кристалл, чем исчерпается ресурс. И что именно поэтому реального ресурса никто не знает - "убить пока не удалось"  Спасибо, а то прочитав про FRAM испугался, что заложился на неё в серии...
--------------------
Быстро, Дёшево, Качественно-выбери любые 2 пункта
|
|
|
|
|
Mar 21 2007, 16:22
|
Частый гость
 
Группа: Новичок
Сообщений: 173
Регистрация: 3-09-04
Из: Moscow
Пользователь №: 595

|
rumit2000 В ДШ к последним FRAM-ным м/сх указывается неограниченный срок (то есть, время истощения ресурса при непрерывном чтении превышает время хранения данных при отключенном питании). Однако с нетерпением ждём от mse новостей из интимного места техподдержки (терморектальный криптоанализ, видимо, полезная вещь). Но вот только ходят слухи, что главный бич FRAM-ок - это нестабильность в общем полупроводниковом смысле (от питания/температуры). Любопытно было бы послушать "пострадавших".
Сергей Борщ Почему при использовании кода Грея будет равномерный износ ячеек? Мне кажется, это не так, потому что в коде Грея младшие биты меняются гораздо чаще старших, в этом он ничем не отличается от двоичного кода. Это легко проверить, вспомнив формулу перевода двоичного кода в код Грея (там просто XOR соседних битов). Код Грея не даёт других преимуществ кроме "атомарности" операции, что само по себе часто бывает полезным.
Сообщение отредактировал CD_Eater - Mar 21 2007, 16:23
|
|
|
|
|
Mar 21 2007, 16:29
|

Частый гость
 
Группа: Свой
Сообщений: 175
Регистрация: 16-03-07
Из: Москва
Пользователь №: 26 228

|
Цитата(CD_Eater @ Mar 21 2007, 16:22)  Но вот только ходят слухи, что главный бич FRAM-ок - это нестабильность в общем полупроводниковом смысле (от питания/температуры). Любопытно было бы послушать "пострадавших". скоро будет год как в серии (в том числе в уличных исполнениях) работает... вроде проблем не было "тьфу-тьфу-тьфу..." Хотя конечно год совершенно не показатель... Зато вот атмеловская память AT25256 побилась в ходе тестов..... при обещаных 100.000, чесно выдержала около 250.000 циклов записи а потом благополучно перестала воспринимать запись в ячейку...
--------------------
Быстро, Дёшево, Качественно-выбери любые 2 пункта
|
|
|
|
|
Mar 21 2007, 17:01
|

Йа моск ;)
     
Группа: Модераторы
Сообщений: 4 345
Регистрация: 7-07-05
Из: Kharkiv-city
Пользователь №: 6 610

|
Цитата(CD_Eater @ Mar 21 2007, 15:22)  Почему при использовании кода Грея будет равномерный износ ячеек? Мне кажется, это не так, потому что в коде Грея младшие биты меняются гораздо чаще старших, в этом он ничем не отличается от двоичного кода. Это легко проверить, вспомнив формулу перевода двоичного кода в код Грея (там просто XOR соседних битов). При изменении на +-1 меняется только ОДИН бит, значит все будут равномерно изменяться Цитата Код Грея не даёт других преимуществ кроме "атомарности" операции, что само по себе часто бывает полезным. см. выше
--------------------
"Практика выше (теоретического) познания, ибо она имеет не только достоинство всеобщности, но и непосредственной действительности." - В.И. Ленин
|
|
|
|
|
Mar 21 2007, 18:26
|

Гуру
     
Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095

|
Цитата(CD_Eater @ Mar 21 2007, 16:33)  Rst7, Вы не правы. Байт, отвечающий за младший биты счётчика, будет перезаписываться каждое второе приращение, а старший бит счётчика изменится только один раз за весь диапазон ! Да, справился с Гуглем, признаю, что был не прав. Получается, преимущество только одно - удалась запись или не успела закончиться при снятии питания - счетчик не порушится а лишь успеет/не успеет увеличить значение. А перезапись на каждое второе приращение счетчика - уже вдвое увеличивает ресурс, вот
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
Mar 21 2007, 19:12
|
Гуру
     
Группа: Свой
Сообщений: 2 246
Регистрация: 17-03-05
Из: Украина, Киев
Пользователь №: 3 446

|
Цитата Дык вроде бы питание не снимается, а только в powerdown контроллер падает. Уже переписал все так, что в данном конкретном приложении удалось обойти эту ситуацию. Но есть другие, где запоминание байта (иногда и бита хватает) будет важно. Например, питание (возможно ошибочно) было выключено во время нахождения в powerdown. Иногда полезно вести статистику возникновения ситуаций в эксплуатации, интенсивность эксплуатации... да мало что еще...
--------------------
Живи днем так, чтобы ночью ты спал спокойно.
|
|
|
|
|
Mar 21 2007, 21:56
|

Участник

Группа: Участник
Сообщений: 58
Регистрация: 28-11-05
Пользователь №: 11 495

|
Цитата(defunct @ Mar 21 2007, 18:19)  Если записи одинакового формата. То счетчик можно хранить прямо внутри записи. При старте последовательно вычитывать все записи, найти запись с макс счетчиком и продолжать записывать со сл. места, инкрементируя счетчик естессно. когда дойдем до 255 (или 65535 - это вряд-ли для встроенного EEPROM) и переполнимся - как писать/искать будем?
|
|
|
|
|
Mar 21 2007, 22:55
|
Местный
  
Группа: Участник
Сообщений: 358
Регистрация: 29-05-05
Пользователь №: 5 526

|
если сделать кольцевои счетчик из 256 баит то число перезаписеи и растет 256 раз. если из 512 баит то получится ок. 50 млн. циклов. некоторые EEPROM ( и все FLASH) имеют запиь без стирания, там можно атомарно биты писать, каждыи баит при том имеет 9 состоянии : FF,FE,FC,F8,F0,80,40,20,10,00. я сделал таким образом счетчик в FLASH е , 125 баит как колцевои счетчик ( мах число = 125 x8= 1000) , а переполнение , т.е. тысячи считал в оставшихся 3 баитах. получилось счетчик, где происходить 1 стирние на 1000 единиц .учитывая ресурс Flash 100K , общии износь будет на 100млн. но не сложно удлинить кольцо 2 ^ N раз
|
|
|
|
|
Mar 22 2007, 09:55
|
    
Группа: Свой
Сообщений: 1 928
Регистрация: 11-07-06
Пользователь №: 18 731

|
Цитата(smk @ Mar 21 2007, 19:12)  Но есть другие, где запоминание байта (иногда и бита хватает) будет важно. Например, питание (возможно ошибочно) было выключено во время нахождения в powerdown. Иногда полезно вести статистику возникновения ситуаций в эксплуатации, интенсивность эксплуатации... да мало что еще... При мониторинге событий обычно интересны не только сами события, но и время их возникновения. Для мониторинга питания есть специально обученные логгеры у DallasSemi. По любому для этих целей удобнее удобнее использовать что-нибудь с более быстрым циклом записи, чем у ЕЕПРОМ. А в качестве примера использования кольцевого буфера в EEPROM - те же одометры в машинках. В VW'ах, например, пройденный путь пишется в 3 байта, буфер или 24, или 48 байт (не помню, давно ковырял), дискретность записи (LSB) 100 м. Несложно подсчитать, что VW не расчитаны на пробег более 1677721 км  Цитата(proba @ Mar 21 2007, 22:55)  если сделать кольцевои счетчик из 256 баит то число перезаписеи и растет 256 раз. если из 512 баит то получится ок. 50 млн. циклов. некоторые EEPROM ( и все FLASH) имеют запиь без стирания, там можно атомарно биты писать, каждыи баит при том имеет 9 состоянии : FF,FE,FC,F8,F0,80,40,20,10,00. А можно ссылочку на pdf таких занятных EEPROM и всех FLASH, которые умеют писАть без (скрытого) стирания, да еще и по-битово?
|
|
|
|
|
Mar 22 2007, 11:10
|
Гуру
     
Группа: Свой
Сообщений: 2 246
Регистрация: 17-03-05
Из: Украина, Киев
Пользователь №: 3 446

|
Цитата Несложно подсчитать, что VW не расчитаны на пробег более 1677721 км А больше и не надо. Вообще-то и половины более чем достаточно. Я имел ввиду ведение статистики наступления событий. Например производим ежесекундный мониторинг какого-то события. качество события может характеризоваться тремя значениями: не произошло; произошло, но мало; произошло полностью. Ну вот и пишем статистику, а при попадании изделия на ремонт или по снятии с эксплуатации читаем статистику и делаем выводы. Полезно с позиций оценки ресурса датчиков событий, например...
--------------------
Живи днем так, чтобы ночью ты спал спокойно.
|
|
|
|
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|