[an error occurred while processing this directive]
много раз спрашивал, нашел ответ по замене log2
(«Телесистемы»: Конференция «Языки описания аппаратуры (VHDL и др.))

миниатюрный аудио-видеорекордер mAVR

Отправлено MAZZI 06 сентября 2004 г. 12:56

Много раз звучало сообщение от меня и других, как реализовать функцию log2, зная значение модуля счета, глубины памяти и т.д. на Verilog.
Во-первых, оказалось что в Verilog 2001 такие вещи предусматриваются, однако не все синтезаторы такое поддерживают, а именно Constant Function.
Нашел в IEEE Std 1364-2001 (10.3.5 Use of constant functions), там есть пример.
Немного полегче реализация той же функции:
function integer f_clogb2;
//Входы
input [31:0] value; //Значение глубины шины
//Цикл функции
for (f_clogb2= 0; value > 0; f_clogb2= f_clogb2+ 1)
value = value >> 1;
endfunction //MaZZi'S ZoNE
Теперь самое интересное, какие синтезаторы поддерживают Constant Function? Из двух рассмотреных Symplify 7.6.1, Xilinx XST ISE 6.2, заработало только на Symplify 7.6.1, т.ч. юзайте :)

Составить ответ  |||  Конференция  |||  Архив

Ответы


Отправка ответа

Имя (обязательно): 
Пароль: 
E-mail: 

Тема (обязательно):
Сообщение:

Ссылка на URL: 
Название ссылки: 

URL изображения: 


Перейти к списку ответов  |||  Конференция  |||  Архив  |||  Главная страница  |||  Содержание  |||  Без кадра

E-mail: info@telesys.ru