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

 
 
> Многоразрядный таймер, Синхронное считывание
Serhiy_UA
сообщение Feb 27 2012, 09:39
Сообщение #1


Знающий
****

Группа: Свой
Сообщений: 721
Регистрация: 23-10-08
Из: next to Odessa
Пользователь №: 41 112



Таймер и какая-то FSM синхронизируются от 100МГц. Таймер имеет нано-, микро-, мили- и секундные поля.

Как лучше считать на лету значение таймера в FSM, чтобы не нарваться на гонки, т.е. на еще незавершившийся в таймере переходной процесс?
Простейшее решение, перед считыванием приостановить таймер на время достаточное для завершения гонок, считать код в FSM, и опять включить. Но здесь есть как бы небольшие потери для таймера, а как без потерь?

Вопрос все же более теоретический…

Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Boris_TS
сообщение Feb 27 2012, 10:48
Сообщение #2


Злополезный
****

Группа: Свой
Сообщений: 608
Регистрация: 19-06-06
Из: Russia Taganrog
Пользователь №: 18 188



Цитата(Serhiy_UA @ Feb 27 2012, 13:39) *
Но здесь есть как бы небольшие потери для таймера, а как без потерь?
Вопрос все же более теоретический…

Этот вопрос решён практически давным-давно: для того, чтобы было "без потерь" необходимо использовать Synchronous counter, а не Asynchronous (ripple) counter.
Для ускорения работы синхронных счётчиков большой разрядности в FPGA применяются специализированные схемы быстрого переноса.

P.S. Асинхронщина для FPGA противоестественна. Конечно, можно делать асинхронные схемы - но т.к. они противоестественны, то в большинстве случаев себе дороже.
Go to the top of the page
 
+Quote Post



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

 


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


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