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

 
 
> Можно ли подцепиться дебагером к бегущей апликации, keil st-link SWD
igorle
сообщение Oct 18 2013, 13:59
Сообщение #1


Местный
***

Группа: Свой
Сообщений: 338
Регистрация: 14-07-12
Пользователь №: 72 753



У меня устройство работаает автономно несколько суток. Ингода возникают непонятности. Можно ли подцепиться к уже бегущей апликации, чтобы подебагировать ситуацию?

Работают с Кейлом. Дебагер - ST-Link. Интерфейс - SDW

Единственное, до чего я додумался - убрать флажок "Load Application at Startup". В результате имидж не грузится, но и увидеть что творится в бегущем старом имидже не получается.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов (1 - 10)
igorle
сообщение Oct 19 2013, 06:18
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 338
Регистрация: 14-07-12
Пользователь №: 72 753



Пока все отдыхают (за сутки ни одного ответа, редкий случай sm.gif ), я немного продвинулся. Можно подцепиться без сброса. Для этого надо в свойствах проекта, на закладке Debug убрать флажок "Load Application at Startup" (это я уже делал раньше). Вдобавок надо нажать кнопку Settings рядом с выбором дебагера, и там убрать флажок "Reset after Connect".

Теперь, при нажатии кнопки "старт дебаг", я вижу в окне дизассемблера - где я нахожусь. Могу проверить регистры и почитать память. Пользуясь файлом *.map, я могу вычислить - в какой функции я сейчас.

Но я бы хотел получить полноценный дебаг. С Call Stack, breakpoints, с показом переменных... Это возможно?
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Oct 19 2013, 07:35
Сообщение #3


Гуру
******

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



QUOTE (igorle @ Oct 19 2013, 09:18) *
на закладке Debug убрать флажок "Load Application at Startup" (это я уже делал раньше)
А поищите, нет ли в вашем Кейле отдельной галочки, запрещающей именно загрузку в проц. Load Application вполне может загружать в отладчик и необходимый вам файл с отладочной информацией.


--------------------
На любой вопрос даю любой ответ
"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
igorle
сообщение Oct 19 2013, 08:12
Сообщение #4


Местный
***

Группа: Свой
Сообщений: 338
Регистрация: 14-07-12
Пользователь №: 72 753



Идея красивая, но не сработала. Я попробвал вернуть "Load Application", убрать "Update Target before Debugging" и убрать "Reset after Connect" - target сразу оказывается на стартовом адресе....

Странно - ведь проблема, которую я пытаюсь решить - стандартная для тех задач, что решают MCU. Неужени никто из профи не сталкивался с нею?
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Oct 19 2013, 09:21
Сообщение #5


Гуру
******

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



А нет ли там какого-либо скрипта, выполняющегося перед отладкой? Типа настройки тактирования, сброса периферии и т.д.? Может это он перезапускает?


--------------------
На любой вопрос даю любой ответ
"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
igorle
сообщение Oct 19 2013, 10:08
Сообщение #6


Местный
***

Группа: Свой
Сообщений: 338
Регистрация: 14-07-12
Пользователь №: 72 753



Скрипт можно добавить, но его нет. И если я убираю "Load Application at Startup", то борд не сбрасывается. Но и радости мало - я вижу только дизассемблер, и текущие регистры. В таком спартанском контексте дебагировать затруднительно.
Go to the top of the page
 
+Quote Post
Alex11
сообщение Oct 19 2013, 11:21
Сообщение #7


Гуру
******

Группа: Свой
Сообщений: 2 106
Регистрация: 23-10-04
Из: С-Петербург
Пользователь №: 965



Я с кейлом не работаю, но, например, у техаса есть командочка load symbols, после чего становится гораздо интереснее. Может и в кейле есть что-то похожее?
Go to the top of the page
 
+Quote Post
igorle
сообщение Oct 19 2013, 12:45
Сообщение #8


Местный
***

Группа: Свой
Сообщений: 338
Регистрация: 14-07-12
Пользователь №: 72 753



"У техаса" - это имеется ввиду Code Composer? Я с ним работаю на MSP430. Тоже полезно знать. Просто там все байты на пересчет, так что обычно дебагировал методом пристального вглядывания. Но спасибо за информацию - буду знать.

А у кейла я такой кнопки не нашел.
Пока наиболее полезную информацию почерпнул здесь. И то, что нужная мне тема не обсуждается, наводит на мысль, что я неправильно задаю ключевые слова поиска. Ну не может быть, что никому этого не надо, и все обходятся без дебага долго работающего устройства.
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Oct 19 2013, 13:15
Сообщение #9


Гуру
******

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



QUOTE (igorle @ Oct 19 2013, 15:45) *
Ну не может быть, что никому этого не надо, и все обходятся без дебага долго работающего устройства.
В принципе - да, этим редко кто пользуется. Я когда еще пользовал ИАР пытался пару раз, но с большой долей вероятности при втыкании дебаггера в работающее устройство происходил сброс. То ли от помех, то ли нога reset дебаггера находилась в неудачном положении, а отрезать ее было проблематично. Сейчас, когда попытался так отлаживать через OpenOCD и ST-Link, обнаружил и исправил в коде OpenOCD ошибки, делавшие такю отладку невозможной. И раз за почти два года, как в OpenOCD существует поддержка ST-Link и SWD никто эти ошибки не нашел и на них не жаловался - значит практически никто такой режим не использует.


--------------------
На любой вопрос даю любой ответ
"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
toweroff
сообщение Oct 19 2013, 19:20
Сообщение #10


Гуру
******

Группа: Свой
Сообщений: 2 957
Регистрация: 19-09-06
Из: Москва
Пользователь №: 20 514



Цитата(Сергей Борщ @ Oct 19 2013, 17:15) *
обнаружил и исправил в коде OpenOCD ошибки, делавшие такю отладку невозможной

при отсутствии CRP и подобных механизмов, надеюсь?
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Oct 19 2013, 20:35
Сообщение #11


Гуру
******

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



QUOTE (toweroff @ Oct 19 2013, 22:20) *
при отсутствии CRP и подобных механизмов, надеюсь?
Разумеется. Там просто не вызывался опрос опрос состояния, а если это и справить и он начнет вызываться - то состояние не обновлялось считанным значением.


--------------------
На любой вопрос даю любой ответ
"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

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

 


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


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