Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: MAX3000A двунаправленный буффер
Форум разработчиков электроники ELECTRONIX.ru > Программируемая логика ПЛИС (FPGA,CPLD, PLD) > Работаем с ПЛИС, области применения, выбор
4RESTER
Подскажите, почему не работает эта схема в MAX3000A (EPM3032A, EPM3064A)?

В симуляторе (MAX+Plus ][) всё нормально.

Шина данных CPU_D7..CPU_D0, и шина дынных BUS_D7..BUS_D0 с внешними PullUp-ами.
Andron_
соединять выход open-drain, со входом логики? оригинально...

в максе не знаю, в квартусе для этих целей есть буфер tri, за который нужно ставить open-drain, если очень хочется.
sazh
Цитата(4RESTER @ Mar 20 2010, 23:18) *
Шина данных CPU_D7..CPU_D0, и шина дынных BUS_D7..BUS_D0 с внешними PullUp-ами.


Да вроде должна работать. Скорее всего это кусок и не склеивается с другим. (В квартусе есть отличие от макса. Там шина
BUS_D[7]..BUS_D[0])

Код
module ap6_opn
#(parameter width_bus = 1)
(
inout [width_bus-1:0] da,
inout [width_bus-1:0] db,
input                  oe_n,
input                   dir
);

genvar i;
generate for(i=0; i<width_bus; i=i+1)
begin:opn
assign db[i] = ( dir && (oe_n == 1'b0) && (da[i] == 1'b0) )              ? 1'b0 : 1'bz,
       da[i] = ( (dir == 1'b0) && (oe_n == 1'b0) && (db[i] == 1'b0) ) ? 1'b0 : 1'bz;
end
endgenerate

endmodule
VladimirB
Цитата(4RESTER @ Mar 20 2010, 23:18) *
Подскажите, почему не работает эта схема в MAX3000A (EPM3032A, EPM3064A)?

В симуляторе (MAX+Plus ][) всё нормально.

Шина данных CPU_D7..CPU_D0, и шина дынных BUS_D7..BUS_D0 с внешними PullUp-ами.


На высоких частотах она и не должна работать, т.к. pullupы c емкостью шины образуют RC цепочку и получаются долгие переходные процессы.
А вот на постоянке теоретически должна работать.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.