Телесистемы
 Разработка, производство и продажа радиоэлектронной аппаратуры
На главную   | Карта сайта | Пишите нам | В избранное
Требуется программист в Зеленограде
- обработка данных с датчиков; ColdFire; 40 тыс.
e-mail:jobsmp@pochta.ru

Телесистемы | Электроника | Конференция «Языки описания аппаратуры (VHDL и др.)

Ответ: Вроде так. :) тока у меня предотпускное настроение и внимания ноль.

Отправлено axalay 14 сентября 2009, г. 12:34
В ответ на: Имеем 8-разрядную двунаправленную шину и сигнал ~WR/RD нужно на Verilog написать код запись в регистр из шины по заднему фронту ~CS и ~WR/RD = 0 и чтение из регистра по ~CS при ~WR/RD = 1. При ~CS = 1 шина должа находиться в третьем Z cостоянии! отправлено пользователем Make_Pic 10 сентября 2009, г. 00:40

module test_make (Reset, nCs, nWr_Rd, DataBidir, DataIn, DataOut);

// Global
input Reset;
// Bus
input nCs;
input nWr_Rd;
inout [7:0] DataBidir; wire [7:0] DataBidir;
// user data
input [7:0] DataIn;
output [7:0] DataOut; reg [7:0] DataOut;


wire ReadEna, WriteEna;
assign ReadEna=nWr_Rd;
assign WriteEna=!nWr_Rd;

always @(posedge nCs or negedge Reset)
if (!Reset) begin
DataOut=8'd0;
end //if
else begin
if (WriteEna)
DataOut=DataBidir;
end //else

// можно упростить
assign DataBidir=(nCs)?8'bzzzzzzzz:( (ReadEna)?DataIn:8'bzzzzzzzz );

endmodule //test_make


Составить ответ | Вернуться на конференцию.

Ответы


Отправка ответа
Имя*: 
Пароль: 
E-mail: 
Тема*:

Сообщение:

Ссылка на URL: 
URL изображения: 

если вы незарегистрированный на форуме пользователь, то
для успешного добавления сообщения заполните поле, как указано ниже:
введите число 12:

Перейти к списку ответов | Конференция | Раздел "Электроника" | Главная страница | Карта сайта

Rambler's Top100 Рейтинг@Mail.ru
 
Web telesys.ru