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

 
 
 
Reply to this topicStart new topic
> График в IAR, как построить?
sevastianovd
сообщение May 1 2012, 04:02
Сообщение #1


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

Группа: Свой
Сообщений: 78
Регистрация: 8-04-08
Из: Омск
Пользователь №: 36 562



Здравствуйте,
начал работать с DSP-функциями на ядре Cortex-M3
захотелось видеть график изменения переменной от времени/отсчетов

как это сделать?

наткнулся на timeline window в режиме SWD, но на каждое изменение переменной точку останова мне не поставить.
в идеале, хочется набрать массив данных, в конце остановиться и отрисовать график.
отладчик J-link(segger)
Go to the top of the page
 
+Quote Post
MrAlex
сообщение May 2 2012, 09:21
Сообщение #2


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

Группа: Свой
Сообщений: 197
Регистрация: 15-10-10
Из: г. Москва
Пользователь №: 60 179



Сохранить значения в массив, сохранить область памяти в файл.
Как то так.
Go to the top of the page
 
+Quote Post
sevastianovd
сообщение May 2 2012, 09:29
Сообщение #3


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

Группа: Свой
Сообщений: 78
Регистрация: 8-04-08
Из: Омск
Пользователь №: 36 562



Цитата(MrAlex @ May 2 2012, 15:21) *
Сохранить значения в массив, сохранить область памяти в файл.
Как то так.

потом пробежаться по файлу, перевести hex в dec и в exel....

может кто писал подобный плагин с c-spy sdk?

ps пробовал uProbe (micrium) то, что надо, но не работает параллельно с iar, был бы он плагином sm.gif
Go to the top of the page
 
+Quote Post
KRS
сообщение May 2 2012, 10:46
Сообщение #4


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

Группа: Модераторы
Сообщений: 1 951
Регистрация: 27-08-04
Из: Санкт-Петербург
Пользователь №: 555



IMHO самое простое сохранить прямо в программе нужные данные в файл на компе! при помощи

Код
int f1;
f1 = __open("e:/flash1.bin",_LLIO_CREAT | _LLIO_TRUNC | _LLIO_WRONLY | _LLIO_BINARY);
__write(f1, block, size);
__close(f1);

а на компе мониторить появление файла и т.п. и т.д.
Go to the top of the page
 
+Quote Post
sevastianovd
сообщение May 3 2012, 07:57
Сообщение #5


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

Группа: Свой
Сообщений: 78
Регистрация: 8-04-08
Из: Омск
Пользователь №: 36 562



Цитата(KRS @ May 2 2012, 16:46) *
IMHO самое простое сохранить прямо в программе нужные данные в файл на компе! при помощи

я правильно вас понял, __open и остальные - это макросы c-spy?
получилось у меня так:
CODE
filesave()
{
__var myFileHandle;
__var ii;
myFileHandle=__openFile("$PROJ_DIR$/test.tst", "w");
for(ii=0;ii<128;ii++)
__writeFile(myFileHandle, tmpW[ii]);
__closeFile(myFileHandle);
}
где tmpW-интересующий меня массив.
макрос запускается по точке останова.
вообще штука полезная, большое спасибо за подсказку!
один недостаток - writeFile пишет только числа в hex
Go to the top of the page
 
+Quote Post
KRS
сообщение May 3 2012, 09:45
Сообщение #6


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

Группа: Модераторы
Сообщений: 1 951
Регистрация: 27-08-04
Из: Санкт-Петербург
Пользователь №: 555



Цитата(sevastianovd @ May 3 2012, 11:57) *
я правильно вас понял, __open и остальные - это макросы c-spy?

Нет! через макросы c-spy как раз неудобно из-за формата записи.

Я привел именно кусок программы! IAR позволяет писать и читать файлы на компе прямо из программы через отладчик, механизмы там разные (называется это semihosting), обычно ставится точка останова и дальше отладчик выкачивает/закачивает нужные данные. для программы/пользователя это прозрачно как вызов обычной функции.
посмотрите в доке
EWARM Develompment guide
Part 1 Using the build tools
DLIB runtime enviroment
Application Debug support
Go to the top of the page
 
+Quote Post
sevastianovd
сообщение May 4 2012, 03:35
Сообщение #7


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

Группа: Свой
Сообщений: 78
Регистрация: 8-04-08
Из: Омск
Пользователь №: 36 562



