Перейти к содержанию
    

Прерывание DMA TMS320VC5509A

DMA канал постоянно пересылает данные на последовательный порт и в определенный момент перестают генерироваться прерывания по этому каналу. При этом сам канал продолжает передавать данные и прерывания с других DMA каналов работают в штатном режиме. Все биты разрешающие прерывания по данному каналу установлены ( INTM, IER0/1, DMACICR). Флаги статуса (SYNC, HALF, FRAME) расположенные в DMACSR имеют значение 1.

В чем может быть причина пропадания прерывания?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

поподробнее о том сколько DMA,McBSP и др периферии и как конретно настроено.......

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

поподробнее о том сколько DMA,McBSP и др периферии и как конретно настроено.......

Использую DSP/BIOS. Загрузка проца до 60 %. Активно работает USB + один McBSP (CLK до 12Мгц) и два DMA его обслуживает ( один на прием , другой на передачу). Управление передачей данных по McBSP происходит по прерываниям DMA (HALF, FRAME). Прерывания от DMA происходят примерно раз в 100 мкс.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

1. Надо смотреть не загрузку проца, а загрузку шин

2. какой приоритет у DMA?

3. USB используют DMA ? два Endpoint однозначно используют и приоритет выше чем DMA-controller, а остальные Endpoint?

4. Сколько времени тратится на обработку каждого прерывания, включая USB, DMA и другой периферии?

5. Есть ли прерывания, которые обрабатываюся более 100 мкс? Проверить осциллом в режиме запоминания в течении длительного времени

6. Или может суммарно все прерывания могут перевалить за 100 мкс в какой-либо момент времени?

7. Отключи USB и проверь будет ли отпадывать прерывания без него

8. Где-то видал расчет загрузки шин дсп в зависимости от включенной периферии, но не могу найти

 

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Использую DSP/BIOS. Загрузка проца до 60 %. Активно работает USB + один McBSP (CLK до 12Мгц) и два DMA его обслуживает ( один на прием , другой на передачу). Управление передачей данных по McBSP происходит по прерываниям DMA (HALF, FRAME). Прерывания от DMA происходят примерно раз в 100 мкс.

Странно у вас как-то построено....

DMA обычно используется для уменьшения частоты прерываний. Для этого стараются увеличить размер блока.

У вас же вижу частота прерываний очень высокая (10кГц). Зачем так - пересылать всего по неск. байт?

И это при том, что у DSP вход/выход в ISR обычно требуют сохранения/восстановления большого контекста. Подозреваю что значительная часть из 60% загрузки у вас тратится именно на сохранения/восстановления контекста в ISR.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

1. Надо смотреть не загрузку проца, а загрузку шин

2. какой приоритет у DMA?

3. USB используют DMA ? два Endpoint однозначно используют и приоритет выше чем DMA-controller, а остальные Endpoint?

4. Сколько времени тратится на обработку каждого прерывания, включая USB, DMA и другой периферии?

5. Есть ли прерывания, которые обрабатываюся более 100 мкс? Проверить осциллом в режиме запоминания в течении длительного времени

6. Или может суммарно все прерывания могут перевалить за 100 мкс в какой-либо момент времени?

7. Отключи USB и проверь будет ли отпадывать прерывания без него

8. Где-то видал расчет загрузки шин дсп в зависимости от включенной периферии, но не могу найти

 

Я вполне могу допустить, что у меня прерывания могут "налезать" друг на друг. Но разве это или сбой по шине может привести к полному прекращению появления одного из прерывания и при этом ни по какому биту/флагу мы это не сможем определить?

А есть какой-нибудь флаг, который показывает что произошел сбой передачи по шине ? Случайно не BERR(Bus Error interrupt) для этого используется ?

 

Странно у вас как-то построено....

DMA обычно используется для уменьшения частоты прерываний. Для этого стараются увеличить размер блока.

У вас же вижу частота прерываний очень высокая (10кГц). Зачем так - пересылать всего по неск. байт?

И это при том, что у DSP вход/выход в ISR обычно требуют сохранения/восстановления большого контекста. Подозреваю что значительная часть из 60% загрузки у вас тратится именно на сохранения/восстановления контекста в ISR.

Возможна передача/прием коротких пакетов, на которые надо быстро реагировать. Но возможно действительно стоит увеличить размер блока немного пожертвовав скоростью реакции.

Большая часть загрузки у меня все-таки тратиться на обработку принятых пакетов ( фильтрация и т.п.). Без обработки пакетов загрузка cpu с учетом dsp/bios 10-15% .

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Случайно не BERR(Bus Error interrupt) для этого используется ?

В том числе для этого и создано

но для 5509А как-то мало описания

в 5502 есть регистр Time-Out Control Register (TOCR) для этих целей, а в 5509А его не нашел

 

зато в ДМА DMACICR/DMACSR есть биты TIMEOUTIE/TIMEOUT и DROPIE/DROP, которые можно проанализировать

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

В том числе для этого и создано

но для 5509А как-то мало описания

в 5502 есть регистр Time-Out Control Register (TOCR) для этих целей, а в 5509А его не нашел

 

зато в ДМА DMACICR/DMACSR есть биты TIMEOUTIE/TIMEOUT и DROPIE/DROP, которые можно проанализировать

Я тоже не особо много информации насчет BERR нашел, поэтому и появились сомнения насчет него. Но я проверял флаг BERR у меня он не выставляется при пропадание прерывания.

 

TIMEOUTIE/TIMEOUT и DROPIE/DROP тоже проверял. Данные флаги не устанавливаются и прерывания по ним не срабатывают.

 

 

 

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Bus error возникает, когда происходит обращение к адресу в I/O space, которого нет физически, когда процессор обращается не с той шины не в ту область ОЗУ (например с шины BB/BAB во внешнее ОЗУ), ну и т.п., и к DMA прямого отношения не имеет.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.

Гость
К сожалению, ваш контент содержит запрещённые слова. Пожалуйста, отредактируйте контент, чтобы удалить выделенные ниже слова.
Ответить в этой теме...

×   Вставлено с форматированием.   Вставить как обычный текст

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

×
×
  • Создать...