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

 
 
 
Reply to this topicStart new topic
> Использование Bootloader'а на XMEGA, XMEGA, Bootloader
Brain13
сообщение Apr 11 2010, 21:18
Сообщение #1


Участник
*

Группа: Участник
Сообщений: 65
Регистрация: 28-08-09
Пользователь №: 52 078



Доброго времени суток!

По работе появилась необходимость обновлять прошивку XMEGA16A4(XMEGA32A4) по последовательному каналу, т.к. устройства при изготовлении заливаются компаундом, остается только разъем EIA-485.
Но я с bootloader'ами дела не имел, и плохо понимаю как они работают. Посмотрел AVR1605: XMEGA™ Boot Loader Quick Start
Guide стало понятнее, но ненамного.
Я так понял, что должны быть два проекта: bootloader, и основной программы. Тогда bootloader можно переделать из AVR1605 с поддержкой 485-го и на этом все. Или я ошибаюсь?
Но где-то в проекте надо указать, что это проект bootloader'а, но такого не нашел. Он по идее должен располагаться в 4К Boot области.
AVR1605 заточен под IAR и XMEGA128A1, но мне надо под WinAVR и XMEGA16A4(XMEGA32A4), будет ли он работать? Что докрутить?
Есть ли готовые bootloader'ы с поддержкой XMEGA16A4(XMEGA32A4) и 485-го?

Можете в общем рассказать как прикручивать bootloader?

PS: Извините если подобные темы уже были...
Go to the top of the page
 
+Quote Post
V_G
сообщение Apr 11 2010, 23:03
Сообщение #2


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

Группа: Свой
Сообщений: 1 818
Регистрация: 15-10-09
Из: Владивосток
Пользователь №: 52 955



Цитата(Brain13 @ Apr 12 2010, 08:33) *
Есть ли готовые bootloader'ы с поддержкой XMEGA16A4(XMEGA32A4) и 485-го?
Можете в общем рассказать как прикручивать bootloader?

1. Ну, может, у кого-то и есть, но точно не на официальном Атмеловском сайте
2. Я пишу на ассемблере, так что там просто пишешь ".ORG BOOTSTART" и далее размещаешь текст бутлоадера, а фьюзы программируешь на загрузку с Bootloader Reset.
3. Bootloader с поддержкой стандартной атмеловской утилиты AVRProg для 485 написать сложновато, наверное: в системе команд адресная инфо не предусмотрена, да и эхо от посылки будет сбивать AVRProg. Так что и со стороны компа свою поддержку бутлоадера писать придется.
Go to the top of the page
 
+Quote Post
Brain13
сообщение Apr 11 2010, 23:50
Сообщение #3


Участник
*

Группа: Участник
Сообщений: 65
Регистрация: 28-08-09
Пользователь №: 52 078



Цитата(V_G @ Apr 12 2010, 03:18) *
1. Ну, может, у кого-то и есть, но точно не на официальном Атмеловском сайте
2. Я пишу на ассемблере, так что там просто пишешь ".ORG BOOTSTART" и далее размещаешь текст бутлоадера, а фьюзы программируешь на загрузку с Bootloader Reset.
3. Bootloader с поддержкой стандартной атмеловской утилиты AVRProg для 485 написать сложновато, наверное: в системе команд адресная инфо не предусмотрена, да и эхо от посылки будет сбивать AVRProg. Так что и со стороны компа свою поддержку бутлоадера писать придется.

1. Есть на Атмеловском сайте подобное: AVR1605 и файлы к ним.
2. В том то и дело, что надо на С.
3. Поддержка 485 заключается в том, что определенную ногу надо поднять/опустить при передаче. Эха нет. Устройство на время программирования будут отключать от сети. Со стороны компа используем ту же прогу(я присмотрел AVROSP), потом на железяку 232-485. Просто работать только в полудуплексном режиме, но это не проблема, все загрузчики так и работают.

