Стандарты шины ввода / вывода и контроллеры устройств

Я действительно запутался в таких стандартах шины, как ide, ata, sata, pci и т. Д.

Я только что прочитал эту статью: когда происходит чтение или запись на диск, куда идут данные? Так что, если мы говорим о жестком диске; Жесткая логическая плата содержит микроконтроллер, буферную память, драйвер двигателя и т. д. Этот микроконтроллер связывается с драйвером двигателя для чтения и записи секторов на жесткие диски. Как я знаю, микроконтроллер представляет собой комбинацию процессора, регистров, портов ввода-вывода, оперативной памяти и т. д. Также внутри микроконтроллера должна быть прошивка.

Мой первый вопрос: как определяется тактовая частота жесткого диска микроконтроллера?

И в соответствии с вышеупомянутой статьей, почему существует такое слово, как "диск sata"? Я имею в виду, если "ata" или "sata" и т. Д. Являются просто шинными интерфейсами между процессором и контроллерами устройств, почему слова "ata", "sata" или "pci" становятся префиксом для периферийных устройств?

Я действительно хочу глубоко понять связь с периферийными устройствами. Выше статьи я понял, что когда мы хотим прочитать секторы с жесткого диска, возникают две отдельные связи: первая - между "процессор - контроллер устройства", а вторая - "контроллер устройства - жесткий диск". как эти отдельные коммуникации работают друг с другом?

Наконец, если "ata" или "sata" являются интерфейсами, которые просто обозначают шлюз связи "cpu&memory(dma)-device controller", то почему этот интерфейс медленнее, чем передняя сторона шины (fsb)? Я имею в виду, если я говорю о передаче dma, после того, как контроллер диска считывает один сектор с жесткого диска, он должен перевести этот сектор в память, верно? Так почему эти медленные интерфейсы шины используются для связи между памятью и контроллерами устройств?

1 ответ

Решение

Я действительно запутался в таких стандартах шины, как ide, ata, sata, pci и т. Д.

Вы должны отделить PCI от ATA, SATA и IDE.
ATA, SATA и IDE не являются такой же шиной, как PCI.

Мой первый вопрос: как определяется тактовая частота жесткого диска микроконтроллера?

Это решение основано на том, что является экономически эффективным по сравнению с тем, какой уровень производительности требуется.

И в соответствии с вышеупомянутой статьей, почему существует такое слово, как "диск sata"? Я имею в виду, если "ata" или "sata" и т. Д. Являются просто шинными интерфейсами между процессором и контроллерами устройств, почему слова "ata", "sata" или "pci" становятся префиксом для периферийных устройств?

SATA и ATA являются интерфейсами, а не "шинными интерфейсами".

Он используется в качестве прилагательного для обозначения типа интерфейса, который имеет периферийное устройство, и того, что требуется на стороне хост-компьютера.
Если у вас есть "диск SATA" и на материнской плате вашего компьютера нет свободных портов SATA, вы не сможете подключить его. Если есть другие неиспользуемые интерфейсы (например, слот PCI, порт IDE или порт USB), то вы можете использовать соответствующий адаптер (с дополнительными затратами и, возможно, снижением производительности).

Я понял, что когда мы хотим прочитать секторы с жесткого диска, возникают две отдельные связи, первая - между "процессор - контроллер устройства", а вторая - "контроллер устройства - жесткий диск". Так как эти отдельные коммуникации работают друг с другом?

Контроллер устройства находится в середине обеих этих операций.
Современный контроллер диска, который встроен в дисковод SATA, имеет свой собственный ЦП (он же микроконтроллер), ОЗУ и флэш-память и выполняет свою собственную прошивку для выполнения своих функций.

Кстати, у вас есть поток данных на 100% в обратном направлении. Для считываемого сектора с диска первая передача - "hdd -> контроллер устройства", а затем вторая передача - "контроллер устройства -> хост".
Также "передача данных" является более точным описанием операции, чем "связь".

Наконец, если "ata" или "sata" - это интерфейсы, которые просто обозначают коммуникационный шлюз "cpu&memory(dma)-device controller", почему этот интерфейс медленнее, чем передняя шина (fsb)?

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

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

Я имею в виду, если я говорю для передачи DMA, после того, как контроллер диска читает один сектор с жесткого диска, он должен перенести этот сектор в память, верно?

Периферийный интерфейс, такой же быстрый, как FSB, через гибкий кабель длиной 0,25 м может стоить в 1000 раз дороже. Соотношение затрат и выгод является низким, поскольку улучшается только одна фаза многофазной передачи данных.

Так почему же эти медленные интерфейсы шины используются для связи между памятью и контроллерами устройств?

Стоимость.
Чтобы еще больше сбить вас с толку, эти периферийные интерфейсы не подключаются напрямую к "памяти" (как вы писали несколько раз). Обычно сторона хоста такого интерфейса подключается к локальной системной шине, чтобы либо ЦП (использующий PIO), либо контроллер DMA могли получить доступ к регистру данных интерфейса.
Может быть, это слишком много деталей для вас, но, возможно, именно эта нехватка деталей и упрощение способствуют путанице.

Другие вопросы по тегам