Цитата(KRS @ May 3 2012, 15:45) *
Я привел именно кусок программы!

вот так получилось:
CODE
#include <yfuns.h>
...
for(int i=0;i<128;i++){
dpf_xb.in=(int16_t)...;
sprintf(tmpW[i],"%d\n\0",dpf_xb.in);
...
}
...
int myFileHandle;
int ii;
myFileHandle=__open("$PROJ_DIR$/test.txt", _LLIO_CREAT | _LLIO_TRUNC | _LLIO_WRONLY | _LLIO_TEXT/*BINARY*/);
for(ii=0;ii<128;ii++)
__write(myFileHandle, tmpW[ii],sizeof(unsigned char)*strlen(tmpW[ii]));

__close(myFileHandle);

получаю "удобный" текстовый файл, но время выполнения цикла записи 5,3 сек!
я что-то не так делаю?
Go to the top of the page
 
+Quote Post
KRS
сообщение May 4 2012, 07:45
Сообщение #8


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

Группа: Модераторы
Сообщений: 1 951
Регистрация: 27-08-04
Из: Санкт-Петербург
Пользователь №: 555



Цитата(sevastianovd @ May 4 2012, 07:35) *
получаю "удобный" текстовый файл, но время выполнения цикла записи 5,3 сек!
я что-то не так делаю?

все так. но т.к. данные выкачиваются через отладчик - у вас 128 раз происходит остановка программы и через jtag читаются данные.
что бы ускорить надо писать бинарные данные за 1 раз, а на компе уже парсировать.
Go to the top of the page
 
+Quote Post
sevastianovd
сообщение May 4 2012, 08:32
Сообщение #9


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

Группа: Свой
Сообщений: 78
Регистрация: 8-04-08
Из: Омск
Пользователь №: 36 562



благодарю за помощь!
Go to the top of the page
 
+Quote Post
Nixon
сообщение May 4 2012, 09:36
Сообщение #10


Гуру
******

Группа: Админы
Сообщений: 2 736
Регистрация: 17-06-04
Из: Киев
Пользователь №: 48



Цитата(KRS @ May 4 2012, 10:45) *
все так. но т.к. данные выкачиваются через отладчик - у вас 128 раз происходит остановка программы и через jtag читаются данные.
что бы ускорить надо писать бинарные данные за 1 раз, а на компе уже парсировать.

Не обязательно - достаточно выключить окно лога в иаре (чтобы каждый запуск макроса не отмечался) и вывод делается почти мгновенным.


--------------------
Вам помочь или не мешать?
Go to the top of the page
 
+Quote Post
KRS
сообщение May 4 2012, 12:38
Сообщение #11


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

Группа: Модераторы
Сообщений: 1 951
Регистрация: 27-08-04
Из: Санкт-Петербург
Пользователь №: 555



Цитата(Nixon @ May 4 2012, 13:36) *
Не обязательно - достаточно выключить окно лога в иаре (чтобы каждый запуск макроса не отмечался) и вывод делается почти мгновенным.

так операции через semihosting в лог не попадают, они сами по себе не быстрые. (при реализации через брекпоинт), собственно и макросов в данном случае нет никаких что бы в логе отмечать.
Go to the top of the page
 
+Quote Post
Nixon
сообщение May 4 2012, 13:34
Сообщение #12


Гуру
******

Группа: Админы
Сообщений: 2 736
Регистрация: 17-06-04
Из: Киев
Пользователь №: 48



Странно - у меня пишет в лог, причем все это достаточно медленно, и если окно лога закрыть, то сразу получаем ускорение.
Возможно потому, что у меня все это работает через SWO.
В лог выдается такое сообщение
Код
Fri May 04, 2012 16:36:28: execConfigureTraceSWO()


--------------------
Вам помочь или не мешать?
Go to the top of the page
 
+Quote Post
KRS
сообщение May 4 2012, 13:46
Сообщение #13


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

Группа: Модераторы
Сообщений: 1 951
Регистрация: 27-08-04
Из: Санкт-Петербург
Пользователь №: 555



Цитата(Nixon @ May 4 2012, 17:34) *
Возможно потому, что у меня все это работает через SWO.

Может еще и от железяки зависит, я то использовал еще RDI H-JTAG на ARM7, там через брекпонинт работало в лог ничего не попадало.
Go to the top of the page
 
+Quote Post

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

 


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


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