Управления ногой привинтить думаю не проблема. Думаю, что вся проблема заключается в следующем вопросе:
Как настроить проект AVRStudio+WinAVR, для написания bootloader'a.
Имеется в виду, чтобы при компиляции код размещался в загрузочной секции. Может есть директива, указывающая куда кидать код?

Сообщение отредактировал Brain13 - Apr 11 2010, 23:52
Go to the top of the page
 
+Quote Post
smac
сообщение Apr 12 2010, 03:19
Сообщение #4


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

Группа: Участник
Сообщений: 149
Регистрация: 2-06-08
Из: Москва
Пользователь №: 38 003



Цитата(Brain13 @ Apr 12 2010, 04:05) *
...Думаю, что вся проблема заключается в следующем вопросе:
Как настроить проект AVRStudio+WinAVR, для написания bootloader'a...

Так Вы документацию на WinAVR (точнее на avr-libc) почитайте, там написано многое, вот ссылка на всякий случай bootloaer
Go to the top of the page
 
+Quote Post
Brain13
сообщение Apr 12 2010, 19:49
Сообщение #5


Участник
*

Группа: Участник
Сообщений: 65
Регистрация: 28-08-09
Пользователь №: 52 078



Цитата(smac @ Apr 12 2010, 07:34) *
Так Вы документацию на WinAVR (точнее на avr-libc) почитайте, там написано многое, вот ссылка на всякий случай bootloaer

Это я читал. Все было бы хорошо, но вот при подключении <avr/boot.h> вылетают ошибки. Он предназначен для mega. На XMEGA работать не хочет. Но в этом файле есть интересная строка:
Код
#define BOOTLOADER_SECTION    __attribute__ ((section (".bootloader")))



Если в опциях проекта, в разделе Memory Sections сделать секцию ".bootloader" с адресом начала boot-секции в словах(для XMEGA16A4 это 0x2000) и сделать вот такую конструкцию:

Код
int main()
{
// Здесь main
}



__attribute__ ((section (".bootloader")))

int bootmain() // А здесь bootloader
{
    void (*funcptr)( void ) = 0x0000;
    while(1)
    {
           funcptr(); // Run to program
    }
    
    return 0;
}


То функция bootmain является загрузчиком. Но здесь есть проблемка: с такой конструкцией мне удалось использовать в boot-секции только одну функцию. Если __attribute__ ((section (".bootloader"))) написать перед несколькими они перезаписывают друг-друга и это естественно. А если не писать, то след функция пишется в основной секции. Остается вариант использовать inline функции, чтоб они встраивались в код bootloader'а. Но может и места не хватить.

Какие есть еще мысли и предложения?
Go to the top of the page
 
+Quote Post
zltigo
сообщение Apr 12 2010, 20:15
Сообщение #6


Гуру
******

Группа: Свой
Сообщений: 13 372
Регистрация: 27-11-04
Из: Riga, Latvia
Пользователь №: 1 244



Цитата(Brain13 @ Apr 11 2010, 23:33) *
PS: Извините если подобные темы уже были...

Admin:
Не извиняю. Поиском НАДО пользоваться.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Apr 12 2010, 20:24
Сообщение #7


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(Brain13 @ Apr 12 2010, 22:04) *
То функция bootmain является загрузчиком. Но здесь есть проблемка: с такой конструкцией мне удалось использовать в boot-секции только одну функцию. Если __attribute__ ((section (".bootloader"))) написать перед несколькими они перезаписывают друг-друга и это естественно.
Это неестественно. Линкер складывает секции одну за другой. Ничего никуда не накладывается - вы, видимо, что-то не так поняли. Не нужно делать секцию .bootloader - вы все равно не сможете положить в нее стартап-код. Да и просто замучаетесь класть каждую функцию в эту секцию. Возьмите из winavr/avr/lib/ldscripts скрипт для вашего проекта, измените в нем адрес региона text на нужные вам адреса области загрузчика и укажите линкеру использовать этот скрипт: -Wl,-T,<имя скипта>. Рассматривайте ваш загрузчик как самостоятельную программу.


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
Brain13
сообщение Apr 12 2010, 21:39
Сообщение #8


