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

 
 
> Вопрос по AVR32AP7000 USBA с DMA..., Вопрос по AVR32AP7000 USBA с DMA...
cipher
сообщение Sep 25 2007, 11:59
Сообщение #1





Группа: Новичок
Сообщений: 6
Регистрация: 13-07-07
Пользователь №: 29 104



Не получается добиться работы USBA с DMA. Плата NGW100. Переписал драйвер от линукса. Без DMA всё работает с DMA получается только LOOPBACK, т.е. что принял, то и отправил (при этом внутри МК данных не видно).
Проблема в том, что при приёме с DMA данные куда-то записываются, но куда - я не знаю. При этом в dmaaddress записан например такой адрес 0x10306d40, но по этому адресу никаких изменений не происходит. Если при передаче указать этот же адрес, то данные уйдут корректно.
В MMUCR - 0x00000010 - транслируются только сегменты. Вроде в остальном MMU выключен.
Есть какая-то трансляция памяти или кэширование, но я не знаю по какой причине.
Помогите советом.
Заранее большое спасибо.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
singlskv
сообщение Sep 25 2007, 18:02
Сообщение #2


дятел
*****

Группа: Свой
Сообщений: 1 681
Регистрация: 13-05-06
Из: Питер
Пользователь №: 17 065



Цитата(cipher @ Sep 25 2007, 15:59) *
Не получается добиться работы USBA с DMA. Плата NGW100. Переписал драйвер от линукса. Без DMA всё работает с DMA получается только LOOPBACK, т.е. что принял, то и отправил (при этом внутри МК данных не видно).
Проблема в том, что при приёме с DMA данные куда-то записываются, но куда - я не знаю. При этом в dmaaddress записан например такой адрес 0x10306d40, но по этому адресу никаких изменений не происходит. Если при передаче указать этот же адрес, то данные уйдут корректно.
В MMUCR - 0x00000010 - транслируются только сегменты. Вроде в остальном MMU выключен.
Есть какая-то трансляция памяти или кэширование, но я не знаю по какой причине.
Помогите советом.
Заранее большое спасибо.
Скорее всего проблема с кешированием, DMA вероятно нужно запускать на некешируемой
области, к сожалению на AVR32 до этого момента еще не дошел, но то что Вы описываете,
когда в одну сторону не работает а в другую работает, ИМХО это кеш.

А если вместо 0x10306d40 указать 0x90306d40 ???
Go to the top of the page
 
+Quote Post
cipher
сообщение Sep 26 2007, 09:57
Сообщение #3





Группа: Новичок
Сообщений: 6
Регистрация: 13-07-07
Пользователь №: 29 104



Цитата(singlskv @ Sep 25 2007, 21:02) *
А если вместо 0x10306d40 указать 0x90306d40 ???


Я пробовал так делать - никакой разницы. Так как включена трансляция сегментов, то оба адреса проецируются в один и тот же физический адрес.
Go to the top of the page
 
+Quote Post
singlskv
сообщение Sep 26 2007, 15:27
Сообщение #4


дятел
*****

Группа: Свой
Сообщений: 1 681
Регистрация: 13-05-06
Из: Питер
Пользователь №: 17 065



Цитата(cipher @ Sep 26 2007, 13:57) *
Я пробовал так делать - никакой разницы. Так как включена трансляция сегментов, то оба адреса проецируются в один и тот же физический адрес.
Как это точно реализованно на AVR32 я еще не разбирался, но
на некоторых других процах такое разделение адресов сделано специально,
т.е. например 0x1xxxxxxx кешируемая область а 0x9xxxxxxx некешируемая, и при этом
физический адрес один и тотже.
Go to the top of the page
 
+Quote Post
cipher
сообщение Sep 27 2007, 12:28
Сообщение #5





Группа: Новичок
Сообщений: 6
Регистрация: 13-07-07
Пользователь №: 29 104



Вроде всё заработало.
Нигде не нашёл подробного описания команды CACHE. Для DCACHE есть варианты: invalidate, clear, flash и различные их комбинации. Какая между ними разница?
Есть некэшируемая область памяти с A0000000 512 МБ. В этой области тоже всё работает. Не знаю пока как оценить эффект от использования кэша. Может он и не нужен мне совсем.
Go to the top of the page
 
+Quote Post



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

 


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


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