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

 
 
 
Reply to this topicStart new topic
> Организация bursttransfer для Slave-компонента
Shevnnov
сообщение Sep 21 2010, 05:29
Сообщение #1


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

Группа: Участник
Сообщений: 85
Регистрация: 8-04-10
Из: Нижний Новгород
Пользователь №: 56 498



Всем добрый день,
Возникла необходимость оптимизировать передачу данных по шине от собственного компонента. Данные приходят обычно по-многу, так что по 4 байта выбирать их через стандартный интерфейс не разумно.
Читая документацию более менее разобрался с сигналами, но до конца не понял какие должен обеспечивать компонент, а какие шина Avalon.
И второй главный вопрос: как програмно реализовать в драйвере выборку данных процессором в память (сейчас я это делаю через IOWR_, IORD_)
Go to the top of the page
 
+Quote Post
barabek
сообщение Sep 21 2010, 05:44
Сообщение #2


Знающий
****

Группа: Свой
Сообщений: 540
Регистрация: 16-08-07
Из: Владивосток
Пользователь №: 29 831



1 какие конкретно?
2.Вы про DMA-компонент спрашиваете?
Go to the top of the page
 
+Quote Post
Shevnnov
сообщение Sep 21 2010, 10:22
Сообщение #3


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

Группа: Участник
Сообщений: 85
Регистрация: 8-04-10
Из: Нижний Новгород
Пользователь №: 56 498



Нет. Пока DMA не трогаю. Суть вопроса - как организовать програмный доступ к компоненту, чтобы Nios мог выбирать данные из внутренней памяти компонента и записывать себе куда-то.
Go to the top of the page
 
+Quote Post
vadimuzzz
сообщение Sep 21 2010, 11:21
Сообщение #4


Гуру
******

Группа: Свой
Сообщений: 2 291
Регистрация: 21-07-05
Пользователь №: 6 988



Цитата(Shevnnov @ Sep 21 2010, 12:29) *
Всем добрый день,
Возникла необходимость оптимизировать передачу данных по шине от собственного компонента. Данные приходят обычно по-многу, так что по 4 байта выбирать их через стандартный интерфейс не разумно.
Читая документацию более менее разобрался с сигналами, но до конца не понял какие должен обеспечивать компонент, а какие шина Avalon.
И второй главный вопрос: как програмно реализовать в драйвере выборку данных процессором в память (сейчас я это делаю через IOWR_, IORD_)

если данные приходят помногу, то читать процессором неразумно. делайте dma.
Avalon-MM Slave должен обеспечить readdata и readdatavalid(если используется), все остальное обеспечит проц. iowr/iord - это правильный способ доступа к периферии. но грузить этим ядро не стоит, делайте сразу dma
Go to the top of the page
 
+Quote Post
Shevnnov
сообщение Sep 21 2010, 12:23
Сообщение #5


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

Группа: Участник
Сообщений: 85
Регистрация: 8-04-10
Из: Нижний Новгород
Пользователь №: 56 498



Хорошо, спасибо за совет. Про дма я знаю, но пока рано на этом этапе его делать. Готовые решения не подходят, так как это потом всё пойдет в комерческий проект. Так что придется самому писать ДМА контроллер. Просто стало интересно можно ли потоком процу считывать.
Go to the top of the page
 
+Quote Post
vadimuzzz
сообщение Sep 21 2010, 13:02
Сообщение #6


Гуру
******

Группа: Свой
Сообщений: 2 291
Регистрация: 21-07-05
Пользователь №: 6 988



ничего там сложного нет, вот посмотрите примерчик http://www.altera.com/support/examples/nio...celeration.html

все потоковые пересылки так или иначе задействуют dma. нет ничего более унылого, чем вычитывать процом данные из какого-нибудь регистра и складывать их в буфер.
Go to the top of the page
 
+Quote Post

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

 


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


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