Участник
*

Группа: Участник
Сообщений: 65
Регистрация: 28-08-09
Пользователь №: 52 078



Цитата
Не нужно делать секцию .bootloader - вы все равно не сможете положить в нее стартап-код

Но я уже туда смог положить код, и он выполняется. Или что-то не так?

Цитата
Возьмите из winavr/avr/lib/ldscripts скрипт для вашего проекта, измените в нем адрес региона text на нужные вам адреса области загрузчика и укажите линкеру использовать этот скрипт: -Wl,-T,<имя скипта>. Рассматривайте ваш загрузчик как самостоятельную программу.


А можно поподробнее? А где он там прописывается и в каком виде? Что указывать в коде? Что в настройках?
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Apr 13 2010, 09:28
Сообщение #9


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(Brain13 @ Apr 12 2010, 23:54) *
Но я уже туда смог положить код, и он выполняется. Или что-то не так?
Кроме вашего кода в программе могут быть библиотечные функции. Одна из основных - стартап код: настройка указателя стека, иниициализация переменных. Поскольку эти функции - библиотечные, вы не сможете задать их размещение. Они попадут в те секции, которые прописаны в их исходниках.
Цитата(Brain13 @ Apr 12 2010, 23:54) *
А где он там прописывается и в каком виде? Что указывать в коде? Что в настройках?
Кто "он"? Где "там"?


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
Brain13
сообщение Apr 14 2010, 03:46
Сообщение #10


Участник
*

Группа: Участник
Сообщений: 65
Регистрация: 28-08-09
Пользователь №: 52 078



"Он" - адрес региона text.
"Там" - "скрипт из winavr/avr/lib/ldscripts". А какой скрипт предпочтительнее править?
Что указывать в коде, чтобы функции попали в прописанный регион?
В настройках проекта что-нибудь править надо?

Сообщение отредактировал Brain13 - Apr 14 2010, 03:48
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Apr 14 2010, 11:04
Сообщение #11


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(Brain13 @ Apr 14 2010, 06:01) *
"Он" - адрес региона text.
Откройте любой файл скрипта из упомянутой папки любым текстовым редактором. Если вопрос останется - прочтите документацию на линкер в WinAVR\doc\binutils\ld.html, хотя бы раздел Scripts/MEMORY command
Цитата(Brain13 @ Apr 14 2010, 06:01) *
"Там" - "скрипт из winavr/avr/lib/ldscripts". А какой скрипт предпочтительнее править?
Найдите тот, который используется с конкретно вашим процессором. Я не работаю с хмегами.
Цитата(Brain13 @ Apr 14 2010, 06:01) *
Что указывать в коде, чтобы функции попали в прописанный регион?
Ничего. Регион text - это вся доступная для проекта флеш-память. В него укладываются секции.
Цитата(Brain13 @ Apr 14 2010, 06:01) *
В настройках проекта что-нибудь править надо?
Достаточно указать линкеру использовать ваш исправленый скрипт, см сообщение №7


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
Brain13
сообщение Apr 14 2010, 20:03
Сообщение #12


Участник
*

Группа: Участник
Сообщений: 65
Регистрация: 28-08-09
Пользователь №: 52 078



Спасибо, что-то у меня получилось(по крайней мере в .hex файле адреса у меня начинаются с 0x4000), сейчас разберусь с самопрограммированием, прерываниями в этом режиме, и отпишусь здесь что получилось.
Go to the top of the page
 
+Quote Post
Brain13
сообщение Apr 16 2010, 19:58
Сообщение #13


Участник
*

Группа: Участник
Сообщений: 65
Регистрация: 28-08-09
Пользователь №: 52 078



