|
stm32 bootloader, разьясните новичку |
|
|
|
Apr 18 2012, 11:40
|
Частый гость
 
Группа: Участник
Сообщений: 89
Регистрация: 3-01-11
Пользователь №: 61 997

|
Помогите, пожалуйста, поставить точки над i. Насколько мне понятно, в stm32 bootloader может быть использован вместо программатора. Для того, чтоб залить прошивку в контроллер, необходимо подсоединить плату с МК к компу через ком порт( по USART1 МК), подать на вход бут0 1, на бут 1 -0, загрузить бинарник, используя специальную утилиту Flash Loader Demonstrator.Это весь алгоритм? Второй вопрос. Часто встречается в сети такое выражение, как "написать загрузчик". Что имеется в виду под этим? В каком случае нужно писать свой загрузчик и как это сделать?
Сообщение отредактировал batisto4ka - Apr 18 2012, 11:41
|
|
|
|
|
 |
Ответов
|
Apr 18 2012, 20:22
|
Участник

Группа: Участник
Сообщений: 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
|
|
|
|
|
Apr 19 2012, 05:44
|
Частый гость
 
Группа: Участник
Сообщений: 89
Регистрация: 3-01-11
Пользователь №: 61 997

|
Цитата(lead_seller @ Apr 19 2012, 00:22)  А от себя добавлю (строго мое мнение, без намерения кого-либо оскорбить), написание бутлоадеров не самая тривиальная задача, которая требует достаточно хорошего знания периферии микроконтроллера, ядра Cortex-M3, и особенностей работы компиляторов. Всем спасибо за советы и ответы. Мне приходилось как-то писать свой компилятор и интерпретатор на базе pic24, писать/читать флеш-память вроде как умеем, мелкие улититки по передачи через ком порт для ПК писать приходилось. В проекте, дя которого нужно написать свой бутлоадер, как раз такая ситуация " либо там где нет пригодного коммуникационного интерфейса в заводском загрузчике", то есть сам юсарт1 занят под другие нужды (в проекте используется камень stm32f103vet). То есть вроде как все махинации с флешкой понятны, но, поскольку еще не начинала "колупать" остаются вопросы: 1. Не понятно, зачем пеерносить таблицу векторов прерываний. 2. Сейчас пок а вголове созрела идея такая: первую страницу ПЗУ использовать для хранения своего загрузчика. Ее защитить от записи. В эту область будет попадать программный счетчик либо при старте системы, либо когда нужно будет перепрошивать МК. Условие попадание будет проверяться по какому-то флагу. Если это обычный режим работы, то бутлоадер отправляет программный счетчик на начало программы. А программа сама будет записываться со второй страницы. Таким образом, сам загрузчик может быть стерт только при перепрошивке с помощью программатора, либо иным способом, предусморенным программой загрузчика. И тогда, если теоретически, так сделать можно, то остается вопрос, как с помощью стандартной улититы (стмовского флэш лоадер демонсттратор) зашить бинарник, как понять сигналы утилиты и т.д. Это думаю найти в AN2557, который посоветовал load_seller.
|
|
|
|
|
Apr 19 2012, 07:04
|

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
|
|
|
|
Сообщений в этой теме
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
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|