Цитата Сообщение от Lion17 Посмотреть сообщение
Посмотрел схему Пентагона. Процессор имеет приоритет над видео-контроллером. Как только активен MREQ и на шине адреса - оперативка, в следующем такте происходит чтение памяти процессором. Все остальное время каждый такт происходит по очереди чтение атрибутов или пикселей. Так как они считываются асинхронно с границей знакоместа, то сначала они помещаются в буферные регистры, а на границе знакоместа переносятся в регистры вывода, а оттуда попиксельно выталкиваются на экран.

Исходя из выше-сказанного, мерцание пикселей в тесте легко объясняется. Судя по всему за один кадр видео-контроллер успевает считать нечетное количество байт (атрибуты + пиксели). Поэтому, в одном кадре непосредственно после записи #FF в верхний левый угол экрана считываются пиксели (полоска есть), а в другом - считываются атрибуты, а пиксели уже считались до записи (полоски нет).

Код:
Tackts:   17983 |  17984 |  17985
Frame 0: RAT=32 | WRT=FF | RPX=FF (полоска есть)
Frame 1: RPX=00 | WRT=FF | RAT=32 (полоски нет)
RAT - чтение атрибутов, RPX - чтение пикселей, WRT - запись CPU



Получается, что на текущий момент ни один из эмуляторов точно не воспроизводит времянку Пентагона.

Забавно, всегда считал, что эмулировать Пентагон проще всего. Оказалось, наоборот.
Вопрос к хардварщикам. Правильно ли я понимаю, что при обращении к портам ввода-вывода видеоконтроллер Пентагона тоже приостанавливает чтение видеопамяти (т.к. в этот момент шины адреса/данных также заняты процессором, по идее)? И если да, на сколько тактов, на один или на два?