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

 
 
> Обновление ПО с удаленного сервера., Как правильнее разделить ПО и самописный bootloader
Atridies
сообщение Dec 18 2013, 20:10
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 445
Регистрация: 7-02-05
Из: Зеленоград
Пользователь №: 2 468



Доброго времени суток, армоводы!

Есть железка на Cortex-M0, в которой хотелось бы иметь возможность обновления ПО с фирменного FTP-сервера. Все части загрузчика: скачивание файла в SPI Flash, собственно запись в MCU Flash - готово. Но пока не могу всё это взаимоувязать, чтобы получился надежный загрузчик (чтобы из-за провалов питания и кривых рук персонала - не умирал насовсем).

На msp430 делал следующим образом (обновление по rs485): все обработчики прерывания - были расположены по жестким адресам и обслуживали основное ПО. Сам загрузчик не использовал вообще прерывания - вся обработка была через контроль соответствующих флагов (кроме reset-а). Соответственно как бы чего не происходило - всегда после перевключения стартовал загрузчик и в этот момент его можно было перехватить (нужным пакетом на rs485) и обновить ПО. Если перехвата нет - уходим в основное ПО.

Ровно сделать также на кортексе - не получается: почему-то uart-ы периодически подвисают.

Вообще мне видится несколько решений задачи загрузчика:
1. Сделать работу загрузчика чисто по флагам и оставить прерывания для основного ПО. Хорошо, но пока - не получается.
2. Сделать загрузчик как часть основной программы, но тогда - все вызовы между ними надо будет делать по жестким адресам. Муторно писАть и отлаживать.
3. Сделать работу загрузчика по прерываниям, но внутри сделать ветвление: в функцию загрузчика или в функцию основного ПО. Убиваем скорость реакции. Не айс.


Вопросы, которые хотелось бы прояснить для себя:
1. Какой вариант загрузчика все-таки лучше ?
2. Нет ли каких-то подводных камней при работе с флагами прерывания, но без самих прерываний ? Возможно ли это в принципе на кортексе ?

Заранее спасибо.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
kolobok0
сообщение Dec 18 2013, 21:14
Сообщение #2


практикующий тех. волшебник
*****

Группа: Участник
Сообщений: 1 190
Регистрация: 9-09-05
Пользователь №: 8 417



Цитата(Atridies @ Dec 19 2013, 00:10) *
..хотелось бы ..обновления ПО..чтобы получился надежный загрузчик..
1. Какой вариант загрузчика все-таки лучше ?..


сейчас для себя решил следующее:
1) заливка принимаеся и сохраняется в штатном режиме работы, как данные. заливку пишем во флэш как новую, следующую версию.
сама версия модульная. между модулями позднее связывание (на старте камня). ссылки могут быть
обязательными или не обязательными, с указанием минимальной требуемой версии модуля на который ссылается.
2) после апдэйта уходим на ресет. после ресета и проверки работоспособности ядра, происходит поиск свежей комбинации софта:
фулл + дифференциальные + инкрементальные версии модулей.
3) при записи во флэш определённого обёма версий - мы можем смело прореживать версии (инкрементальные между дифами), и удалять
старые не используемые версии.


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

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


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

Сообщение отредактировал kolobok0 - Dec 18 2013, 21:16
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- Atridies   Обновление ПО с удаленного сервера.   Dec 18 2013, 20:10
- - A. Fig Lee   А там что, NVIC_SetVectorTable() не присутствует? ...   Dec 18 2013, 20:37
|- - KRS   Цитата(A. Fig Lee @ Dec 19 2013, 00:37) А...   Dec 18 2013, 20:58
|- - jcxz   Цитата(A. Fig Lee @ Dec 19 2013, 02:37) У...   Dec 19 2013, 02:50
||- - A. Fig Lee   Цитата(jcxz @ Dec 18 2013, 21:50) При про...   Dec 19 2013, 03:08
||- - demiurg_spb   Цитата(jcxz @ Dec 19 2013, 06:50) При про...   Dec 19 2013, 06:33
||- - scifi   Цитата(demiurg_spb @ Dec 19 2013, 10:33) ...   Dec 19 2013, 06:49
|- - mantech   Цитата(A. Fig Lee @ Dec 19 2013, 00:37) У...   Dec 19 2013, 09:22
|- - scifi   Цитата(mantech @ Dec 19 2013, 13:22) Можн...   Dec 19 2013, 11:05
||- - mempfis_   Цитата(scifi @ Dec 19 2013, 15:05) Не все...   Dec 19 2013, 11:51
|- - A. Fig Lee   Цитата(mantech @ Dec 19 2013, 04:22) Можн...   Dec 19 2013, 11:55
|- - mantech   Цитата(A. Fig Lee @ Dec 19 2013, 15:55) В...   Dec 19 2013, 16:37
- - Golikov A.   надо 2 загрузчика делать 1. примитивный, на 1 путь...   Dec 19 2013, 21:18
|- - mantech   Цитата(Golikov A. @ Dec 20 2013, 01:18) н...   Dec 20 2013, 06:10
- - Atridies   Спасибо за ответы! Проблема несколько модифиц...   Jan 4 2014, 23:53
- - Atridies   Проблема решена. "указатель Reset-а - на 0x0...   Jan 6 2014, 21:40
- - alx125   Цитата(Atridies @ Jan 7 2014, 01:40) Проб...   Jan 6 2014, 22:29


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

 


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


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