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

 
 
 
Reply to this topicStart new topic
> Многоразрядный таймер, Синхронное считывание
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
Bad0512
сообщение Feb 27 2012, 09:49
Сообщение #2


Знающий
****

Группа: Свой
Сообщений: 802
Регистрация: 11-05-07
Из: Томск
Пользователь №: 27 650



Цитата(Serhiy_UA @ Feb 27 2012, 16:39) *
Таймер и какая-то FSM синхронизируются от 100МГц. Таймер имеет нано-, микро-, мили- и секундные поля.

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

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

А в чём тут собственно проблема? Таймер - это обычный двоичный счётчик. Довольно большой разрядности, но это не так уж и страшно на частоте 100 МГц.
FSM и этот счётчик работают на одной и той же частоте, соответственно временной анализ учитывает пути между выходом таймера и входом FSM. Всё синхронно,
тут не может быть никаких гонок. Могут не соблюдаться немного тайминги, но это лечится известными способами.Гонки возникают при асинхронщине, а тут всё должно быть шито-крыто.
Go to the top of the page
 
+Quote Post
Boris_TS
сообщение Feb 27 2012, 10:48
Сообщение #3


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

Группа: Свой
Сообщений: 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
billidean
сообщение Feb 28 2012, 13:13
Сообщение #4


Местный
***

Группа: Свой
Сообщений: 247
Регистрация: 4-10-10
Из: г. Екатеринбург
Пользователь №: 59 925



Цитата(Serhiy_UA @ Feb 27 2012, 12:39) *
Как лучше считать на лету значение таймера в FSM, чтобы не нарваться на гонки, т.е. на еще незавершившийся в таймере переходной процесс?


Есть еще решение - двойная буферизация, т.е. будете иметь значение счетчика с опозданием на два такта, но это есть вариант обычно для синхронизации двух процессов на разных частотах. Но для Вас тоже должно подойти.
На счет гонок на частоте 100МГц - тоже оччень сомневаюсь, хотя... wacko.gif
Go to the top of the page
 
+Quote Post

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

 


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


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