Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Синхронизация внешнего сигнала
Форум разработчиков электроники ELECTRONIX.ru > Программируемая логика ПЛИС (FPGA,CPLD, PLD) > Работаем с ПЛИС, области применения, выбор
alexf
У меня FPGA вся из себя синхронная 200 МГц внутри. И есть некий внешний сигнал у которого есть строб и данные. Строб не чаще 50 МГц. По стробу надо читать данные. Видимо задача расространенная.

Я вижу 2 способа:

1. Стандартно ловися фронт строба и по внутреннему такту защелкиваем данные.

2. Внешний строб защелкивает данные во входной регистр, а когда обнаруживаем фронт строба, по внутреннему такту переписываем в другой регистр.

Оба способа работают и в симуляторе и в чипе, но вопрос к гуру: как правильнее? На вскидку способ 2 точнее в том смысле что hold time менее критичен. При первом способе можем защелкивать через 5 нс после внешнего строба, что не есть хорошо.

Мнения?
Vitёk
Я делал так: по внутренней тактовой защёлкиваются оба сигнала, а потом отслеживается изменение защелкнутого строба - это является СЕ для последующих цепей. Нареканий нет. smile.gif
ASN
alexf
Использовал (и не только я, но и "крутые перцы") второй способ - нет проблем.
Vitёk
Здорово смахивает на синхронизатор для последовательного линка smile.gif.
Проект, кажется, называется - MiniUART.
Vitёk
>Здорово смахивает на синхронизатор для последовательного линка
Наверное, да... smile.gif Хотя - UART, насколько я помню - работает без внешнего строба. А здесь по фронту строба нужно защёлкнуть данные и маякнуть дальнейшей схеме, что принят очередной бит.
То, что я предложил - наверное, ближе к способу "А", только я не понял: alexf по внутренней тактовой защёлкивает только данные, или же данные вместе со стробом. Поэтому и привёл способ целиком. smile.gif
Димыч
Делаю еще так:
по внутреннему тактовому сигналу детектируется строб со всей вытекающей логикой дальнейших действий... А данные сохраняются в асинхронной защелке по активному уровню строба.
Работает.
alexf
Цитата(Димыч @ Feb 10 2005, 04:02)
Делаю еще так:
по внутреннему тактовому сигналу детектируется строб со всей вытекающей логикой дальнейших действий... А данные сохраняются в асинхронной защелке по активному уровню строба.
Работает.
*


Дык это и есть "способ 2" или я чего-то не понял? Вроде так и делаю...
Vitёk
Судя по словам "асинхронная защёлка" речь идёт о защёлке типа LATСH.
alexf
Цитата(Vitёk @ Feb 10 2005, 05:11)
Судя по словам "асинхронная защёлка" речь идёт о защёлке типа LATСH.
*


"по активному уровню строба" наводит на мысль о flip-flop. кроме того я столько раз слышал что в FPGA latch не есть хорошо, что поверил smile.gif

В общем всем спасибо, тема исчерпана.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.