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

 
 
 
Reply to this topicStart new topic
> Хэш-сумма прошивки изменилась!
Ashurbanipal
сообщение Dec 24 2014, 09:35
Сообщение #1





Группа: Новичок
Сообщений: 1
Регистрация: 24-12-14
Пользователь №: 84 272



Приветствую уважаемых участников форума!

Помогите, пожалуйста, решить такую проблему: я прошиваю микроконтроллер ATmega48PA с помощью программатора AVR910, через программу CodeVisionAVR.
Ставлю галочки на фьюзах BODLEVEL1=0 и EESAVE=0. Лок биты не программирую. Также ставлю галочки на Check Erasure и Verify.
Далее стираю чип и прошиваю МК своей прошивкой. До прошивки я вычислил ее хэш-сумму (CRC32). Если сразу после прошивки я читаю флеш-память, то хэш-сумма совпадает.
Если я даю устройству некоторое время поработать и затем считываю прошивку, то обнаруживаю, что она изменилась. Никак не могу взять в толк в чем дело.
Функции самопрограммирования я не использовал (хотя код писал на Си, возможно компилятор самовольничает).
Есть работа с EEPROM памятью - но ведь это не должно повлиять на флеш-память.

Подскажите в чем проблема и как с этим бороться?
Go to the top of the page
 
+Quote Post
megajohn
сообщение Dec 24 2014, 09:44
Сообщение #2


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

Группа: Свой
Сообщений: 1 080
Регистрация: 16-11-04
Из: СПб
Пользователь №: 1 143



проверьте через JTAG или SPI что прошивка реально изменилась. а то сомнения


--------------------
Марс - единственная планета, полностью населенная роботами (около 7 штук).
Go to the top of the page
 
+Quote Post
Xenia
сообщение Dec 24 2014, 09:48
Сообщение #3


Гуру
******

Группа: Модератор FTP
Сообщений: 4 479
Регистрация: 20-02-08
Из: Москва
Пользователь №: 35 237



Цитата(Ashurbanipal @ Dec 24 2014, 12:35) *
До прошивки я вычислил ее хэш-сумму (CRC32). Если сразу после прошивки я читаю флеш-память, то хэш-сумма совпадает.
Если я даю устройству некоторое время поработать и затем считываю прошивку, то обнаруживаю, что она изменилась. Никак не могу взять в толк в чем дело.


Вы не хэш-суммы сравнивайте, а сравните обе прошивки! Побайтно, а bin-формате. Ту, которую прошивали, с той, которая якобы испортилась. Тогда и узнаете, в каком месте происходит эта порча.

Кто же, кроме вас, может это проверить? Да еще и заочно. Только вы сами!
Go to the top of the page
 
+Quote Post
alexeyv
сообщение Jan 28 2015, 05:15
Сообщение #4


Местный
***

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



Как конкретно вычисляете хэш-сумму?
Как вариант, перед прошивкой вычисляется хэш-сумма только Вашей программы, а после - всей флэш-памяти (4K).
Или при вычислении хэш-суммы также затрагивается память EEPROM.
Как сказали выше сравнивайте бинарные образы
Go to the top of the page
 
+Quote Post
Кондратьев Андре...
сообщение Jan 29 2015, 13:00
Сообщение #5





Группа: Участник
Сообщений: 13
Регистрация: 23-10-12
Пользователь №: 74 057



Цитата(alexeyv @ Jan 28 2015, 09:15) *
Как конкретно вычисляете хэш-сумму?
Как вариант, перед прошивкой вычисляется хэш-сумма только Вашей программы, а после - всей флэш-памяти (4K).

так и есть

Сообщение отредактировал Кондратьев Андрей - Jan 29 2015, 13:02
Go to the top of the page
 
+Quote Post
pavel-pervomaysk
сообщение Feb 11 2015, 21:42
Сообщение #6


Местный
***

Группа: Свой
Сообщений: 253
Регистрация: 28-12-07
Из: Украина г. Первомайск
Пользователь №: 33 716



С каких это пор для контрольной суммы начали хэш применять?
Может CRC?
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 18th July 2025 - 08:57
Рейтинг@Mail.ru


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