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

 
 
> Использование bidir портов
prom
сообщение Feb 17 2005, 14:22
Сообщение #1


Участник
*

Группа: Свой
Сообщений: 49
Регистрация: 12-01-05
Пользователь №: 1 912



Такой вопросик возник по ходу работы. Может кто подскажет?

Есть бидир пин. Пусть его зовут data. Также есть два модуля (верилог) - в одном есть порт data (output), в другом порт data (input);

Можно ли подключить пин data к обоим модулям одним wire'ом??? при таком подключении ISE все компилирует и не матерится. Только вот в Assign Package Pins пин data выводится как output. А надо чтобы он был bidir (inout) blink.gif

Если есть такая возможность, то как ее реализовать на верилоге

Если нет, тот как реализовать использование inout пинов в модулях без использования в них (модулях) inout портов???

Заранее спасибо
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
cdg
сообщение Feb 17 2005, 14:55
Сообщение #2


Местный
***

Группа: Свой
Сообщений: 313
Регистрация: 8-09-04
Из: Таганрог
Пользователь №: 617



В модуле с выходным пином надо описать output с присвоением 'z' состояния, а на самом верхнем уровне data_hight_level должен быть описан как bidiractional
Код
module outputpin
...
  output wire data;
....
 
  assign data = (OutEnable) ? DATA : xx'hz;

endmodule

module inputpin
...
  input data;
...
endmodule

module hight_level
...
  inout data_hight_level;
....
   
outputpin my_component_outputpin(
                                                    .data(data_hight_level)
                                                    );

inputpin my_component_inputpin(
                                               .data(data_hight_level)
                                               );
   
endmodule
 


Никаких проблем быть не должно.
Go to the top of the page
 
+Quote Post
prom
сообщение Feb 17 2005, 15:40
Сообщение #3


Участник
*

Группа: Свой
Сообщений: 49
Регистрация: 12-01-05
Пользователь №: 1 912



Цитата(cdg @ Feb 17 2005, 17:55)
В модуле с выходным пином надо описать output с присвоением 'z' состояния, а на самом верхнем уровне data_hight_level должен быть описан как bidiractional
Код
module outputpin
...
  output wire data;
....
 
  assign data = (OutEnable) ? DATA : xx'hz;

endmodule

module inputpin
...
  input data;
...
endmodule

module hight_level
...
  inout data_hight_level;
....
   
outputpin my_component_outputpin(
                                                    .data(data_hight_level)
                                                    );

inputpin my_component_inputpin(
                                               .data(data_hight_level)
                                               );
   
endmodule
 


Никаких проблем быть не должно.
*



пробовал этот вариант, все равно выводит как output
Go to the top of the page
 
+Quote Post
cdg
сообщение Feb 17 2005, 16:08
Сообщение #4


Местный
***

Группа: Свой
Сообщений: 313
Регистрация: 8-09-04
Из: Таганрог
Пользователь №: 617



У меня это работает, правда ISE у меня нет, с Альтерой пока работаю, посему точней сказать не могу, в Synplify все синтезируется корректно, в ISE есть неплохие RTL-viewers, посмотрите, может с управлением что не так, и выход всегда включен, тогда точно такая ситуация будет, а вообще промоделировать не мешало-бы или хотябы в тот-же Synplify загнать код.
Go to the top of the page
 
+Quote Post



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

 


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


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