Все получилось!
Итак, опишу последовательность действий.
Материал не претендует на звание единственно правильного. smile.gif

Создаем новый проект. Пишем простейшую прогу(кому что нравится). Лезем в ..\WinAVR\avr\lib, видим папку ldscripts, переименовываем ее в ldscripts_, компилим проект, видим, что она ругается на какой-то скрипт(у меня на avrxmega2.x), копируем этот скрипт в "<папка проекта>\default\" с другим именем(у меня avrxmega2b.x), переименовываем папку ldscripts обратно. Открываем наш скрипт, видим следующее:
Код
/* Default linker script, for normal executables */
OUTPUT_FORMAT("elf32-avr","elf32-avr","elf32-avr")
OUTPUT_ARCH(avr:102)
MEMORY
{
  text      (rx)   : ORIGIN = 0, LENGTH = 1024K
  data      (rw!x) : ORIGIN = 0x802000, LENGTH = 0xffa0
  eeprom    (rw!x) : ORIGIN = 0x810000, LENGTH = 64K
  fuse      (rw!x) : ORIGIN = 0x820000, LENGTH = 1K
  lock      (rw!x) : ORIGIN = 0x830000, LENGTH = 1K
  signature (rw!x) : ORIGIN = 0x840000, LENGTH = 1K
}

...

Изменяем строку
Код
  text      (rx)   : ORIGIN = 0, LENGTH = 1024K

на
Код
  text      (rx)   : ORIGIN = 0x4000, LENGTH = 1024K

Адрес у каждого контроллера свой. Сохраняем, закрываем.

Лезем в настройки проекта в AVR Studio: Project->Configuration Options->Custon Options->Linker Options.
В строке вбиваем -Wl,-T,"avrxmega2b.x", Вводите свое имя файла скрипта. Нажимаем Add, OK.

Компилим проект. Открывааем файл <папка проекта>/default/<имя проекта>.hex в любом текстовом редакторе. Описание формата.
Должно начинаться примерно так(у меня адрес 0x4000, у Вас может быть другой)
Код
:10400000 Тут Ваш код
:10401000 Тут Ваш код
:10402000 Тут Ваш код
:10403000 Тут Ваш код
:10404000 Тут Ваш код

Адреса должны начинаться с того что вы написали в скрипте.

Дальше лезем во фьюзы: Tools->Program AVR->Connect-> Выбираем Ваш Программатор ->Fuses->BOOTRST
Говорим загружаться с boot-секции.

Теперь все, что Вы напишете в проекте будет загрузчиком.

Я взял код из AVR1605 и переделал под себя. Изменил defines.h(обязательно измените PAGESIZE, APP_END и сигнатуру, а PARTCODE я не менял, не знаю что это) немножко main.c и serial.c. Теперь имею программатор с поддержкой AVROSP(имеется в AVR1605).
Кстати как пользоваться AVROSP написано в этом Application Note, если нет XML вашего контроллера - все равно запустите прошивать контроллер, он ругнется, что flash pagesize не указан. А рядом с ним создастся xml-файл. Отркойте его и впишите Ваш размер страницы до следущего вида(у меня 256):
Код
<AVRPART><MEMORY><PROG_FLASH>20480</PROG_FLASH><EEPROM>1024</EEPROM><BOOT_CONFIG><PAGESIZE>256</PAGESIZE></BOOT_CONFIG></MEMORY><FUSE></FUSE><ADMIN><SIGNATURE><ADDR000>$1E</ADDR000><ADDR001>$94</ADDR001><ADDR002>$41</ADDR002></SIGNATURE></ADMIN></AVRPART>


На этом все!
Выражаю благодарность Сергею Борщ и всем, кто помогал мне.

PS: Сообщите мне если я что-то упустил из виду, или что-нибудь осталось непонятным.

Сообщение отредактировал Brain13 - Apr 16 2010, 20:00
Go to the top of the page
 
+Quote Post

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

 


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


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