|
|
  |
bootloader в IARe 3,10, Помогите разобраться как сделать |
|
|
|
Jan 16 2008, 20:08
|
Знающий
   
Группа: Свой
Сообщений: 589
Регистрация: 24-04-05
Пользователь №: 4 447

|
Пытаюсь использовать функции записи во флеш из апнота avr106 для своего проекта (Mega324P). Хочу сохранять параметры в неиспользованной части бутлодера (от начала сектора NRWW до начала собственно бутлодера). В верхней NRWW области прошит бутлодер размером 1кб. Область NRWW для данного мк занимает 4кБ. Бутлодер создан отдельным проектом. Сделал так как указано в апноте: Код //Alternatively it is possible to place only selected functions into defined segments of //the Flash memory. In fact it is only the functions for writing that need to be located //inside the Boot section. //1. Make a new define for Boot size. -D_..X_BOOTSEC_SIZE=1000 /* 2048 words */ //2. Define a new segment for the entire Boot section based on the definition in step 1. -Z(FARCODE)BOOT_SEGMENT=(_..X_FLASH_END-_..X_BOOTSEC_SIZE+1)-_..X_FLASH_END //Placing a C function into the defined segment: void ExampleFunction() @ BOOT_SEGMENT { ------ } ...т.е. в описании и объявлении функции записи во флеш добавил @"BOOT_SEGMENT" unsigned char WriteFlashByte(MyAddressType flashAddr, unsigned char data)@"BOOT_SEGMENT"; При вызове этой функции возникает ошибка: Код Error[e133]: The output format intel-extended cannot handle multiple address spaces. Use format variants (-y -O) to specify which address space is wanted Что я сделал не так? Вообще-то, мне необходимо разместить функции так, чтобы не они не "попали" в самый верхний килобайт памяти (загрузчик).
|
|
|
|
|
Jan 17 2008, 09:27
|

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

|
Цитата(alux @ Jan 17 2008, 08:14)  Прошу прощения. Ошибка вышла. Скопировал с апнота... У меня было -Z(CODE)... Так в чем же дело? EEPROM не используется? Точнее, не так: Если используется eeprom, то задаются ли ей в программе начальные значения? Если да, то оставьте на вкладке выбора формата отладочный формат для C-SPY, а на вкладке extra options допишите Код -Ointel-extended,(CODE)=.hex -Ointel-extended,(XDATA)=.eep
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
Jan 17 2008, 09:41
|

Просто Che
    
Группа: Свой
Сообщений: 1 567
Регистрация: 22-05-07
Из: ExUSSR
Пользователь №: 27 881

|
Сразу возник вопрос: вы это пытаетесь добавлять в проект с бутлоадером или в проект с прикладной программой? Я попробовал на проекте на мега128 с бутлоадером. При добавлении в прикладную программу след. строк все линкуется без ошибок. Код *.xcl файл: -D_..X_APPFLASH_END=1DFFF /* End of Applications flash memory */ -D_..X_BOOTLOADER_BASE=1F000 /* Start of BootLoader flash memory */ -Z(CODE)BOOTCODE=_..X_BOOTLOADER_BASE-_..X_FLASH_END -Z(CODE)BOOT_SEGMENT=1E000-(_..X_BOOTLOADER_BASE-1) *.c файл: __root unsigned char WriteFlashByte(unsigned int flashAddr, unsigned char data)@"BOOT_SEGMENT"; Правда, обратите внимание, что я разделил сегменты, куда прилинковывается бутлоадер из другого проекта и сегмент с вашей функцией. А такую ошибку я тоже уже видел: Цитата(alux @ Jan 16 2008, 22:08)  Error[e133]: The output format intel-extended cannot handle multiple address spaces. Use format variants (-y -O) to specify which address space is wanted Но возникает она, если пытаться вывести в hex файл одновременно и CODE и DATA (или EEPROM).
|
|
|
|
|
Jan 17 2008, 13:51
|
Знающий
   
Группа: Свой
Сообщений: 589
Регистрация: 24-04-05
Пользователь №: 4 447

|
Цитата(Сергей Борщ @ Jan 17 2008, 13:27)  Код -Ointel-extended,(CODE)=.hex -Ointel-extended,(XDATA)=.eep Цитата(Baser @ Jan 17 2008, 13:41)  Сразу возник вопрос: вы это пытаетесь добавлять в проект с бутлоадером или в проект с прикладной программой?Я попробовал на проекте на мега128 с бутлоадером. При добавлении в прикладную программу след. строк все линкуется без ошибок. Еще раз повторюсь. Есть многофайловый проект на Мега324 (без бутлодера). Бутлодер создан отдельным проектом. В контроллер уже прошит загрузчик в последний килобайт флеша. Хочу использовать функции из avr106 для записи во флеш. В частности в неиспользованную область NRWW (до начала загрузчика). В области NRWW необходимо разместить только функции записи во флеш. Я в курсе, что такое сообщение возникает при попытке скомпилить с данными в ЕЕПРОМе. И эти опции тоже использую, если надо. Но в тот момент ЕЕПРОМ не использовал. Это сообщение возникает при ВЫЗОВЕ WriteFlashByte(); Если не вызывать данную функцию, линкуется без ошибок.
|
|
|
|
|
Jan 17 2008, 14:11
|

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

