Урок 14
|
Предыдущий урок | Ардуино - главная | Следуюший урок |
В уроке рассказывается, как работать с внутренним EEPROM платы Ардуино, о контроле целостности данных при хранении и передаче.
Внутреннее EEPROM в системе Ардуино.
EEPROM это энергонезависимая память. Расшифровывается как электрически стираемое программируемое постоянное запоминающее устройство. Применяется для хранения данных, которые должны быть сохранены при выключении питания.
Платы Ардуино имеют EEPROM разных объемов в зависимости от типа используемого микроконтроллера.
Микроконтроллер | Объем внутреннего EEPROM |
ATmega328 | 1024 байт |
ATmega8, ATmega168 | 512 байт |
ATmega1280, ATmega2560 | 4096 байт |
Такого объема памяти вполне достаточно для хранения режимов, технологических параметров, коэффициентов и т.п.
Библиотека EEPROM.
Для работы с энергонезависимой памятью в Ардуино есть библиотека EEPROM. Она имеет две функции для записи и чтении байта в EEPROM.
Программа проверки записи в EEPROM.
Давайте напишем простую программу проверки работы EEPROM. Программа должна записывать до 16ти символов, принятых с последовательного порта и в цикле выводить 16 символов, считанных из EEPROM. С помощью монитора порта Arduino IDE мы сможем записывать данные в EEPROM и контролировать содержимое энергонезависимой памяти.
// проверка работы EEPROM
#include <EEPROM.h>
int i, d;
void setup() {
Serial.begin(9600); //- инициализируем порт, скорость 9600
}
void loop() {
//- чтение EEPROM и вывод 16 данных в последовательный порт
Serial.println();
Serial.print("EEPROM= ");
i= 0; while(i < 16) {
Serial.print((char)EEPROM.read(i));
i++;
}
//- проверка есть ли данные для записи
if ( Serial.available() != 0 ) {
delay(50); //- ожидание окончания приема данных
//- запись в EEPROM
i= 0; while(i < 20) {
d= Serial.read();
if (d == -1) d= ' '; //- если символы закончились, заполнение пробелами
EEPROM.write(i, (byte)d); //- запись EEPROM
i++;
}
}
delay(500);
}
Загружаем программу в плату Ардуино, проверяем. Открываем монитор порта, посылаем данные на плату:”Проверка EEPROM”.
Данные записываются в EEPROM и теперь в цикле выводятся в окне монитора. Если мы отключим плату от компьютера и затем снова подключим, то данные будут продолжать посылаться на компьютер. Они сохранены в энергонезависимой памяти и при выключении питания платы не меняются.
Контроль целостности данных.
В EEPROM обычно хранят данные абсолютно необходимые для работы программы. Например, если вы делаете регулятор температуры, то это может быть : заданная температура, коэффициенты регуляторов, параметры защитных функций и т.п. Представьте, что эти параметры будут испорчены, а регулятор продолжит работу. Он может включить нагревательный элемент на полную мощность и выставить недопустимо высокую температуру. При неправильных коэффициентах регулятор может “пойти в разнос”. Перестанут работать защитные функции. Неприятности будут большие.
А ведь ситуация, когда в EEPROM могут оказаться недостоверные данные вполне реальная.
Поэтому крайне важно быть уверенными, что в EEPROM хранятся достоверные данные. В случае, если они ошибочны, программа должна принять определенные действия. Это может быть:
Целостность данных это показатель, того что данные не были изменены при хранении, передаче, отображении и т.п. Целостность данных может проверяться в любой ситуации, потенциально опасной для разрушения данных. Обычно контроль достоверности данных производят:
Для контроля целостности к блоку данных добавляется контрольный код. Этот код рассчитывается по определенному алгоритму при записи данных. При проверке данных код заново вычисляется и сравнивается с кодом, сформированным при записи. Если коды не совпадают – данные ошибочны.
Алгоритм расчета контрольного кода определяет вероятность определения ошибки данных. Существует большое число алгоритмов формирования контрольных кодов: циклические коды, различные функции хэширования. Но самым простым способом вычисления контрольного кода является контрольная сумма.
Просто делается математическая сумма всех байтов блока данных. Такой алгоритм требует минимума ресурсов для реализации, и в то же время позволяет с достаточно высокой вероятностью определить ошибочные данные в случае небольших объемов информации. Контрольная сумма может быть разной разрядности. В минимальном варианте это один байт. В этом случае происходит переполнение результата суммы, что уменьшает вероятность обнаружения ошибок.
Я всегда к вычисленной контрольной сумме применяю операцию “исключающее ИЛИ” с кодом подобным E5h. Это позволяет исключить весьма вероятную ситуацию, когда все данные равны 0. Сумма 0 равна 0. Поэтому если блок данных будет ошибочно обнулен (а это бывает), то простая сумма не вычислит эту ошибку. А когда контрольная сумма для всех 0 равна E5h, то ошибка будет выявлена.
Давайте добавим в предыдущую программу контроль целостности данных.
// проверка работы EEPROM
#include <EEPROM.h>
int i, d;
byte sum; //- контрольная сумма
void setup() {
Serial.begin(9600); //- инициализируем порт, скорость 9600
}
void loop() {
//- вычисление контрольной суммы
sum= 0;
i= 0; while(i < 16) {
sum += EEPROM.read(i);
i++;
}
//- проверка контрольной суммы
if ( (sum^0xe5) == EEPROM.read(i)) {
//- контрольна сумма правильная
//- чтение EEPROM и вывод 16 данных в последовательный порт
Serial.println();
Serial.print("EEPROM= ");
i= 0; while(i < 16) {
Serial.print((char)EEPROM.read(i));
i++;
}
}
else {
//- контрольная сумма неправильная
Serial.println();
Serial.print("EEPROM= data error");
}
//- проверка есть ли данные для записи
if ( Serial.available() != 0 ) {
delay(50); //- ожидание окончания приема данных
//- запись в EEPROM
sum= 0;
i= 0; while(i < 16) {
d= Serial.read();
if (d == -1) d= ' '; //- если символы закончились, заполнение пробелами
EEPROM.write(i, (byte)d); //- запись EEPROM
sum += (byte)d; //- вычисление контрольной суммы
i++;
}
EEPROM.write(i, sum ^ 0xe5); //- запись контрольной суммы
}
delay(500);
}
Отмечу только, что программа принимает не 16, а 14 символов, т.к. монитор порта добавляет к каждой строке символы переноса строки \r и \n.
Загрузим программу и запустим монитор.
В окне бегут сообщения об ошибке данных. Мы еще не загрузили в EEPROM никаких данных, и алгоритм распознает эту ситуацию. Пошлем строку, например, ”проверка”. Теперь в окне отображаются данные из EEPROM.
Таким же образом можно защищать целостность данных при передаче по последовательному порту. Любая импульсная помеха может исказить сигнал в кабеле связи и вызвать ошибку данных. Конечно, программа приема данных на компьютере должна поддерживать протокол с контрольной суммой. Монитор порта Arduino IDE этой функции не имеет.