Автор Тема: Зеркала RAM в NES  (Прочитано 4073 раз)

0 Пользователей и 1 Гость просматривают эту тему.

Оффлайн feos

  • Пользователь
  • Сообщений: 786
  • Пол: Мужской
    • Просмотр профиля
Зеркала RAM в NES
« : 03 Ноябрь 2010, 23:30:04 »
Цитата
Начиная с адреса $0800 из-за неполной дешифрации адреса, идут три «зеркала» оперативной памяти RAM

Что такое неполная дешифрация адреса, и зачем эти зеркала?
В наличии их убедился благодаря RAM Search, выдающему для каждой искомой ячейки по 3 ее копии.

Оффлайн iddqd

  • Пользователь
  • Сообщений: 5885
  • Пол: Мужской
  • murderforkill
    • Просмотр профиля
Re: Зеркала RAM в NES
« Ответ #1 : 04 Ноябрь 2010, 00:13:55 »
Могу помочь только этой ссылкой: http://forum.emu-russia.net/viewtopic.php?f=13&t=2117

Оффлайн MetalliC

  • Технический консультант
  • Сообщений: 9386
  • Пол: Мужской
  • Demul team / MAME developer
    • Просмотр профиля
Re: Зеркала RAM в NES
« Ответ #2 : 04 Ноябрь 2010, 00:46:59 »
feos, для упрощения схемотехники,
факт доступа к РАМ определяется по старшим трем битам (A13-A15), если они = 0
младшие 11 бит (A0-A10) - адрес в РАМ
оставшиеся два бита в середине (A11 и А12) тупо не используются

Оффлайн feos

  • Пользователь
  • Сообщений: 786
  • Пол: Мужской
    • Просмотр профиля
Re: Зеркала RAM в NES
« Ответ #3 : 19 Июнь 2011, 02:05:30 »
Объяснение на пальцах от АнСа:

На любой адрес в архитектуре Денди отводится 16 битов.
Вот визуально представим их, обозначив место каждого бита буквой.
A B C D E F G H I J K L M N O P - 16 позиций
Например, вот так в двоичном виде можно представить число $FFFE (адрес в РОМе, где хранится указатель на процедуру IRQ):
1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 0

Вот в Memory Viewer (сейчас он называется Hex Editor) ты видишь всё адресное пространство от 0000 до FFFF. А на самом деле физически такого цельного пространства на приставке нет. Есть отдельная плата с оперативной памятью, есть плата постоянной памяти (в пластмассовом картридже), и есть порты видео/звука, которые вообще даже памятью не являются, а в пространстве процессора они обозначены только для лёгкого доступа.

Всё содержимое окна Hex Editor составляется на лету из нескольких источников. На самой приставке нету такого массива размером 65536 байтов, который ты скроллируешь в этом окне.


Так вот, когда процессор получает 16 битов некоего адреса, ему надо их расшифровать и определить, к какому виду памяти это относится (ОЗУ, ПЗУ, порты, а может вообще SRAM для сэйва). Так что процессор по первым нескольким битам определяет тип устройства, а по оставшимся битам - адрес ячейки внутри этого устройства.

Расшифровка идёт слева направо (со старшего бита к младшему).
Если самый первый бит (на позиции A, см. выше) равен единице, то мы явно имеем дело с ROM, так что отбрасываем старший бит и оставшиеся 15 битов являются адресом ячейки на картридже. В итоге на картридже можно адресовать 0000-7FFF - это 32 килобайта. Если 32к игре мало, она использует мапперы, ловко подменяя содержимое этих тридцати двух килобайтов.

Но если бит на позиции A равен нулю, то надо расшифровывать дальше.
Берём бит на позиции B. Если он равен единице то мы имеем дело либо с портами звуковухи, либо с карточкой сохранения (это уже определяется по биту на позиции C - если он равен 1, то используем SRAM, если 0, то APU).
А вот если бит B равен нулю, то мы имеем дело либо с оперативной памятью, либо с портами видеокарты. Это можно определить по биту C - если он равен 1, то используем PPU, если 0, то RAM.

Итак, если бит A равен 0, бит B равен 0, бит C равен 0, то мы точно определились, что имеем дело с RAM. Оставшиеся 13 битов являются адресом ячейки в оперативке.
Но физически оперативной памяти только 2 килобайта (и в эмуляторе тоже для ОЗУ отводится массив в 2048 байт), и любое число в диапазоне от 0 до 7FF можно записать с помощью одиннадцати битов.
Так что значение битов D и E не принимается в расчёт при доступе к ячейке ОЗУ. Эти два бита могут быть любыми, а конечный адрес определяется битами FGHIJKLMNOP (но только если ABC = 000).

Так вот, допустим, "FGHIJKLMNOP" - это адрес жизней босса, ну 0x589. То есть в двоичном это "10110001001". Как можно указать процессору на этот адрес? Ну, во-первых, три старших бита обязаны быть нулями, чтобы процессор изначально отправил сигнал вправо по материнке, где микросхемы памяти, а не налево, где картридж торчит, и не вниз, где PPU.
Во-вторых, из оставшихся 13 битов младшие одиннадцать должны быть равны "10110001001", чтобы указать точный адрес в ОЗУ.
В-третьих... а третьих нет. Биты D и E игнорируются.

В итоге можно адресовать эту пятьсот восемьдесят девятую ячейку четырьмя шестнадцатибитными адресами:
000 00 10110001001
000 01 10110001001
000 10 10110001001
000 11 10110001001
И это всё будет та же самая ячейка 0x589.

Возьмём последний адрес - 0001110110001001. Если перевести его в хекс, то это будет 1D89. И в хексредакторе по адресу 0x1D89 ты видишь то же самое значение, что и в 589. Но если запишешь в эту ячейку своё число, то эмулятор (как и реальный процессор Денди) отбросит значения битов D и E (в данном случае они оба равны единице), и запишет твоё новое значение не в ячейку 1D89 (такой ячейки просто нет в массиве RAM, в нём только ячейки с 0 до 7FF), а в ячейку 589.
При этом в самом хексредакторе одновременно с 589 обновится и ячейка 1D89, так как хексредактор когда рисует на экране цифры тоже в уме игнорирует D и E. Рисуя значение ячейки 1D89 он смотрит на ячейку 0x589 в массиве RAM. В итоге эта ячейка 1D89 существует только у тебя на экране в момент обновления картинки, а внутри эмулятора хранится только ячейка 589.

Оффлайн gepar

  • Пользователь
  • Сообщений: 10150
  • Пол: Мужской
  • ▂ ▃ ▄ ▅ ▆ ▇ █
    • Просмотр профиля
Re: Зеркала RAM в NES
« Ответ #4 : 19 Июнь 2011, 13:42:50 »
feos,действительно на пальцах, интересно  :)

Оффлайн perfect_genius

  • Пользователь
  • Сообщений: 1173
    • ВКонтакте
    • Steam
    • Просмотр профиля
Re: Зеркала RAM в NES
« Ответ #5 : 27 Июнь 2011, 00:26:12 »
feos, можно ссылку на источник?

Оффлайн feos

  • Пользователь
  • Сообщений: 786
  • Пол: Мужской
    • Просмотр профиля
Re: Зеркала RAM в NES
« Ответ #6 : 27 Июнь 2011, 18:08:02 »
SUPER_ROBOT, источник - личка моя на сайте тасвидеос. ^_^