|
Цитата(alux @ Jan 17 2008, 15:51)  Если не вызывать данную функцию, линкуется без ошибок. Тогда приведите кусок вашего .xcl. Вы показываете какой-то другой .xcl, и хотите телепатии. В вашем .xcl в определнии сегмента BOOT_SEGMENT используется _..X_FLASH_END? Если да, чему оно у вас равно?
--------------------
На любой вопрос даю любой ответ"Write code that is guaranteed to work, not code that doesn’t seem to break" ( C++ FAQ)
|
|
|
|
|
Jan 17 2008, 16:57
|

Просто Che
    
Группа: Свой
Сообщений: 1 567
Регистрация: 22-05-07
Из: ExUSSR
Пользователь №: 27 881

|
Цитата(alux @ Jan 17 2008, 15:51)  Еще раз повторюсь. Есть многофайловый проект на Мега324 (без бутлодера). Бутлодер создан отдельным проектом. В контроллер уже прошит загрузчик в последний килобайт флеша. Хочу использовать функции из avr106 для записи во флеш. В частности в неиспользованную область NRWW (до начала загрузчика). В области NRWW необходимо разместить только функции записи во флеш. Еще раз проверьте все, что вы делаете. Если именно так как написано, то это линкуется без ошибок. Проверил  Если есть сомнения, посмотрите прикрепленные файлы. Цитата Я в курсе, что такое сообщение возникает при попытке скомпилить с данными в ЕЕПРОМе. И эти опции тоже использую, если надо. Но в тот момент ЕЕПРОМ не использовал. Это сообщение возникает при ВЫЗОВЕ WriteFlashByte(); Если не вызывать данную функцию, линкуется без ошибок. Это просто наложение ошибок. На вызов функции такое сообщение выдаваться не может.
Прикрепленные файлы
Test.zip ( 9.25 килобайт )
Кол-во скачиваний: 59
|
|
|
|
|
Jan 18 2008, 11:16
|
Знающий
   
Группа: Свой
Сообщений: 589
Регистрация: 24-04-05
Пользователь №: 4 447

|
Цитата(arttab @ Jan 18 2008, 06:02)  я поимел большие проблемы в установлении причины почему не получается самопрограммирование из-за неверных фузов размера загрузчика. проверьте на всякий случай При чем в данном случае фузы? Речь идет об ошибке на этапе линковки программы. To BaserНе совсем понимаю для чего необходимо создавать хексы для DATA и EEPROM? Код -y(CODE) -Ointel-extended,(DATA)=_data.hex -Ointel-extended,(XDATA)=_eeprom.hex Обязательно ли все функции размещать в "BOOT_SEGMENT" ? По-моему, достаточно разместить только те функции, которые непосредственно работают с SPM инструкцией. Так? Или также и функции, в которые входят эти функции (SPM) ? И зачем объявлять их как extern? Без модификатора extern все компилится без ошибок. И последнее, для чего root?
|
|
|
|
|
Jan 18 2008, 16:29
|

Просто Che
    
Группа: Свой
Сообщений: 1 567
Регистрация: 22-05-07
Из: ExUSSR
Пользователь №: 27 881

|
Цитата(alux @ Jan 18 2008, 13:16)  To Baser Не совсем понимаю для чего необходимо создавать хексы для DATA и EEPROM? Про это вам, вообщем-то, Сергей Борщ говорил  и относилось это к возникающей у вас ошибке линкера, которая могла быть следствием попытки вывести в Intel-hex файл одновременно два адресных пространства: CODE и EEPROM. А для чего получать два файла с хексами для DATA и EEPROM - чтобы затем прошить их в МК Цитата Обязательно ли все функции размещать в "BOOT_SEGMENT" ? По-моему, достаточно разместить только те функции, которые непосредственно работают с SPM инструкцией. Так? Или также и функции, в которые входят эти функции (SPM) ? Да, конечно, можно размещать только функции с SPM. Но это только в том случае, если вы все эти функции компилируете и пишете в МК вместе (а не отдельно функции с SPM в проекте бутлоадера, а другие функции в прикладной программе), иначе вам необходимо обеспечить нахождение точек вызова функций по абсолютным адресам. Цитата И зачем объявлять их как extern? Без модификатора extern все компилится без ошибок. В случае описания внешних функций спецификатор extern является спецификатором по умолчанию и его допускается не писать (как мы не пишем auto при определении локальных auto-переменных). Но я привык всегда явно указывать extern, считаю, что это наглядней. Цитата И последнее, для чего root? __root служит для указания линкеру, что данная функция или переменная должна быть безусловно включена в код, даже если она нигде не используется. Поскольку пример был тестовый, я везде добавил __root , чтобы линкер не своевольничал з.ы. А как вы отлаживаете прикладную программу, с кодами бутлоадера или без них? Интересен опыт других людей, поскольку с этим вопросом сам недавно разбирался.
|
|
|
|
|
Jan 20 2008, 18:02
|
Группа: Новичок
Сообщений: 9
Регистрация: 20-01-08
Пользователь №: 34 261

|
Возникла такая проблема - не работает АЕS бутлоадер для ATmega64. Стал упрощать код, еще и еще, пока не дошел просто до пустой функции main(void) - он в функцию входит но из нее не выходит и висит - что это может быть?
|
|
|
|
|
  |
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|