Ну хз..
хочеш головняков - лови
Есть допустим такие варианты работы
В общем есть одно вакантное место на режим, тот который щас пень4, нада что то придумать из популярного на замещение этого места.// Mem model
parameter Pentagon128 = 0;
//parameter Pentium4VI = 1 ???????????????????????
parameter Pentagon512 = 2;
parameter Scropion256 = 3;
parameter Kay256 = 4;
parameter Kay1024 = 5;
parameter Quorum128 = 6;
parameter P1024SL = 7;
.........
// IO Decoder
wire WriteFE = (!IOWRn && EA == 16'bxxxx_xxxx_xxxx_xxx0);
wire Write7FFD = (!IOWRn &&
(MMODE == Quorum128) ? EA == 16'b0xxx_xxxx_xxx1_1x0x :
(MMODE == Kay256) ? EA == 16'b01xx_xxxx_xxxx_xx01 :
(MMODE == Kay1024) ? EA == 16'b01xx_xxxx_xxxx_xx01 :
(MMODE == Scropion256) ? EA == 16'b01xx_xxxx_xx1x_xx01 :
EA == 16'b0xxx_xxxx_xxxx_xx0x // Pentagon
);
wire WriteEFF7 = (!IOWRn && EA == 16'b1110_xx11_1xxx_0111);
wire Write1FFD = (!IOWRn &&
(MMODE == Kay256) ? EA == 16'b00xx_xxxx_xxxx_xx01 :
(MMODE == Kay1024) ? EA == 16'b00xx_xxxx_xxxx_xx01 :
(MMODE == Scropion256) ? EA == 16'b00xx_xxxx_xx1x_xx01 :
1'b1 // Disable
);
............
// Page detector
reg [5:0] PAGE;
always @ *
begin
case (MMODE)
Pentagon512 : PAGE = {1'b0, P7FFD[7:6], P7FFD[2:0]};
Scropion256 : PAGE = {2'b00, P1FFD[4], P7FFD[2:0]};
Kay256 : PAGE = {2'b00, P1FFD[4], P7FFD[2:0]};
Kay1024 : PAGE = {P7FFD[6], P1FFD[6], P1FFD[4], P7FFD[2:0]};
P1024SL : PAGE = (M128) ?
{3'b000, P7FFD[2:0]} :
{P7FFD[7:5], P7FFD[2:0]};
default : PAGE = {3'b000, P7FFD[2:0]};
endcase
end
wire Page5 = EA[15:13] == 3'b010 || (EA[15:13] == 3'b110 && PAGE == 5);
wire Page7 = EA[15:13] == 3'b110 && PAGE == 7;
Заодно если есть желание свериться со схемами на правильное детектирование портов и разбитовку.
Добавлено через 6 минут
Тю блин Quote вместо Code написал![]()
Последний раз редактировалось ZEK; 12.02.2009 в 17:53. Причина: Добавлено сообщение
Тут возможно глупость сморожу, по крайней мере оцените реальность этого заблуждения.
Скажем пока применительно к Спектруму.
Имеем два буфера(каждый на строку). В один буфер сначала пишем пиксели с частотой 7МГц, а второй выводит инфу с удвоенной частотой.
Тоесть за время записи в один буфер второй отобразит два раза.
Затем по окончанию строчного импульса происходит переключение буферов и сброс счетчиков синхрогенератора.
Ну и так далее процесс повторяется. Естественно для VGA частот надо собрать синхрогенератор(строчная и кадровая частота).
По реализации допустим нужно две микросхемы типа 132РУ8(1024x4) с временем доступа 60нс, несколько счетчиков, кучка мультиплексоров ну и логика по вкусу. Вход цветов, если не цифра, то компараторы.
Ну а на выход, стандартный набор с эммитерными повторителями.
С любовью к вам, Yandex.Direct
Размещение рекламы на форуме способствует его дальнейшему развитию
Я рассуждал о внешнем устройстве.
Эту тему просматривают: 1 (пользователей: 0 , гостей: 1)