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

 
 
> Вопрос по меге dcfifo, откуда лишних два clock'а
tvv
сообщение Jul 6 2005, 15:57
Сообщение #1


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

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



Может я что-то не заметил, но - делаю пустой проект, MegaWizard'ом рожаю двух клоковое fifo, делаю vwf с повторением примера от Wizard и, с удивлением, вижу в симуляторе смещение q от фронта rdreq не на 2 клока, а на 4! sad.gif Quartus 5.0 не web. Для меня эти два клока ой как не лишнии! Может кто с этим dcfifo боролся? Или надо забыть об использовании данной мега и все писать ручками?

Прикрепленное изображение


Прикрепленное изображение

Прикрепленный файл  fifo160.rar ( 3.27 килобайт ) Кол-во скачиваний: 122
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Jenik
сообщение Jul 25 2005, 12:13
Сообщение #2


Участник
*

Группа: Свой
Сообщений: 39
Регистрация: 10-02-05
Пользователь №: 2 554



Цитата(tvv @ Jul 6 2005, 17:57)
Может я что-то не заметил, но - делаю пустой проект, MegaWizard'ом рожаю двух клоковое fifo, делаю vwf с повторением примера от Wizard и, с удивлением, вижу в симуляторе смещение q от фронта rdreq не на 2 клока, а на 4!  sad.gif  Quartus 5.0 не web. Для меня эти два клока ой как не лишнии! Может кто с этим dcfifo  боролся? Или надо забыть об использовании данной мега и все писать ручками?

Прикрепленное изображение


Прикрепленное изображение

Прикрепленный файл  fifo160.rar ( 3.27 килобайт ) Кол-во скачиваний: 122

*


Все просто: вы подали сигнал rdreq во время того, как rdempty был '1'. FIFO игнорирует rdreq если rdempty='1'. Я обычно ползуюсь следующей логикой:

signal q_ready: boolean;

process(clk, resetN)
begin
if resetN='0' then
q_ready<= false;
elsif rising_edge(clk) then
if rdempty='0' and rdreq='1' then
q_ready <= true;
else
q_ready <= false;
end if;
end if;
end process;
.............................
Далее:

if q_ready then
sampled_q <= q;
end if;
Go to the top of the page
 
+Quote Post



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

 


RSS Текстовая версия Сейчас: 21st July 2025 - 07:45
Рейтинг@Mail.ru


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