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

 
 
> ATmega128 проблемы с загрузчиком
Konste
сообщение Nov 10 2006, 06:19
Сообщение #1





Группа: Новичок
Сообщений: 14
Регистрация: 27-02-06
Пользователь №: 14 731



Здравствуйте!

Пишу для ATmega128, из под winAVR bootloader и пользовательскую программу, прошиваю по очереди сначала hex пользовательской, потом - hex bootloader`a.
В данном случае не подразумевается, что boot должен грузить пользовательскую (просто разместил две программы в разных секциях флэш для проверки работоспособности и возможности загружаться из нужного места).
Проблема в следующем:
- после загрузки запускается сразу пользовательская программа (хотя BOOTRST fuse запрограммирован).

Если прошить только bootloader - он один запускается и работает нормально.
Если прошить только пользовательскую программу (фьюз BOOTRST запрограммирован) - грузится пользовательская
Если прошить и то и другое, то возникает описанная проблема.

чтобы boot писался в нужное место в Makefile в параметрах для линкера дописываю
LDFLAGS = -Wl,--section-start=.text=0xF000,

Тексты прог в архиве.

Подскажите, пожалуйста, что я не так делаю.
Заранее спасибо.

Случайно кинул архив, в котором много лишнего - вот новый архив.
Прикрепленные файлы
Прикрепленный файл  _ATMega128_.rar ( 46.93 килобайт ) Кол-во скачиваний: 72
Прикрепленный файл  _ATMega128_.rar ( 14.55 килобайт ) Кол-во скачиваний: 61
 
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов (1 - 5)
_Sam_
сообщение Nov 10 2006, 06:30
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 278
Регистрация: 18-01-05
Из: Санкт-Петербург
Пользователь №: 2 031



может поможет.
Код
Table 3-6. Recommended fuse bits
                                  M8, M8515, M8535, M16,
                                  M162, M169, M32, M64                        M128
BOOTSZ1:0                            0:0                                      1:0
BOOTRST                                0                                        0


вобщем надо проверить соответсвие между BOOTSZ и Boot Reset Adres.
Go to the top of the page
 
+Quote Post
Konste
сообщение Nov 10 2006, 08:12
Сообщение #3





Группа: Новичок
Сообщений: 14
Регистрация: 27-02-06
Пользователь №: 14 731



Цитата(_Sam_ @ Nov 10 2006, 09:30) *
может поможет.
Код
Table 3-6. Recommended fuse bits
                                  M8, M8515, M8535, M16,
                                  M162, M169, M32, M64                        M128
BOOTSZ1:0                            0:0                                      1:0
BOOTRST                                0                                        0


вобщем надо проверить соответсвие между BOOTSZ и Boot Reset Adres.


BOOTSZ1:0 0 0
при этом reset на 0xf000. Так оно и должно быть. Хоть это и не "Recommended" для ATmega128, но работать-то всё равно должно... так что не ясно пока в чём дело... sad.gif
Go to the top of the page
 
+Quote Post
Dopler
сообщение Nov 11 2006, 12:46
Сообщение #4


Местный
***

Группа: Свой
Сообщений: 437
Регистрация: 23-04-05
Из: Таганрог
Пользователь №: 4 425



Код
; Move interrupts to boot flash section
    ldi     tmp,     (1<<IVCE)
    out     MCUCR, tmp
    
    ldi     tmp,     (1<<IVSEL)
    out     MCUCR, tmp


Для Mega128 в коде программы (при старте), при запуске из загрузочной области необходимо переместить вектора прерываний. Фьюз BOOTRST перемещает только прерывание Reset. Возможно проблемма в этом.
Go to the top of the page
 
+Quote Post
Konste
сообщение Nov 13 2006, 04:23
Сообщение #5





Группа: Новичок
Сообщений: 14
Регистрация: 27-02-06
Пользователь №: 14 731



Спасибо всем за помощь, решение найдено - ошибка в даташите на ATmega128 под номером 2467N-AVR-03/06
В даташите
BOOTSZ(1-0) Boot Reset Address
1-1 $FE00
1-0 $FC00
0-1 $F800
0-0 $F000

Тогда как реально:
BOOTSZ(1-0) Boot Reset Address
1-1 $FC00
1-0 $F800
0-1 $F000
0-0 $E000

Ну и от этого уже соответственно вся таблица 112 неверна.

Короче багрепорт это. Просьба к модераторам переместить это сообщение куда надо (мож там ркбрика какая с багрепортами есть) - авось ещё кто столкнётся.

PS в опциях для линковщика нужно указывать скажем --section-start=.text=0x1FC00, а не 0xFC00 так как представление адреса байтовое, а не по словам и его надо в два раза увеличивать (ну или что-то в этом роде smile.gif).

Тема закрыта.
Go to the top of the page
 
+Quote Post
Konste
сообщение Nov 13 2006, 07:27
Сообщение #6





Группа: Новичок
Сообщений: 14
Регистрация: 27-02-06
Пользователь №: 14 731



Ну всё... теперь, надеюсь, окончательно с этим разобрался smile.gif)

В даташите всё правильно - просто там адрес считается в словах, а в опциях линковщика и ihex формате - в байтах, потому, например для $0xF000 (DS) имеен $0xF000 * 2 = $0x1E000 в ihex и линкере.

... теперь, наверное всё - тема закрыта smile.gif
Go to the top of the page
 
+Quote Post

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

 


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


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