В компьютерной архитектуре шина (исторически также называемая магистралью данных [1] или шиной данных ) — это система связи, которая передает данные между компонентами внутри компьютера или между компьютерами. [2] Она охватывает как аппаратное обеспечение (например, провода, оптоволокно ), так и программное обеспечение , включая протоколы связи . [3] По своей сути шина — это общий физический путь, обычно состоящий из проводов, дорожек на печатной плате или шин , который позволяет нескольким устройствам обмениваться данными. Чтобы предотвратить конфликты и обеспечить упорядоченный обмен данными, шины полагаются на протокол связи для управления тем, какое устройство может передавать данные в данный момент времени.
Шины классифицируются в зависимости от их роли, например, системные шины (также известные как внутренние шины, внутренние шины данных или шины памяти), соединяющие ЦП и память . Шины расширения , также называемые периферийными шинами , расширяют систему для подключения дополнительных устройств, включая периферийные устройства . Примерами широко используемых шин являются PCI Express (PCIe) для высокоскоростных внутренних соединений и Universal Serial Bus (USB) для подключения внешних устройств.
Современные шины используют как параллельную , так и последовательную связь , применяя передовые методы кодирования для максимизации скорости и эффективности. Такие функции, как прямой доступ к памяти (DMA), еще больше повышают производительность, позволяя передавать данные напрямую между устройствами и памятью без необходимости вмешательства ЦП.
Адресная шина — это шина, которая используется для указания физического адреса . Когда процессору или устройству с поддержкой DMA необходимо выполнить чтение или запись в ячейку памяти, он указывает ячейку памяти на адресной шине (значение для чтения или записи отправляется на шину данных). Ширина адресной шины определяет объем памяти, к которой может обратиться система. Например, система с 32-битной адресной шиной может адресовать 2 32 (4 294 967 296) ячеек памяти. Если каждая ячейка памяти содержит один байт, адресуемое пространство памяти составляет 4 ГБ.
Ранние процессоры использовали провод для каждого бита ширины адреса. Например, 16-битная адресная шина имела 16 физических проводов, составляющих шину. По мере того, как шины становились шире и длиннее, этот подход становился дорогим с точки зрения количества выводов чипа и дорожек платы. Начиная с Mostek 4096 DRAM , мультиплексирование адресов, реализованное с помощью мультиплексоров, стало обычным явлением. В схеме мультиплексированного адреса адрес отправляется двумя равными частями на альтернативных циклах шины. Это вдвое сокращает количество сигналов адресной шины, необходимых для подключения к памяти. Например, 32-битная адресная шина может быть реализована с использованием 16 линий и отправкой первой половины адреса памяти, за которой сразу следует вторая половина адреса памяти.
Обычно два дополнительных контакта на шине управления — строб адреса строки (RAS) и строб адреса столбца (CAS) — используются для того, чтобы сообщить DRAM, отправляет ли адресная шина в данный момент первую половину адреса памяти или вторую половину.
Доступ к отдельному байту часто требует чтения или записи полной ширины шины ( слова ) за один раз. В этих случаях младшие биты адресной шины могут даже не быть реализованы — вместо этого ответственность за изоляцию отдельного требуемого байта из полного переданного слова лежит на управляющем устройстве. Так обстоит дело, например, с локальной шиной VESA , в которой отсутствуют два младших бита, что ограничивает эту шину выровненными 32-битными передачами.
Исторически существовали также некоторые примеры компьютеров, которые могли работать только со словами — словесные машины .
Шина памяти — это шина, которая соединяет основную память с контроллером памяти в компьютерных системах. Первоначально использовались шины общего назначения, такие как VMEbus и S-100 , но для уменьшения задержки современные шины памяти разработаны для прямого подключения к чипам DRAM и, таким образом, определяются органами по стандартизации чипов, такими как JEDEC . Примерами являются различные поколения SDRAM и последовательные шины точка-точка, такие как SLDRAM и RDRAM .
Шины могут быть параллельными шинами , которые передают слова данных параллельно по нескольким проводам, или последовательными шинами , которые передают данные в бит-последовательной форме. Добавление дополнительных соединений питания и управления, дифференциальных драйверов и соединений данных в каждом направлении обычно означает, что большинство последовательных шин имеют больше проводников, чем минимум одного, используемого в 1-Wire и UNI/O . По мере увеличения скорости передачи данных проблемы перекоса синхронизации , энергопотребления, электромагнитных помех и перекрестных помех на параллельных шинах становится все труднее обойти. Одним из частичных решений этой проблемы было двойное накачивание шины. Часто последовательная шина может работать на более высоких общих скоростях передачи данных, чем параллельная шина, несмотря на меньшее количество электрических соединений, поскольку последовательная шина по своей природе не имеет перекоса синхронизации или перекрестных помех. USB , FireWire и Serial ATA являются примерами этого. Многоточечные соединения не работают хорошо для быстрых последовательных шин, поэтому большинство современных последовательных шин используют конструкции с последовательным соединением или концентратором.
Переход от параллельных к последовательным шинам был разрешен законом Мура , который позволил включить SerDes в интегральные схемы, используемые в компьютерах. [4]
Сетевые соединения, такие как Ethernet, обычно не считаются шинами, хотя разница в основном концептуальная, а не практическая. Атрибутом, обычно используемым для характеристики шины, является то, что питание предоставляется шиной для подключенного оборудования. Это подчеркивает шинное происхождение архитектуры шины как подачи коммутируемого или распределенного питания. Это исключает, как шины, такие схемы, как последовательный RS-232 , параллельный Centronics , интерфейсы IEEE 1284 и Ethernet, поскольку этим устройствам также требовались отдельные источники питания. Устройства Universal Serial Bus могут использовать питание, подаваемое шиной, но часто используют отдельный источник питания. Это различие иллюстрируется телефонной системой с подключенным модемом , где соединение RJ11 и связанная с ним модулированная схема сигнализации не считаются шиной и аналогичны соединению Ethernet . Схема подключения телефонной линии не считается шиной в отношении сигналов, но центральный офис использует шины с перекрестными коммутаторами для соединений между телефонами.
Однако это различие — что питание обеспечивается шиной — не относится ко многим авиационным системам , где соединения данных, такие как ARINC 429 , ARINC 629 , MIL-STD-1553B (STANAG 3838) и EFABus ( STANAG 3910 ), обычно называются «шинами данных» или, иногда, «шинами данных». Такие авиационные шины данных обычно характеризуются наличием нескольких устройств или сменных элементов/блоков (LRI/LRU), подключенных к общей, совместно используемой среде . Они могут быть, как в случае с ARINC 429, симплексными , т.е. иметь один источник LRI/LRU, или, как в случае с ARINC 629, MIL-STD-1553B и STANAG 3910, дуплексными , позволяющими всем подключенным LRI/LRU действовать в разное время ( полудуплекс ), как передатчики и приемники данных. [5]
Частота или скорость шины измеряется в Гц, например, МГц, и определяет, сколько тактовых циклов в секунду; за такт может быть одна или несколько передач данных. Если за такт происходит одна передача, это называется одинарной скоростью передачи данных (SDR), а если за такт происходит две передачи, это называется двойной скоростью передачи данных (DDR), хотя использование сигнализации, отличной от SDR, за пределами ОЗУ встречается редко. Примером этого является PCIe, который использует SDR. [6] В каждой передаче данных может быть несколько бит данных. Это описывается как ширина шины, которая представляет собой количество бит, которые шина может передать за такт, и может быть синонимом количества физических электрических проводников, которые есть у шины, если каждый проводник передает один бит за раз. [7] [8] [9] Скорость передачи данных в битах в секунду можно получить, умножив количество бит за такт, на частоту, на количество передач за такт. [10] [11] В качестве альтернативы шина, такая как PCIe, может использовать модуляцию или кодирование, например PAM4 [12] [13] [14] , которое группирует 2 бита в символы, которые затем передаются вместо самих битов, и позволяет увеличить скорость передачи данных без увеличения частоты шины. Эффективная или реальная скорость/скорость передачи данных может быть ниже из-за использования кодирования, которое также позволяет исправлять ошибки, например, кодирование 128/130b (b для бита). [15] [16] [17] Скорость передачи данных также известна как пропускная способность. [18] [19]
Простейшая системная шина имеет полностью отдельные входные линии данных, выходные линии данных и адресные линии. Для снижения стоимости большинство микрокомпьютеров имеют двунаправленную шину данных, повторно используя одни и те же провода для ввода и вывода в разное время. [20]
Некоторые процессоры используют выделенный провод для каждого бита адресной шины, шины данных и шины управления. Например, 64-контактная STEbus состоит из 8 физических проводов, выделенных для 8-битной шины данных, 20 физических проводов, выделенных для 20-битной адресной шины, 21 физического провода, выделенного для шины управления, и 15 физических проводов, выделенных для различных шин питания.
Мультиплексирование шины требует меньше проводов, что снижает затраты во многих ранних микропроцессорах и чипах DRAM. Одна из распространенных схем мультиплексирования, мультиплексирование адреса, уже упоминалась. Другая схема мультиплексирования повторно использует контакты шины адреса в качестве контактов шины данных, [20] подход, используемый обычными PCI и 8086. Различные «последовательные шины» можно рассматривать как конечный предел мультиплексирования, отправляя каждый из бит адреса и каждый из бит данных, по одному за раз, через один контакт (или одну дифференциальную пару).
Со временем над различными стандартами компьютерных шин работали несколько групп людей, включая Комитет по стандартам архитектуры шины IEEE (BASC), исследовательскую группу IEEE «Superbus», Инициативу по открытым микропроцессорам (OMI), Инициативу по открытым микросистемам (OMI), «Банду девяти», разработавшую EISA , и т. д. [ необходима ссылка ]
Ранние компьютерные шины представляли собой пучки проводов, соединявших компьютерную память и периферийные устройства. В раннем австралийском компьютере CSIRAC их называли « цифровой магистралью » [21] , они были названы в честь электрических шин питания или шин . Почти всегда была одна шина для памяти и одна или несколько отдельных шин для периферийных устройств. К ним обращались с помощью отдельных инструкций с совершенно разными синхронизациями и протоколами.
Одним из первых осложнений было использование прерываний . Ранние компьютерные программы выполняли ввод-вывод , ожидая в цикле готовности периферийного устройства. Это было пустой тратой времени для программ, у которых были другие задачи. Кроме того, если программа пыталась выполнить эти другие задачи, ей могло потребоваться слишком много времени для повторной проверки, что приводило к потере данных. Таким образом, инженеры организовали так, чтобы периферийные устройства прерывали работу ЦП. Прерываниям нужно было назначить приоритет, поскольку ЦП может выполнять код только для одного периферийного устройства за раз, а некоторые устройства более критичны ко времени, чем другие.
Высокопроизводительные системы представили идею контроллеров каналов , которые по сути были небольшими компьютерами, предназначенными для обработки ввода и вывода заданной шины. IBM представила их на IBM 709 в 1958 году, и они стали общей чертой их платформ. Другие высокопроизводительные поставщики, такие как Control Data Corporation, реализовали аналогичные конструкции. Как правило, контроллеры каналов делали все возможное, чтобы выполнять все операции шины внутри, перемещая данные, когда было известно, что ЦП занят в другом месте, если это возможно, и используя прерывания только при необходимости. Это значительно снижало нагрузку на ЦП и обеспечивало лучшую общую производительность системы.
Для обеспечения модульности шины памяти и ввода-вывода могут быть объединены в единую системную шину . [22] В этом случае для соединения многих компонентов системы, а в некоторых случаях и всех компонентов, может использоваться единая механическая и электрическая система.
Позже компьютерные программы начали совместно использовать память, общую для нескольких ЦП. Доступ к этой шине памяти также должен был быть приоритетным. Простым способом приоритизации прерываний или доступа к шине было последовательное подключение . В этом случае сигналы будут естественным образом проходить через шину в физическом или логическом порядке, устраняя необходимость в сложном планировании.
Корпорация Digital Equipment Corporation (DEC) еще больше снизила стоимость для массовых мини-компьютеров и сопоставила периферийные устройства с шиной памяти, так что устройства ввода и вывода выглядели как ячейки памяти. Это было реализовано в Unibus PDP -11 около 1969 года. [23]
Ранние системы шин микрокомпьютеров по сути представляли собой пассивную объединительную плату , подключенную напрямую или через буферные усилители к контактам ЦП . Память и другие устройства добавлялись к шине с использованием тех же адресов и контактов данных, которые использовал сам ЦП, подключенных параллельно. Связь контролировалась ЦП, который считывал и записывал данные с устройств, как будто они были блоками памяти, используя те же инструкции, все синхронизировалось центральным тактовым генератором, управляющим скоростью ЦП. Тем не менее, устройства прерывали ЦП, подавая сигналы на отдельные контакты ЦП.
Например, контроллер дисковода сигнализировал ЦП о том, что новые данные готовы к считыванию, после чего ЦП перемещал данные, считывая «ячейку памяти», соответствующую дисководу. Почти все ранние микрокомпьютеры были построены таким образом, начиная с шины S-100 в компьютерной системе Altair 8800 .
В некоторых случаях, особенно в IBM PC , хотя может использоваться схожая физическая архитектура, инструкции для доступа к периферийным устройствам ( in
и out
) и памяти ( mov
и другие) вообще не были унифицированы и по-прежнему генерируют отдельные сигналы ЦП, которые можно использовать для реализации отдельной шины ввода-вывода.
Эти простые системы шин имели серьезный недостаток при использовании для компьютеров общего назначения. Все оборудование на шине должно было общаться с одинаковой скоростью, поскольку оно использовало один и тот же тактовый генератор.
Увеличение скорости ЦП становится сложнее, поскольку скорость всех устройств также должна увеличиваться. Когда непрактично или экономически невыгодно, чтобы все устройства были такими же быстрыми, как ЦП, ЦП должен либо перейти в состояние ожидания , либо временно работать на более низкой тактовой частоте, [24] чтобы взаимодействовать с другими устройствами в компьютере. Хотя это приемлемо во встраиваемых системах , эта проблема не терпела долго в универсальных компьютерах, расширяемых пользователем.
Такие системы шин также трудно настраивать, если они построены из обычного готового оборудования. Обычно каждая добавленная карта расширения требует много перемычек для установки адресов памяти, адресов ввода-вывода, приоритетов прерываний и номеров прерываний.
Системы шин «второго поколения», такие как NuBus, решали некоторые из этих проблем. Они обычно разделяли компьютер на два «мира»: ЦП и память с одной стороны и различные устройства с другой. Контроллер шины принимал данные со стороны ЦП для перемещения на сторону периферии, тем самым снимая нагрузку протокола связи с самого ЦП. Это позволяло ЦП и стороне памяти развиваться отдельно от шины устройства или просто «шины». Устройства на шине могли общаться друг с другом без вмешательства ЦП. Это приводило к гораздо лучшей производительности «реального мира», но также требовало, чтобы карты были намного сложнее. Эти шины также часто решали проблемы скорости, будучи «больше» с точки зрения размера пути данных, переходя от 8-битных параллельных шин в первом поколении к 16- или 32-битным во втором, а также добавляя настройку программного обеспечения (теперь стандартизированную как Plug-n-play ) для замены или вытеснения перемычек.
Однако эти новые системы разделяли одно качество со своими более ранними собратьями, а именно то, что все на шине должны были общаться с одинаковой скоростью. В то время как ЦП теперь был изолирован и мог увеличивать скорость, ЦП и память продолжали увеличивать скорость намного быстрее, чем шины, с которыми они общались. Результатом стало то, что скорости шин теперь были намного медленнее, чем требовалось современной системе, и машины остались голодными по данным. Особенно распространенным примером этой проблемы было то, что видеокарты быстро обогнали даже более новые системы шин, такие как PCI , и компьютеры начали включать AGP только для управления видеокартой. К 2004 году AGP снова переросла высокопроизводительные видеокарты и другие периферийные устройства и была заменена новой шиной PCI Express .
Все большее число внешних устройств также начали использовать свои собственные системы шин. Когда впервые появились дисководы, они добавлялись к машине с помощью карты, вставленной в шину, поэтому компьютеры имеют так много слотов на шине. Но в 1980-х и 1990-х годах были введены новые системы, такие как SCSI и IDE, чтобы удовлетворить эту потребность, оставив большинство слотов в современных системах пустыми. Сегодня в типичной машине, вероятно, будет около пяти различных шин, поддерживающих различные устройства. [ необходима цитата ]
Шины «третьего поколения» появляются на рынке примерно с 2001 года, включая HyperTransport и InfiniBand . Они также, как правило, очень гибкие с точки зрения их физических соединений, что позволяет использовать их как внутренние шины, а также для соединения разных машин вместе. Это может привести к сложным проблемам при попытке обслуживания разных запросов, поэтому большая часть работы над этими системами касается проектирования программного обеспечения, а не самого оборудования. В целом, эти шины третьего поколения, как правило, больше похожи на сеть, чем на первоначальную концепцию шины, с более высокими накладными расходами протокола, необходимыми, чем ранние системы, а также позволяя нескольким устройствам использовать шину одновременно.
Такие шины, как Wishbone, были разработаны сторонниками открытого исходного кода в попытке еще больше устранить правовые и патентные ограничения при проектировании компьютеров.
Compute Express Link (CXL) — это открытое стандартное соединение для высокоскоростного обмена данными между ЦП и устройством и между ЦП и памятью, разработанное для ускорения производительности центров обработки данных следующего поколения . [25]
Многие полевые шины представляют собой последовательные шины данных (не путать с параллельной частью «шины данных» системной шины или платы расширения ), некоторые из которых используют электрические характеристики RS-485 , а затем определяют свой собственный протокол и разъем:
Другие серийные автобусы включают в себя:
Внутренняя компьютерная шина представляет собой параллельную схему передачи; внутри компьютера....