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

 
 
 
Reply to this topicStart new topic
> Непонятный возврат из функции..., IAR SAM7 J-Link
Dron_Gus
сообщение Apr 24 2007, 13:44
Сообщение #1


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

Группа: Свой
Сообщений: 1 202
Регистрация: 9-01-05
Из: Санкт-Петербург
Пользователь №: 1 861



Даже не знаю, куда копать. Есть несколько ramfunc-функций, возвращающих значение типа int. Используются для перезаписи флеш. Одна ramfunc функция вызывается из другой. Если просто запустить процессор, то в какой-то момент он вываливается в data abort. Если ходить по шагам, то происходит непонятное - при выходе из самой "глубокой" функции происходит перескакивание на 1 выход. Т.е. выходим сразу на 2 уровня вложенности. Т.е. вместо 1-2-3-2-1 просходит 1-2-3-1. После еще нескольких шагов процессор радостно падает в data abort. Стеки проверил.



З.Ы. как таковой записи во флешь не происходит - программа не доходит до этого момента. sad.gif


--------------------
Если сверху смотреть, то сбоку кажется, что снизу ничего не видно.
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Apr 24 2007, 14:51
Сообщение #2


Гуру
******

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



Цитата(Dron_Gus @ Apr 24 2007, 12:44) *
З.Ы. как таковой записи во флешь не происходит - программа не доходит до этого момента. sad.gif
Вот тут пример записи во флеш с всего одной короткой ramfunc. Сделайте минимальный проект (выкиньте все лишнее), выложите сюда, посмотрим. Чудес не бывает - отладка прекрасно работает и из флеш и из ОЗУ.


--------------------
На любой вопрос даю любой ответ
"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
Calculator
сообщение Apr 24 2007, 14:52
Сообщение #3


Участник
*

Группа: Свой
Сообщений: 45
Регистрация: 19-04-07
Пользователь №: 27 172



Цитата(Dron_Gus @ Apr 24 2007, 16:44) *
Если просто запустить процессор, то в какой-то момент он вываливается в data abort.

В data abort нужно посмотреть адрес в LR, откуда туда занесло
Цитата(Dron_Gus @ Apr 24 2007, 16:44) *
Если ходить по шагам, то происходит непонятное - при выходе из самой "глубокой" функции происходит перескакивание на 1 выход. Т.е. выходим сразу на 2 уровня вложенности. Т.е. вместо 1-2-3-2-1 просходит 1-2-3-1. После еще нескольких шагов процессор радостно падает в data abort. Стеки проверил.

Хождение по шагам может не получаться из-за оптимизатора, лучше делать шаги в окне дизассемблера, тогда возможно этого глюка не произойдет
Go to the top of the page
 
+Quote Post
Dron_Gus
сообщение Apr 24 2007, 15:34
Сообщение #4


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

Группа: Свой
Сообщений: 1 202
Регистрация: 9-01-05
Из: Санкт-Петербург
Пользователь №: 1 861



2 Сергей Борщ. Спасибо. Тот код я смотрел и писал свой "по мотивам". Одной функцией сделать нет возможности, т.к. образ грузится из AT45DB, поэтому необходимы функци для обслуживания онной.

2 Calculator про дата аборт и lr знаю. Смотрел. По lr-0x8 вполне "невинный" код. А по шагам ходил как раз в окне дизассемблера.

Вообщем-то проблемма решилась вроде как. Перезагрузка всего и отлов нескольких глюков. Похоже массивом на стек наезжал. Правда до этого был абсолютно такой же глюк с другим проектом, который тоже как-то непонятно сам исчез.

Всем спасибо. cheers.gif


--------------------
Если сверху смотреть, то сбоку кажется, что снизу ничего не видно.
Go to the top of the page
 
+Quote Post
Calculator
сообщение Apr 25 2007, 06:22
Сообщение #5


Участник
*

Группа: Свой
Сообщений: 45
Регистрация: 19-04-07
Пользователь №: 27 172



Наезд на стек хорошо ловить watchpoint'ом (меню J-Link). Поставить останов на запись слова в последний адрес стека
Go to the top of the page
 
+Quote Post
Dron_Gus
сообщение Apr 25 2007, 14:51
Сообщение #6


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

Группа: Свой
Сообщений: 1 202
Регистрация: 9-01-05
Из: Санкт-Петербург
Пользователь №: 1 861



Спасибо. Надо будет погонять-посмотреть. А можно ли использовать хардварные watchpoint'ы из программы? Т.е. без подключения отладчика.


--------------------
Если сверху смотреть, то сбоку кажется, что снизу ничего не видно.
Go to the top of the page
 
+Quote Post
defunct
сообщение Apr 26 2007, 01:33
Сообщение #7


кекс
******

Группа: Свой
Сообщений: 3 825
Регистрация: 17-12-05
Из: Киев
Пользователь №: 12 326



Цитата(Dron_Gus @ Apr 24 2007, 14:34) *
По lr-0x8 вполне "невинный" код.

Гм? 0x8 это ж из Exception Tab, вы уверены что смотрите тот LR?
Go to the top of the page
 
+Quote Post
Calculator
сообщение Apr 26 2007, 07:15
Сообщение #8


Участник
*

Группа: Свой
Сообщений: 45
Регистрация: 19-04-07
Пользователь №: 27 172



Цитата(Dron_Gus @ Apr 25 2007, 17:51) *
А можно ли использовать хардварные watchpoint'ы из программы? Т.е. без подключения отладчика.

ИМХО нет, точно не знаю. Отладчиком они используются через JTAG, снаружи контроллера. У ядра к ним доступа скорее всего нет.
Go to the top of the page
 
+Quote Post
zltigo
сообщение Apr 26 2007, 11:40
Сообщение #9


Гуру
******

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



Цитата(Calculator @ Apr 26 2007, 07:15) *
У ядра к ним доступа скорее всего нет.

Точно нет.


--------------------
Feci, quod potui, faciant meliora potentes
Go to the top of the page
 
+Quote Post
Dron_Gus
сообщение Apr 26 2007, 12:44
Сообщение #10


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

Группа: Свой
Сообщений: 1 202
Регистрация: 9-01-05
Из: Санкт-Петербург
Пользователь №: 1 861



Цитата(defunct @ Apr 26 2007, 02:33) *
Гм? 0x8 это ж из Exception Tab, вы уверены что смотрите тот LR?




Имелся ввиду код по [LR-0x8]. Сорри, неточно выразился.


--------------------
Если сверху смотреть, то сбоку кажется, что снизу ничего не видно.
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 21st July 2025 - 15:09
Рейтинг@Mail.ru


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