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

 
 
> stm32 bootloader, разьясните новичку
batisto4ka
сообщение Apr 18 2012, 11:40
Сообщение #1


Частый гость
**

Группа: Участник
Сообщений: 89
Регистрация: 3-01-11
Пользователь №: 61 997



Помогите, пожалуйста, поставить точки над i. Насколько мне понятно, в stm32 bootloader может быть использован вместо программатора. Для того, чтоб залить прошивку в контроллер, необходимо подсоединить плату с МК к компу через ком порт( по USART1 МК), подать на вход бут0 1, на бут 1 -0, загрузить бинарник, используя специальную утилиту Flash Loader Demonstrator.Это весь алгоритм?
Второй вопрос. Часто встречается в сети такое выражение, как "написать загрузчик". Что имеется в виду под этим? В каком случае нужно писать свой загрузчик и как это сделать?

Сообщение отредактировал batisto4ka - Apr 18 2012, 11:41
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
lead_seller
сообщение Apr 18 2012, 20:22
Сообщение #2


Участник
*

Группа: Участник
Сообщений: 53
Регистрация: 27-10-08
Пользователь №: 41 225



Собственно ответы:
1. да

2. нет. Заводской бутлоадер активируется только подачей соответствующих сигналов на соответствующие ноги. Если Вы хотите написать собственный бутлоадер, то должны будете полностью реализовать всю логику прошивки контроллера - получение прошивки с ПК (или иного носителя прошивки), временное хранение в контроллере, верификацию этой прошивки (проверки правильности полученных кодов), запись полученной прошивки в Flash-память контроллера, передачи управления залитой прошивке. По поводу логики работы бутлоадеров можете почитать апнот от STMй AN2557 (http://www.st.com/internet/com/TECHNICAL_RESOURCES/TECHNICAL_LITERATURE/APPLICATION_NOTE/CD00161640.pdf). В нем описывается логика работы бутлоадера с передачей прошивки по USART (не путать с заводским).

3. МК будет ожидать прошивку, пользовательская программа выполнятся не будет. Ноги BOOT0 и BOOT1 определяют из какой области памяти будет грузится контроллер. Подробнее об этих ногах расписано в AN2606 (http://www.st.com/internet/com/TECHNICAL_RESOURCES/TECHNICAL_LITERATURE/APPLICATION_NOTE/CD00167594.pdf)

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

Сообщение отредактировал lead_seller - Apr 18 2012, 20:27
Go to the top of the page
 
+Quote Post
batisto4ka
сообщение Apr 19 2012, 05:44
Сообщение #3


Частый гость
**

Группа: Участник
Сообщений: 89
Регистрация: 3-01-11
Пользователь №: 61 997



Цитата(lead_seller @ Apr 19 2012, 00:22) *
А от себя добавлю (строго мое мнение, без намерения кого-либо оскорбить), написание бутлоадеров не самая тривиальная задача, которая требует достаточно хорошего знания периферии микроконтроллера, ядра Cortex-M3, и особенностей работы компиляторов.



Всем спасибо за советы и ответы. Мне приходилось как-то писать свой компилятор и интерпретатор на базе pic24, писать/читать флеш-память вроде как умеем, мелкие улититки по передачи через ком порт для ПК писать приходилось. В проекте, дя которого нужно написать свой бутлоадер, как раз такая ситуация " либо там где нет пригодного коммуникационного интерфейса в заводском загрузчике", то есть сам юсарт1 занят под другие нужды (в проекте используется камень stm32f103vet).

То есть вроде как все махинации с флешкой понятны, но, поскольку еще не начинала "колупать" остаются вопросы:
1. Не понятно, зачем пеерносить таблицу векторов прерываний.
2. Сейчас пок а вголове созрела идея такая: первую страницу ПЗУ использовать для хранения своего загрузчика. Ее защитить от записи. В эту область будет попадать программный счетчик либо при старте системы, либо когда нужно будет перепрошивать МК. Условие попадание будет проверяться по какому-то флагу. Если это обычный режим работы, то бутлоадер отправляет программный счетчик на начало программы. А программа сама будет записываться со второй страницы. Таким образом, сам загрузчик может быть стерт только при перепрошивке с помощью программатора, либо иным способом, предусморенным программой загрузчика. И тогда, если теоретически, так сделать можно, то остается вопрос, как с помощью стандартной улититы (стмовского флэш лоадер демонсттратор) зашить бинарник, как понять сигналы утилиты и т.д. Это думаю найти в AN2557, который посоветовал load_seller.

Go to the top of the page
 
+Quote Post
Danis
сообщение Apr 19 2012, 07:04
Сообщение #4


Twilight Zone
***

Группа: Свой
Сообщений: 454
Регистрация: 17-02-09
Из: Челябинск
Пользователь №: 44 990



Цитата(batisto4ka @ Apr 19 2012, 08:44) *
1. Не понятно, зачем пеерносить таблицу векторов прерываний.


Вероятно, можно и не переносить, но мне пока в голову не приходит, как организовать тогда взаимодействие загрузчика и основной программы.
У меня два проекта отдельных:
Первый – загрузчик, начинается с начала flash микроконтроллера (0x08000000), таблица векторов с адреса 0х08000004, соответственно свои обработчики прерываний, которые к загружаемой прошивке не имеют никакого отношения.
Второй – прошивка (firmware), готовиться и отлаживается отдельно от загрузчика (так же начиная с адреса 0x08000000), после ее разработки и отладки, переносите таблицу векторов (ну соответственно и адрес начала программы во flash) на несколько килобайт вперед (в зависимости от размере загрузчика и размера страницы памяти микроконтроллера), компилируйте с выходом простого «бинарника».
Так Вы гарантируете /перенос таблицы и начало программы/ отсутствие наложения проектов при их объединении в один «кусок». Объединение в один проект очень просто, зашиваете загрузчик, зашиваете прошивку, по средствам своего загрузчика, считываете всю память.
Так сделано у меня, и я не выдаю это за лучший вариант организации.



Цитата(batisto4ka @ Apr 19 2012, 09:49) *
Правильно ли я понимаю, что под переносом таблицы векторов понимается копирование . То есть старая таблица векторов прерываний рапсоложенная по адресу 0x0000_0000 согласно RM0008 Table 63. Vector table for other STM32F10xxx devices остается на том же месте, и еще дополнительно копируется для своего бутлоадера? Как тогда контроллер при срабатывании прерываний будет понимать,какая обработчик ему нужно вызвать? и как описываютсся обработчики прерываний, перенесеннной таблицы веткоров прерываний?


Нет.
NVIC - Контроллер вложенных векторизированных прерываний STM32, позволяет гибко располагать таблицу во флэш или ОЗУ.
Как раз при его конфигурации и указывается адрес начала этой таблицы.

Цитата(batisto4ka @ Apr 19 2012, 09:49) *
и как описываютсся обработчики прерываний, перенесеннной таблицы веткоров прерываний?
прерываний?

Обработчики прерываний описываютсся одинаково везде.


--------------------
Magic Friend
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- batisto4ka   stm32 bootloader, разьясните новичку   Apr 18 2012, 11:40
- - lead_seller   Бутлоадер (термин "загрузчик" имеет неск...   Apr 18 2012, 11:52
- - KnightIgor   Цитата(batisto4ka @ Apr 18 2012, 12:40) П...   Apr 18 2012, 11:53
- - batisto4ka   Спасибо всем, кто откликнулся. Подскажите, где мож...   Apr 18 2012, 11:57
|- - nicks80   Цитата(batisto4ka @ Apr 18 2012, 15:57) С...   Apr 18 2012, 13:12
- - batisto4ka   И еще хотелось бы уточнить, есть отладочная плата ...   Apr 18 2012, 13:16
|- - scifi   Цитата(lead_seller @ Apr 19 2012, 00:22) ...   Apr 18 2012, 20:45
||- - Danis   Цитата(scifi @ Apr 19 2012, 00:45) +1. Пл...   Apr 18 2012, 23:38
|- - KRS   Цитата(Danis @ Apr 19 2012, 10:57) таблиц...   Apr 19 2012, 07:07
- - lead_seller   Вектора прерываний переносятся потому, что и бутло...   Apr 19 2012, 06:41
|- - jcxz   Цитата(lead_seller @ Apr 19 2012, 12:41) ...   Apr 19 2012, 07:22
||- - batisto4ka   Цитата(jcxz @ Apr 19 2012, 11:22) 1. неиз...   Apr 19 2012, 07:26
|||- - Danis   Цитата(batisto4ka @ Apr 19 2012, 10:26) Н...   Apr 19 2012, 07:31
|||- - jcxz   Цитата(batisto4ka @ Apr 19 2012, 13:26) 1...   Apr 19 2012, 07:34
||- - Danis   Цитата(jcxz @ Apr 19 2012, 10:22) Неправд...   Apr 19 2012, 07:27
||- - Lotor   Цитата(jcxz @ Apr 19 2012, 11:22) Вот так...   Apr 26 2012, 07:05
||- - jcxz   Конечно перед заливкой, надо провести полные испыт...   Apr 26 2012, 08:07
||- - Lotor   Цитата(jcxz @ Apr 26 2012, 12:07) Ваши пр...   Apr 26 2012, 12:08
||- - jcxz   Цитата(Lotor @ Apr 26 2012, 18:08) По-мое...   Apr 26 2012, 13:59
||- - Lotor   Цитата(jcxz @ Apr 26 2012, 17:59) Таким о...   Apr 27 2012, 04:23
||- - jcxz   Цитата(Lotor @ Apr 27 2012, 10:23) Абсурд...   Apr 27 2012, 05:01
||- - Lotor   Цитата(jcxz @ Apr 27 2012, 09:01) Или Вы ...   Apr 27 2012, 05:17
||- - jcxz   Цитата(Lotor @ Apr 27 2012, 11:17) Зачем ...   Apr 27 2012, 05:33
||- - Lotor   Цитата(jcxz @ Apr 27 2012, 09:33) Если вс...   Apr 27 2012, 05:59
|- - Marto   Цитата(lead_seller @ Apr 19 2012, 12:41) ...   Apr 19 2012, 07:36
- - batisto4ka   Правильно ли я понимаю, что под переносом таблицы ...   Apr 19 2012, 06:49
- - lead_seller   Делаю примерно так же, но помимо текущей версии ПО...   Apr 19 2012, 07:27
|- - jcxz   Цитата(lead_seller @ Apr 19 2012, 13:27) ...   Apr 19 2012, 07:41
- - lead_seller   При каждом старте бутлоадер проверяет целостность ...   Apr 19 2012, 07:44
|- - jcxz   Цитата(lead_seller @ Apr 19 2012, 13:44) ...   Apr 19 2012, 07:48
|- - jcxz   Цитата(lead_seller @ Apr 19 2012, 13:44) ...   Apr 19 2012, 09:06
- - lead_seller   Не спорю. Вообще и при моем алгоритме тоже. Но луч...   Apr 19 2012, 07:56
- - lead_seller   У нас проблемы с настройками связи не возникают. П...   Apr 19 2012, 12:36
- - EugenyAM   Хочу привести несколько рекомендаций, основываясь ...   Apr 19 2012, 18:37
- - batisto4ka   Подскажите, как сделать безусловный переход по адр...   Apr 22 2012, 17:02
|- - scifi   Цитата(batisto4ka @ Apr 22 2012, 21:02) Н...   Apr 22 2012, 18:18
|- - EugenyAM   Цитата(batisto4ka @ Apr 23 2012, 00:02) П...   Apr 23 2012, 03:44
|- - batisto4ka   Цитата(EugenyAM @ Apr 23 2012, 07:44) Отв...   Apr 23 2012, 07:03
||- - EugenyAM   Цитата(batisto4ka @ Apr 23 2012, 14:03) Г...   Apr 23 2012, 09:29
|- - batisto4ka   Цитата(EugenyAM @ Apr 23 2012, 07:44) //У...   Apr 23 2012, 13:34
|- - scifi   Цитата(batisto4ka @ Apr 23 2012, 17:34) ч...   Apr 23 2012, 13:52
||- - batisto4ka   Цитата(scifi @ Apr 23 2012, 17:52) Мне во...   Apr 24 2012, 13:53
||- - scifi   Цитата(batisto4ka @ Apr 24 2012, 17:53) В...   Apr 24 2012, 13:59
||- - batisto4ka   Цитата(scifi @ Apr 24 2012, 17:59) Для эт...   Apr 24 2012, 19:17
|- - EugenyAM   Цитата(batisto4ka @ Apr 23 2012, 20:34) ч...   Apr 23 2012, 19:32
- - k000858   подскажите плиз по переходу из бутлоадера в основн...   Apr 26 2012, 06:12
|- - EugenyAM   Цитата(k000858 @ Apr 26 2012, 13:12) - мо...   Apr 26 2012, 08:31
- - lead_seller   Раздумывал над таким вариантом. Придумал такой вар...   Apr 26 2012, 12:52
- - batisto4ka   Прилагаю свой проект с функцией перехода по адресу...   Apr 26 2012, 13:00
|- - spasbyspas   Цитата(batisto4ka @ Apr 26 2012, 16:00) П...   Apr 26 2012, 17:06
|- - batisto4ka   Цитата(spasbyspas @ Apr 26 2012, 21:06) П...   Apr 27 2012, 06:36
- - batisto4ka   Помогите домучать бутлоадер. Программа бутлоадера...   May 3 2012, 07:59
|- - EugenyAM   Цитата(batisto4ka @ May 3 2012, 13:59) Я ...   May 4 2012, 03:34
|- - batisto4ka   Так все решено. На самом деле в программу, которая...   May 4 2012, 05:37
- - veteq   Вопрос по встроенному загрузчику STM, возможно ли ...   Dec 23 2013, 05:26
|- - demiurg_spb   Цитата(veteq @ Dec 23 2013, 09:26) Тут пи...   Dec 23 2013, 06:45
- - veteq   Спасибо, действительно все заработало. Основное мо...   Dec 23 2013, 10:47


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

 


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


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