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

 
 
 
Reply to this topicStart new topic
> Constraint для clock domain crossing в Altera
Winger11
сообщение Nov 20 2015, 14:17
Сообщение #1





Группа: Новичок
Сообщений: 2
Регистрация: 26-01-10
Пользователь №: 55 077



Есть модуль, который принимает данные на одной частоте, отдает на другой. Оба клока (155 и 250 МГц) порождаются внутри схемы - один внутри Ethernet PHY, второй внутри PCIe-IP. Quartus выдает дикие слэки - больше 5нс, из которых около 80% приходится на clock delay (ровно 5нс, еще примерно 0.8нс - data delay). Пробовал разные констрейны, результат не меняется:

//Запихиваю длинные пути к клокам, на которые ругается Quartus, в переменные
set clk1 system|wrapper_mux_avl_2ch|phy_10gbaser_inst|...|g_fpll.altera_pll_156M~PLL_OUTP
UT_COUNTER|divclk
set clk2 system|pcie_256_dma|altera_s5_a2p|altpcie_hip_256_pipen1b|stratixv_hssi_gen3_pci
e_hip|coreclkout

//Вариант 1:
set_false_path -from [get_clocks {$clk1}] -to [get_clocks {$clk2}]

//Вариант 2:
set_clock_groups -exclusive -group {$clk1} -group {$clk2}

Подскажите, пожалуйста, что я делаю не так.
Qusrtus 14, Stratix V
Go to the top of the page
 
+Quote Post
des00
сообщение Nov 20 2015, 14:43
Сообщение #2


Вечный ламер
******

Группа: Модераторы
Сообщений: 7 248
Регистрация: 18-03-05
Из: Томск
Пользователь №: 3 453



Цитата(Winger11 @ Nov 20 2015, 22:17) *
Оба клока (155 и 250 МГц)
Подскажите, пожалуйста, что я делаю не так.

Вы не корректно делаете CDC. клоки асинхронные и не кратные. Используйте FIFO/RAM.


--------------------
Go to the top of the page
 
+Quote Post
Timmy
сообщение Nov 20 2015, 15:11
Сообщение #3


Знающий
****

Группа: Участник
Сообщений: 835
Регистрация: 9-08-08
Из: Санкт-Петербург
Пользователь №: 39 515



Цитата(Winger11 @ Nov 20 2015, 17:17) *
set_false_path -from [get_clocks {$clk1}] -to [get_clocks {$clk2}]

//Вариант 2:
set_clock_groups -exclusive -group {$clk1} -group {$clk2}

Ваши констрейны не работают. Макроподстановка изнутри {} не выполняется. В данном случае можно писать без фигурных скобок, так как списки из одного элемента. Если нужно больше элементов, то использовать команду list:
неправильно: [get_clocks {$clk1 $clk2}]
правильно: [get_clocks [list $clk1 $clk2]]
А вообще, чтобы отчёты выглядели красиво, по возможности следует руками описать все клоки, взяв команды из листинга derive_pll_clocks.

Ещё, чуть не забыл: если вдруг значение clk1 внутри содержит пробелы, то без [list] оно будет ошибочно принято за список и неверно интерпретировано, так что на всякий случай [list] стоит использовать даже для списка из одного элемента. [list] правильно прикроет пробелы внутри clk1 эскейп последовательностями, и пробелы не будут интерпретироваться, как разделители списка.

Сообщение отредактировал Timmy - Nov 20 2015, 15:33
Go to the top of the page
 
+Quote Post
des333
сообщение Nov 22 2015, 10:58
Сообщение #4


Профессионал
*****

Группа: Свой
Сообщений: 1 129
Регистрация: 19-07-08
Из: Санкт-Петербург
Пользователь №: 39 079



Цитата(Timmy @ Nov 20 2015, 18:11) *
неправильно: [get_clocks {$clk1 $clk2}]
правильно: [get_clocks [list $clk1 $clk2]]


Можно еще так: [get_clocks "$clk1 $clk2"]
Кавычки, в отличие от фигурных скобок, разрешают подстановку.

Но лучше, всё-таки, с list.
Как Вы правильно написали, избавит от проблем, если значения переменных содержат пробелы.


--------------------
Go to the top of the page
 
+Quote Post
Winger11
сообщение Nov 23 2015, 10:03
Сообщение #5





Группа: Новичок
Сообщений: 2
Регистрация: 26-01-10
Пользователь №: 55 077



Цитата(des00 @ Nov 20 2015, 17:43) *
Вы не корректно делаете CDC. клоки асинхронные и не кратные. Используйте FIFO/RAM.


Я, возможно, не совсем корректно выразился - в самом модуле, где происходит перетактовка, у меня, конечно же, стоит двухпортовая память.

Цитата(Timmy @ Nov 20 2015, 18:11) *
Ваши констрейны не работают. Макроподстановка изнутри {} не выполняется. В данном случае можно писать без фигурных скобок, так как списки из одного элемента. Если нужно больше элементов, то использовать команду list:
неправильно: [get_clocks {$clk1 $clk2}]
правильно: [get_clocks [list $clk1 $clk2]]
А вообще, чтобы отчёты выглядели красиво, по возможности следует руками описать все клоки, взяв команды из листинга derive_pll_clocks.

Ещё, чуть не забыл: если вдруг значение clk1 внутри содержит пробелы, то без [list] оно будет ошибочно принято за список и неверно интерпретировано, так что на всякий случай [list] стоит использовать даже для списка из одного элемента. [list] правильно прикроет пробелы внутри clk1 эскейп последовательностями, и пробелы не будут интерпретироваться, как разделители списка.


Большое спасибо - помогло!
Go to the top of the page
 
+Quote Post

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

 


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


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