Каким образом HDDM (не ОЗУ!) Доступен, изменен и разрешен в современных компьютерах?
Предупреждение: да, я знаю эту статью в Википедии. Это слишком сложно для меня! Я надеюсь, что есть человек, который мог бы объяснить это проще...
Предыстория: я разработал 6-битный компьютер. Он имеет 4 КБ ОЗУ и 4 КБ ПЗУ (использует двойной адрес). Обе программы доступны и читаются так же, как и другие:
- 12-битный адрес поступает в декодер.
- Декодер декодирует, какая ячейка памяти должна быть доступна.
- Доступ к ячейке памяти и ее содержимое идут на регистрацию А.
Оба строго ограничены. Теперь у нас есть современный 32-битный компьютер. Она имеет:
- 4 ГБ ОЗУ. Ограничено.
- 1 ТБ HDDM, который можно расширить, просто используя больший жесткий диск или несколько жестких дисков!
С ОЗУ все понятно - она читается и модифицируется так же, как на моем компьютере. Но как нам получить доступ к HDDM?
- Нужно ли включать ОГРОМНЫЙ декодер в аппаратное обеспечение современного компьютера, чтобы иметь возможность обрабатывать ОГРОМНОЕ количество отдельных ячеек памяти? Но все-таки память HDD все равно должна быть ограничена определенным объемом памяти?
- Или, может быть, есть крошечные магнитные диски, которые вращаются очень быстро, каждая ячейка памяти излучает свой собственный адрес, и маленькие сканеры ждут, когда диски повернутся в правильное положение для сканирования? Но возможна ли такая скорость?
В общем, так как же мы можем иметь неограниченное количество HDDM? Как получить доступ, прочитать и изменить HDDM?
Дополнительно: доступ к SSDM осуществляется с помощью декодера, поэтому он быстрее, чем HDDM?
1 ответ
Для устройств, которые не имеют прямой адресации, вам не нужно указывать им конкретный адрес, используя фиксированное количество строк, многие устройства позволяют отправлять несколько байтов, описывающих адрес, к которому вы хотите получить доступ. Устройства хранения обычно не имеют адресных линий, связанных с ними, и поэтому реализуют командную шину, которая позволяет отправлять набор байтов, подобный следующему:
- 1-й байт: "Я хочу что-то прочитать, следующие 6 байтов, которые вы получите, будут адресом для чтения"
- 2-й байт: адресный байт 1
- 3-й байт: адресный байт 2
- 4-й байт: адресный байт 3
- 5-й байт: адресный байт 4
- 6-й байт: адресный байт 5
- 7-й байт: адресный байт 6
Затем они уйдут и через некоторое время начнут процесс отправки вам байтов данных, найденных по этому адресу.
Вы также можете переопределить базовое количество "одного блока" данных, чтобы оно отличалось от одного байта (в зависимости от использования памяти). Таким образом, по адресу 0 находится 512-байтовый блок, по адресу 1 - следующий 512-байтовый блок и так далее.
Жесткие диски и т. Д. Используют оба этих метода. То, что вам нужно исследовать, называется логической блочной адресацией.
Это по-прежнему сопряжено с проблемами, аналогичными тем, которые были у нас при переходе с 32-разрядных на 64-разрядные процессоры, старое оборудование пришлось заменить, поскольку оно не могло физически поддерживать новый интерфейс и схему адресации. Предыдущие поколения интерфейса жесткого диска поддерживали только до 137 ГБ хранилища с 28-битным адресом блока, а более новые интерфейсы поддерживают 48-битную адресацию, что позволяет адресовать до 128 ПиБ.
Контроллер и подчиненное устройство должны иметь возможность общаться с использованием более нового стандарта, чтобы они могли поддерживать больший размер. Если один из них просто не может отправить всю необходимую информацию, его необходимо каким-то образом заменить.