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

 
 
2 страниц V  < 1 2  
Reply to this topicStart new topic
> Проблема с синтезом. Память под Synplify 8.2.1
id_gene
сообщение Nov 29 2005, 14:35
Сообщение #16


carpe manana
***

Группа: Свой
Сообщений: 321
Регистрация: 2-06-05
Пользователь №: 5 659



Цитата
Но верилог разрешает использование обоих фронтов для запуска олвайза!! Или я не прав..?


верилог разрешает, а синтез - нет. Синтезируемое подмножество использует небольшое количество всех возможных конструкций.
В частности, always@(posedge clk) синтезируется в триггер.
always @ (clk) реагирует на уровень.

Насчет смешивания блокирующих/неблокирующих- это я поторопился. Для разных сигналов такое возможно. Только очень осторожно, и блокрирующие присвоения в триггерах не рекомендуются.
Go to the top of the page
 
+Quote Post
stalko
сообщение Nov 29 2005, 19:21
Сообщение #17


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

Группа: Свой
Сообщений: 139
Регистрация: 5-05-05
Из: Зеленоград
Пользователь №: 4 762



Цитата(des00 @ Nov 29 2005, 17:19) *
ИМХО always@(GCLK) по уровню smile.gif (сколько себя помню всегда так было),

Нафиг все, работа без выходных на голову таки воздействует!!
Покажу это сообщение начальнику, пусть в отпуск пускает.
Цитата(des00 @ Nov 29 2005, 17:19) *
а если по фронту то always@(posedge GCLK)
это не ВХДЛ,

это по ПЕРЕДНЕМУ фронту smile.gif . А мне хотелось бы по обоим, а Synplify конструкцию posedge GCLK or negedge GCLK не любит. sad.gif
Цитата(des00 @ Nov 29 2005, 17:19) *
насчет списка чувствительности, это из симуляторов, то что у казанно в алвейса и есть sensivity list, т.е. те сигнал по изменению которых запускаеться процесс удачи

Смысл простой... зато название какое!! biggrin.gif


Цитата(id_gene @ Nov 29 2005, 17:35) *
Насчет смешивания блокирующих/неблокирующих- это я поторопился. Для разных сигналов такое возможно. Только очень осторожно, и блокрирующие присвоения в триггерах не рекомендуются.

Смешать разные присвоения не даст синтезатор и тут он прав, он вообще не любит смешения синхронности и асинхронности.
Дело в том, что в том случае мы проверяем {A,A_C}, а потом делаем A_C=A;
Если мы запишем A_C<=A, то они уже на момент проверки будут равны. Значит, либо нужно унести присвоение в границы результата проверки, что в данном случае некоректно, либо ставить небокирующие.
Поправьте меня, если я заблуждаюсь.

P.S. Сказал про ассинхронность, и вспомнил: как-то он нефиг делать попробовал сделать RS-триггер с помощью assign-ов, только на wire-ах. И ведь получилось!! smile.gif
Go to the top of the page
 
+Quote Post
andrew_b
сообщение Nov 30 2005, 06:42
Сообщение #18


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

Группа: Свой
Сообщений: 1 975
Регистрация: 30-12-04
Из: Воронеж
Пользователь №: 1 757



Цитата(stalko @ Nov 29 2005, 22:21) *
Цитата(des00 @ Nov 29 2005, 17:19) *

а если по фронту то always@(posedge GCLK)
это не ВХДЛ,

это по ПЕРЕДНЕМУ фронту smile.gif . А мне хотелось бы по обоим, а Synplify конструкцию posedge GCLK or negedge GCLK не любит. sad.gif

Вы в праве хотеть все, что угодно. Однако ваше желание упирается в возможности FPGA. Как вы себе представляете реализацию
Код
always (GCLK)
       if (GCLK == 0)
          MEM[A_MEM] <= DIN[15:8];
       else
          MEM[A_MEM+1]<= DIN[7:0];

Память не работает по двум фронтам.
Go to the top of the page
 
+Quote Post
dxp
сообщение Nov 30 2005, 06:44
Сообщение #19


Adept
******

Группа: Свой
Сообщений: 3 469
Регистрация: 6-12-04
Из: Novosibirsk
Пользователь №: 1 343



Цитата(des00 @ Nov 29 2005, 20:19) *
Цитата(stalko @ Nov 29 2005, 09:04) *

Или Вы хотите сказать, что у меня окончательно стекла крыша, и always@(GCLK) указывает, что работать по уровню, а не по обоим фронтам? Ну, в таком случае, мне самому уже пора звонить на "скорую"... Либо, наконец, выбить хоть маленький, крохотный отпуск...


ИМХО always@(GCLK) по уровню smile.gif (сколько себя помню всегда так было),
а если по фронту то always@(posedge GCLK)
это не ВХДЛ,

always@(GCLK) - это по любому событию. По факту это соответствует комбинационной логике.

Цитата(des00 @ Nov 29 2005, 20:19) *
насчет списка чувствительности, это из симуляторов, то что у казанно в алвейса и есть sensivity list, т.е. те сигнал по изменению которых запускаеться процесс

В Верилог-2001 задавать список для комбинационных схем не требуется, можно просто писать always @(*) или always @*. Компилятор дальше сам разберется, что к чему исходя из контекста описания тела блока.


--------------------
«Отыщи всему начало, и ты многое поймёшь» К. Прутков
Go to the top of the page
 
+Quote Post

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

 


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


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