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

 
 
 
Reply to this topicStart new topic
> Подскажите как сделать в veriloge задержку
Вано
сообщение Jul 26 2006, 14:10
Сообщение #1


Участник
*

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



Подскажите, как в verilog -е сделать задержку сигнала на половину длительности тактового импульса?

Сообщение отредактировал Вано - Jul 26 2006, 14:10
Go to the top of the page
 
+Quote Post
Kopart
сообщение Jul 26 2006, 14:17
Сообщение #2


Знающий
****

Группа: Свой
Сообщений: 601
Регистрация: 1-03-05
Из: Spb
Пользователь №: 2 972



Цитата(Вано @ Jul 26 2006, 18:10) *
Подскажите, как в verilog -е сделать задержку сигнала на половину длительности тактового импульса?


Это схоже с проблемой деления на логике тактовой НЕ на степень 2-ки (например 3)

А самый очевидный вариант синтезируемой задержки - использовать 2-ух кратную тактовую (на PLL) smile.gif


--------------------
Насколько проще была бы жизнь, если бы она была в исходниках
Go to the top of the page
 
+Quote Post
Вано
сообщение Jul 26 2006, 14:21
Сообщение #3


Участник
*

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



Цитата(NiOS @ Jul 26 2006, 18:17) *
Цитата(Вано @ Jul 26 2006, 18:10) *

Подскажите, как в verilog -е сделать задержку сигнала на половину длительности тактового импульса?


Это схоже с проблемой деления на логике тактовой НЕ на степень 2-ки (например 3)

А самый очевидный вариант синтезируемой задержки - использовать 2-ух кратную тактовую (на PLL) smile.gif

К сожалению pll трогать нельзя, необходимо программно сделать без использования настроек генератора.
Черт побери, сигнал возникает на пол таката раньше , чем нужно, может быть есть еще мнения?
Go to the top of the page
 
+Quote Post
o-henry
сообщение Jul 26 2006, 14:22
Сообщение #4


Местный
***

Группа: Свой
Сообщений: 435
Регистрация: 8-03-06
Из: степей Украины
Пользователь №: 15 069



Цитата(Вано @ Jul 26 2006, 17:10) *
Подскажите, как в verilog -е сделать задержку сигнала на половину длительности тактового импульса?


На половину длительности тактового импульса?
Или на половину периода тактового импульса?
Go to the top of the page
 
+Quote Post
Doka
сообщение Jul 26 2006, 14:28
Сообщение #5


Electrical Engineer
******

Группа: СуперМодераторы
Сообщений: 2 163
Регистрация: 4-10-04
Пользователь №: 778



Цитата(Вано @ Jul 26 2006, 18:21) *
К сожалению pll трогать нельзя, необходимо программно сделать без использования настроек генератора.
Черт побери, сигнал возникает на пол таката раньше , чем нужно, может быть есть еще мнения?


есть.. принимать не по фронту тактовой, а по срезу =)
(или наоборот)

ЗЫ: а вообще хотелось бы более подробного описания - сигал приходит совсем асинхронно?! с другой мксх/платы?
Go to the top of the page
 
+Quote Post
Вано
сообщение Jul 26 2006, 14:28
Сообщение #6


Участник
*

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



Цитата(o-henry @ Jul 26 2006, 18:22) *
Цитата(Вано @ Jul 26 2006, 17:10) *

Подскажите, как в verilog -е сделать задержку сигнала на половину длительности тактового импульса?


На половину длительности тактового импульса?
Или на половину периода тактового импульса?


Под длительностью имею в виду периода.
Go to the top of the page
 
+Quote Post
o-henry
сообщение Jul 26 2006, 14:50
Сообщение #7


Местный
***

Группа: Свой
Сообщений: 435
Регистрация: 8-03-06
Из: степей Украины
Пользователь №: 15 069



Можно сделать удвоитель частоты, как в этой статье:
http://www.xilinx.com/xlnx/xweb/xil_tx_dis..._ID=pa_six_easy
Надеюсь, поможет.
Go to the top of the page
 
+Quote Post
Golikov A.
сообщение Jul 26 2006, 16:44
Сообщение #8


Гуру
******

Группа: Свой
Сообщений: 4 256
Регистрация: 17-02-06
Пользователь №: 14 454



Цитата(Вано @ Jul 26 2006, 18:28) *
Цитата(o-henry @ Jul 26 2006, 18:22) *

Цитата(Вано @ Jul 26 2006, 17:10) *

Подскажите, как в verilog -е сделать задержку сигнала на половину длительности тактового импульса?


На половину длительности тактового импульса?
Или на половину периода тактового импульса?


Под длительностью имею в виду периода.


Если пол периода, то тогда работать не по CLK='1' and CLK'Event, а по CLK='0' and CLK'Event, ну это в VHDL, но в верилоге тоже должна быть возможность работать по падающему фронту или нет?

можно следить за состоянием сигнала по падающему фронту, и когда он станет 1, то по восходящему его обработать будет задержка как раз на полпериода.
Go to the top of the page
 
+Quote Post
Kopart
сообщение Jul 27 2006, 06:18
Сообщение #9


Знающий
****

Группа: Свой
Сообщений: 601
Регистрация: 1-03-05
Из: Spb
Пользователь №: 2 972



Если тактовая не с PLL - то и дальше "от нее" желательно работать по спаду. (А то в общем случае скважность может изменятся)

В Verilog тоже просто ( @(negedge CLK) )


--------------------
Насколько проще была бы жизнь, если бы она была в исходниках
Go to the top of the page
 
+Quote Post
TailWind
сообщение Aug 3 2006, 13:22
Сообщение #10


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

Группа: Свой
Сообщений: 125
Регистрация: 15-11-04
Пользователь №: 1 135



initial
begin
...
#Period/2;
Signal = Value;
...
end
Go to the top of the page
 
+Quote Post
hlebn
сообщение Aug 3 2006, 18:30
Сообщение #11


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

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



Цитата(TailWind @ Aug 3 2006, 17:22) *
initial
begin
...
#Period/2;
Signal = Value;
...
end

это только для модели пойдет.
при синтезе игнорируется
Go to the top of the page
 
+Quote Post

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

 


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


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