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

 
 
> Разбираюсь с FIFO из Coregen, как его сделать little endian?, Может кто-то уже делал подобное?
Dimonira
сообщение Jun 15 2007, 12:17
Сообщение #1


Местный
***

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



Пишу софт для Ethernet обмена для своей платы с ядром 1Г-МАК от ксайлинкса (см. тут). Проект матрицы сделан на ISE 8.2.
В матрице на приём у меня стоит два ФИФО байтовой ширины по записи и по чтению, а на передачу стоит 4-байтовое на входе (по записи с процессора), а на выходе байтовое (в ядро 1Г-МАК). Все ФИФО с разным тактом по чтению и записи, сгенерированы coregen-ом.
С приёмом всё пучком, а с передачей выяснилось, что ФИФО передаёт в МАК первым байтом старший байт 32-битного слова. Т.е. по факту можно сказать big-endian.
А мне надо бы little-endian, т.к. процессор тоже little-endian (Tiger Shark 201).
Казалось бы ерунда, чего там, взял в проекте матрицы переконнектил байты с шины процессора на вход передающего ФИФО. Однако не так всё просто - после компилляции проект "поплыл", перестал работать не только в части МАКа, но и ещё кое-что накрылось. И это несмотря на то, что согласно репорту par-а всё вроде бы Ок. Странно только, то что в новом проекте используемых слайсов оказалось на 10 меньше чем в старом проекте (1989 против 1999).
Изменения были всего в одной строчке:
Код
// было:
wire [31:0] tx_fifo_data_in = data_fr_dsp;
// стало:
wire [31:0] tx_fifo_data_in = {data_fr_dsp[7:0], data_fr_dsp[15:8], data_fr_dsp[23:16], data_fr_dsp[31:24]};


Вот теперь не знаю как быть. Ну не в софте же переставлять байты, это ж такой гимор и убивание времени, а оно важно.
Начинаю склоняться к тому, чтобы взять исходняки ФИФО, засунуть их в проект (вместо coregen-а) и поправить там последовательность выдачи байтов на обратную. Но посмотрел, там такая каша этих исходняков...

Может кто-то уже это делал?
Или есть другие идеи?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Dimonira
сообщение Jun 19 2007, 06:07
Сообщение #2


Местный
***

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



Пока не удалось собрать все исходняки и скомпиллить проект с только одним ФИФО.
Ну не спец я с этим VHDL. Поэтому прошу знатоков VHDL разобраться.
Для этого я выкладываю проект тут. Пароль архива - имя этого сайта по-русски (без точки ру и типа протокола в начале, т.е. одно слово).
Проблема возникает с элементом b l k m e m d p, в котором часть файлов (все кроме одного) исходняков вроде как для симуляции и в них компиллер ругается на строчку USE IEEE.V I T A L _ T i m i n g . A L L;, говоря, что такого в библиотеке IEEE нету. В тоже время как я понял, V I T A L _ T i m i n g вроде нужен только для симуляции. Непонятно тогда где брать нормальные исходняки.
В директории \X i l i n x\I S E\c o r e g e n\i p\x i l i n x\p r i m a r y\c o m\x i l i n x\i p\b l k m e m d p_ v6 _2\, где лежит эта байда, только зашифрованный файл b l k m e m d p_v 6_2 _x s t_c o m p . v h d, остальные в поддиректории s i m u l a t i o n (незашифрованные). Причём все они же в незашифрованном виде лежат в директории \X i l i n x\I S E\v h d l\s r c\X i l i n x C o r e L i b\.
Возможно, что нужное лежит в файлах с расширением class, но я не знаю чем их открыть. Может кто знает? Вроде это java, но я в ней не спец.

Пояснения по прилагаемому проекту.
Все исходняки лежат в поддиректории проекта FIFO. Дополнительно к исходнякам самого ФИФО я туда положил то, что ещё нужно дополнительно:

\b l k _ m e m _ g e n
\b l k m e m d p
\i p u t i l s
\u l

Причём некоторые файлы (которые PKG) при включении в проект почему-то попадали в закладку исходняков. Поэтому я их удалял из проекта (например, i p u t i l s _ s l v . v h d).
За топовый файл проекта я пока взял файл из директория AS\ (это асинхронное ФИФО): f i f o _ g e n e r a t o r _ v 3 _ 2 _ a s . v h d. А вообще там пять вариантов ФИФО, которые расположены в поддиректориях:

\a s
\f i f o 1 6 _ p a t c h
\f i f o _ 1 8 _ 3 6
\s s
\s s h f t

В поддиректории g o l d e n\ лежат совместно используемые файлы.
Ну, и файлы в директории s i m u l a t i o n\ я добавил на всякий случай.
Прикрепленные файлы
Прикрепленный файл  ____.rar ( 1.22 мегабайт ) Кол-во скачиваний: 63
 
Go to the top of the page
 
+Quote Post

Сообщений в этой теме
- Dimonira   Разбираюсь с FIFO из Coregen, как его сделать little endian?   Jun 15 2007, 12:17
- - reddot   вообще стандартным для всех сетевых протоколов (по...   Jun 15 2007, 12:30
- - Dimonira   Зачем же мне время терять на софтовых перестановка...   Jun 15 2007, 12:41
- - reddot   Ну еще такой вопрос, вы собираетесь по эзернет пер...   Jun 15 2007, 12:53
- - Dimonira   Перестановка байт мне нужна только потому, что я п...   Jun 15 2007, 15:21
- - Evil Archer   Я извиняюсь, но я так и не понял из ваших постов, ...   Jun 16 2007, 23:04
- - Dimonira   Проверял итоговый проект - он перестал нормально р...   Jun 17 2007, 16:34
- - Evil Archer   Если не очень критично, попробуйте вставить регист...   Jun 17 2007, 16:56
- - Dimonira   Конечно критично, ведь регистр - это задержка на т...   Jun 18 2007, 06:04
- - Dimonira   Порылся в исходняках. Нашёл нужное место в файле a...   Jun 18 2007, 10:47
|- - andrew_b   Цитата(Dimonira @ Jun 18 2007, 13:47) Пор...   Jun 18 2007, 12:27
- - Dimonira   Ну как чем?! Вы же тут на форуме бываете, а та...   Jun 18 2007, 17:24
- - Dimonira   Начал рассматривать другой вариант выхода из полож...   Jun 19 2007, 08:20
- - oval   Изначально, столкнувшись с проблемой последователь...   Jun 19 2007, 12:05
- - Dimonira   oval Жаль что раньше не написали. Написали бы, что...   Jun 19 2007, 12:37
- - Dimonira   Вернул ядро ФИФО в оригинальное состояние. Скомпил...   Jun 20 2007, 08:02
- - oval   На разницу в 10 слайсов не стоит обращать внимания...   Jun 20 2007, 11:35
- - Dimonira   Я вообще-то проект так в ISE и делаю, т.е. не отде...   Jun 20 2007, 12:02
- - Evil Archer   Во-первых, Oval справедливо заметил, что нужно поп...   Jun 20 2007, 14:16
- - Dimonira   Всё заработало!!! Причём похоже и рань...   Jun 21 2007, 09:50


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

 


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


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