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

 
 
> Xilinx 7 Series PCIe
doom13
сообщение Jul 1 2015, 06:00
Сообщение #1


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

Группа: Свой
Сообщений: 1 404
Регистрация: 11-03-11
Из: Минск, Беларусь
Пользователь №: 63 539



Приветствую.
Много спрашивал в этой теме, но пока ещё больше вопросов чем ответов. Решил создать свою.
Вот тут очень интересная тема, но мне пока туда рано - надо, чтоб всё заработало с WinDriver.

Пытаюсь разбираться с PCIe на базе Virtex 7, ядром AXI Bridge for PCI Express Gen 3 Subsystem и соответственно с xapp1171. Отдельно завёл DDR3, CDMA. Не могу понять принцип работы собранной в xapp1171 системы (сама система и карта памяти на рисунке). Есть CDMA, а кто им управляет? Правильно ли понимаю, что это должен делать драйвер со стороны компа?
Обязательно ли использовать CDMA? Возможно ли просто подключить к мосту память, чтобы он сам записывал/считывал в/из неё данные? Как понимаю, мост записывает данные в какую-то область памяти (translation_bram), а потом CDMA должен перекинуть их в DDR3.
Эскизы прикрепленных изображений
Прикрепленное изображение
Прикрепленное изображение
 
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
doom13
сообщение Jul 21 2015, 17:25
Сообщение #2


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

Группа: Свой
Сообщений: 1 404
Регистрация: 11-03-11
Из: Минск, Беларусь
Пользователь №: 63 539



Приветствую.
Нужно ещё пояснение по поводу BAR-ов. Может ли PCIe:BAR0 отличаться по размеру от AXI:BAR0? Как понял, это независимые адресные пространства, но проект для разных их размеров собираться не захотел.

Пока собрал систему с GPIO (светодиод), прикрутил его к PCIe:BAR0 и сделал простенький драйвер под Linux, который при запуске зажигает светодиод, при удалении - гасит. Счас хочу добавить прерывание (от таймера), но не пойму, как это прикрутить к мосту PCIe?
У таймера есть выход interrupt, у моста - вход intx_msi_request. Достаточно ли их соединить и запустить таймер, чтоб мост начал генерить прерывания от таймера?
Go to the top of the page
 
+Quote Post
Alexey_Rostov
сообщение Jul 24 2015, 06:22
Сообщение #3


Местный
***

Группа: Свой
Сообщений: 236
Регистрация: 28-06-13
Из: Минск, Беларусь
Пользователь №: 77 312



Цитата(doom13 @ Jul 21 2015, 20:25) *
Приветствую.
Нужно ещё пояснение по поводу BAR-ов. Может ли PCIe:BAR0 отличаться по размеру от AXI:BAR0? Как понял, это независимые адресные пространства, но проект для разных их размеров собираться не захотел.

У меня размеры разные. Все работает.

Цитата
Пока собрал систему с GPIO (светодиод), прикрутил его к PCIe:BAR0 и сделал простенький драйвер под Linux, который при запуске зажигает светодиод, при удалении - гасит. Счас хочу добавить прерывание (от таймера), но не пойму, как это прикрутить к мосту PCIe?
У таймера есть выход interrupt, у моста - вход intx_msi_request. Достаточно ли их соединить и запустить таймер, чтоб мост начал генерить прерывания от таймера?

intx_msi_request (в данном случае legacy интерапт, по импульсу) на этот вход я подаю импульс как только закончена транзакция через pcie в PC (в физ память ПК)


Цитата(doom13 @ Jul 22 2015, 17:05) *
За что тогда отвечает msi_vector_num?

Событийные прерывания. Помимо прерывания еще и указывают, чем это прерывание вызвано. В датащите есть расшифровка
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- doom13   Xilinx 7 Series PCIe   Jul 1 2015, 06:00
- - farbius   Цитата(doom13 @ Jul 1 2015, 09:00) Отдель...   Jul 1 2015, 06:54
|- - doom13   Цитата(farbius @ Jul 1 2015, 09:54) Обяза...   Jul 1 2015, 07:32
|- - farbius   Цитата(doom13 @ Jul 1 2015, 10:32) Или CD...   Jul 1 2015, 07:41
- - doom13   Спасибо, картинка немного вырисовывается. Драйвер ...   Jul 1 2015, 08:19
|- - farbius   Цитата(doom13 @ Jul 1 2015, 11:19) Спасиб...   Jul 1 2015, 09:33
|- - doom13   Цитата(farbius @ Jul 1 2015, 12:33) Очен...   Jul 1 2015, 11:23
||- - farbius   Цитата(doom13 @ Jul 1 2015, 14:23) Вопрос...   Jul 1 2015, 11:38
|- - SnowBuzz   Цитата(farbius @ Jul 1 2015, 12:33) Я на ...   Feb 10 2017, 14:23
- - doom13   Вот тут ещё не совсем понимаю. BAR0, что на рисунк...   Jul 1 2015, 12:11
|- - farbius   Цитата(doom13 @ Jul 1 2015, 15:11) Вот ту...   Jul 1 2015, 12:46
- - doom13   Спасибо понятно. Т.е. PCIe BARs - память в ПЛИС, а...   Jul 1 2015, 13:17
|- - farbius   Цитата(doom13 @ Jul 1 2015, 16:17) Тогда ...   Jul 1 2015, 13:27
- - doom13   Передачу большого потока данных для PCIe всегда бу...   Jul 1 2015, 13:31
|- - farbius   Цитата(doom13 @ Jul 1 2015, 16:31) Переда...   Jul 1 2015, 13:49
|- - doom13   Цитата(farbius @ Jul 1 2015, 16:49) читаю...   Jul 1 2015, 14:10
||- - farbius   Цитата(doom13 @ Jul 1 2015, 17:10) Немног...   Jul 1 2015, 16:24
|- - doom13   Цитата(farbius @ Jul 1 2015, 16:49) А пот...   Oct 15 2015, 06:45
|- - farbius   Цитата(doom13 @ Oct 15 2015, 09:45) Приве...   Oct 15 2015, 07:48
- - doom13   Таймер запустил, выход таймера interrupt повесил н...   Jul 22 2015, 14:05
- - doom13   Вопрос, что всё же подаётся на порт моста msi_vect...   Jul 24 2015, 05:59
- - doom13   Счас ядро сгенерено с опциями (см. рисунок). Означ...   Jul 24 2015, 06:42
|- - farbius   Цитата(doom13 @ Jul 24 2015, 09:42) Означ...   Jul 24 2015, 06:55
|- - doom13   Цитата(farbius @ Jul 24 2015, 09:55) я во...   Jul 24 2015, 07:00
- - doom13   PCI Configuration Space Header содержит поле Intr ...   Jul 27 2015, 12:54
- - doom13   Не могу найти ответ на вопрос: -как система (Linu...   Aug 4 2015, 05:45
- - doom13   Спасибо, просто упёрся в потолок 8.5-8.7 Gbit/s дл...   Oct 15 2015, 08:37
- - EugeneS   QUOTE (doom13 @ Oct 15 2015, 11:37) Спаси...   Oct 20 2015, 07:56


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

 


RSS Текстовая версия Сейчас: 23rd July 2025 - 19:50
Рейтинг@Mail.ru


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