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

 
 
 
Reply to this topicStart new topic
> Отладка прерывания от DMA на STR912
Vladimir_T
сообщение Aug 19 2010, 15:50
Сообщение #1


Знающий
****

Группа: Свой
Сообщений: 517
Регистрация: 7-02-06
Пользователь №: 14 073



Здравствуйте, уважаемые коллеги, отлаживаю работу SPI через DMA. Стал смотреть отладчиком Keil состояние VIC, а отладчик не показывает вообще состояние канала VIC0.12 (прерывания от DMA), тогда как все остальные каналы присутствуют. Подскажите почему такое возможно?
Go to the top of the page
 
+Quote Post
Vladimir_T
сообщение Aug 24 2010, 09:21
Сообщение #2


Знающий
****

Группа: Свой
Сообщений: 517
Регистрация: 7-02-06
Пользователь №: 14 073



При приеме/передаче через SPI с использованием DMA , прерывания от DMA идут нормально. Но не пойму почему значительной прибавки общей производительности не вижу. Т.е. передача по SPI, д.б. параллельно с выполнением основного цикла программы, но реально вижу, что основной цикл программы притормаживается пока не закончится передача по SPI. Бьюсь над тем, чтобы максимально разгрузить процессор, потому и задействовал DMA, а существенного выигрыша нет. Где я заблудился?
Go to the top of the page
 
+Quote Post
Vladimir_T
сообщение Aug 25 2010, 15:56
Сообщение #3


Знающий
****

Группа: Свой
Сообщений: 517
Регистрация: 7-02-06
Пользователь №: 14 073



Разобрался. При использовании DMA для работы с небольшими массивами (до 10 байт) эффективности нет, а при передачи объемов поболее - тут все прекрасно.
Go to the top of the page
 
+Quote Post
demiurg_spb
сообщение Aug 25 2010, 20:02
Сообщение #4


неотягощённый злом
******

Группа: Свой
Сообщений: 2 746
Регистрация: 31-01-08
Из: Санкт-Петербург
Пользователь №: 34 643



Цитата(Vladimir_T @ Aug 25 2010, 19:56) *
Разобрался. При использовании DMA для работы с небольшими массивами (до 10 байт) эффективности нет...
Ну так поделитесь и с остальными. В чём причина неэффективности, в накладных расходах?


--------------------
“Будьте внимательны к своим мыслям - они начало поступков” (Лао-Цзы)
Go to the top of the page
 
+Quote Post
Vladimir_T
сообщение Aug 26 2010, 16:16
Сообщение #5


Знающий
****

Группа: Свой
Сообщений: 517
Регистрация: 7-02-06
Пользователь №: 14 073



В самую точку! Накладные расходы на инициализацию контроллера DMA (ок. 10 мксек) на прием и передачу от SPI оказались сравнимы по времени, как если бы напрямую управлять передачей через SPI. Вот потому для коротких пакетов использование DMA не оправданно.
Мне нужно обрабатывать 24-битное АЦП (на шине SPI) по прерываниям. В прерывании инициируется DMA на прием/передачу и когда DMA закончит транзакции, то выставляет прерывание, по которому данные из АЦП готовы. Данные АЦП подвергаются всяческой обработке. Вот на эту обработку не хватает время. Стал разбираться и понял, что в прерывании от АЦП на инициализацию DMA тратится ок. 10 мксек и напрямую через SPI принять те же 3-байта тоже ок. 10 мксек.
Go to the top of the page
 
+Quote Post
sergeeff
сообщение Aug 26 2010, 21:15
Сообщение #6


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

Группа: Свой
Сообщений: 1 481
Регистрация: 10-04-05
Пользователь №: 4 007



Цитата(Vladimir_T @ Aug 26 2010, 19:16) *
Стал разбираться и понял, что в прерывании от АЦП на инициализацию DMA тратится ок. 10 мксек и напрямую через SPI принять те же 3-байта тоже ок. 10 мксек.


Что-то больно много.
Go to the top of the page
 
+Quote Post
Vladimir_T
сообщение Aug 27 2010, 05:57
Сообщение #7


Знающий
****

Группа: Свой
Сообщений: 517
Регистрация: 7-02-06
Пользователь №: 14 073



Очччень много. Ну как я намерил... Перед инициализацией DMA взвожу вспомогательную ногу, а после инициализации ее сбрасываю. Даже если из этого времени отнять время на сброс сигнала на вспомог. ноге, это время - ок. 7.5 мксек. Тактирование всей периферии на макс. частоте.
Go to the top of the page
 
+Quote Post

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

 


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


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