HDLC
High-Level Data Link Control (HDLC) — бит-ориентированный[1] протокол канального уровня сетевой модели OSI, разработанный ISO.
Текущим стандартом для HDLC является ISO 13239.
HDLC может быть использован в соединениях с множественным доступом, но в настоящее время в основном используется в соединениях точка-точка с использованием асинхронного сбалансированного режима (ABM).
История
HDLC был разработан на основе протокола SDLC[англ.] фирмы IBM. Его несильно изменённые дочерние протоколы — LAPB, LAPM[англ.], LAPF[англ.], LAPD[англ.] были встроены ITU соответственно в стеки протоколов X.25, V.42, Frame Relay, ISDN. Также HDLC был базой при разработке кадровых механизмов в протоколе PPP, широко используемом в Интернете.
Типы станций
- Первичная (ведущая) станция (Primary terminal) ответственна за управление каналом и восстановление его работоспособности. Она производит кадры команд. В соединениях точка-многоточка поддерживает отдельные связи с каждой из вторичных станций.
- Вторичная (ведомая) станция (Secondary terminal) работает под контролем ведущей, отвечая на её команды. Поддерживает только 1 сеанс связи.
- Комбинированная станция (Combined terminal) сочетает в себе функции как ведущей, так и ведомой станций. Производит и команды и ответы. Только соединения точка-точка.
Логические состояния
Каждая из станций в каждый момент времени находится в одном из 3 логических состояний:
- Состояние логического разъединения (LDS — Logical Disconnect State)
Если вторичная станция находится в режиме нормального разъединения (NDM), то она может принимать кадры только после получения явного разрешения от первичной. Если же в асинхронном режиме разъединения (ADM), то вторичная станция может самовольно инициировать передачу.
- Состояние инициализации (IS — Initialization State)
Используется для передачи управления на удалённую комбинированную станцию и для обмена параметрами между удалёнными станциями.
- Состояние передачи информации (ITS — Information Transfer State)
Всем станциям разрешено вести передачу и принимать информацию. Станции могут находиться в режимах NRM, ARM, ABM.
Режимы состояния передачи
HDLC поддерживает три режима логического соединения, различающиеся ролями взаимодействующих устройств:
- Режим нормального ответа (Normal Response Mode, NRM) требует инициации передачи в виде явного разрешения на передачу от первичной станции. После использования канала вторичной станцией (ответа на команду первичной), для продолжения передачи она обязана ждать другого разрешения. Для выбора права на передачу первичная станция проводит круговой опрос вторичных. Используется в основном в соединениях точка-многоточка.
- Режим асинхронного ответа (Asynchronous Response Mode, ARM) даёт возможность вторичной станции самой инициировать передачу. В основном используется в соединениях типа кольцо и многоточечных с неизменной цепочкой опроса, так как в этих соединениях одна вторичная станция может получить разрешение на передачу от другой вторичной и в ответ начать передачу. То есть разрешение на передачу передаётся по типу маркера (token). За первичной станцией сохраняются обязанности по инициализации линии, определению ошибок передачи и логическому разъединению. Позволяет уменьшить накладные расходы, связанные с началом передачи.
- Асинхронный сбалансированный режим (Asynchronous Balanced Mode, ABM) используется комбинированными станциями. Передача может быть инициирована с любой стороны, может происходить в полном дуплексе. В режиме ABM оба устройства равноправны и обмениваются кадрами, которые делятся на кадры-команды и кадры-ответы.
Конфигурации канала
Для обеспечения совместимости между станциями, которые могут менять свой статус (тип), в протоколе HDLC предусмотрены 3 конфигурации канала:
- Несбалансированная конфигурация (UN — Unbalanced Normal) обеспечивает работу 1 первичной и одной или нескольких вторичных станций в (симплексном)полудуплексном и полнодуплексном режимах, с коммутируемым или некоммутируемым каналом.
- Симметричная конфигурация (UA — Unbalanced Asynchronous) обеспечивает взаимодействие двух двухточечных несбалансированных станций. Используется 1 канал передачи, в который мультиплексируются и команды и ответы. В данное время не используется.
- Сбалансированная конфигурация (BA — Balanced Asynchronous) состоит из 2 комбинированных станций. Передача в(симплексном) полудуплексном и полнодуплексном режимах, с коммутируемым или некоммутируемым каналом. Каждая станция несёт одинаковую ответственность за управление каналом.
Кадры
Кадры HDLC можно передавать, используя синхронные и асинхронные соединения. В самих соединениях нет механизмов определения начала и конца кадра, для этих целей используется уникальная в пределах протокола битовая последовательность (FD — Frame Delimiter) '01111110' (0x7E в шестнадцатеричном представлении), помещаемая в начало и конец каждого кадра. Уникальность флага гарантируется использованием битстаффинга в синхронных соединениях и байтстаффинга в асинхронных. Битстаффинг — вставка битов, здесь — бита 0 после 5 подряд идущих битов 1. Битстаффинг работает только во время передачи информационного поля (поля данных) кадра. Если передатчик обнаруживает, что передано подряд пять единиц, то он автоматически вставляет дополнительный ноль в последовательность передаваемых битов (даже если после этих пяти единиц и так идёт ноль). Поэтому последовательность 01111110 никогда не появится в поле данных кадра. Аналогичная схема работает в приёмнике и выполняет обратную функцию. Когда после пяти единиц обнаруживается ноль, он автоматически удаляется из поля данных кадра. В байтстаффинге используется escape-последовательность, здесь — '01111101' (0x7D в шестнадцатеричном представлении), то есть байт FD (0x7E) в середине кадра заменяется последовательностью байтов (0x7D, 0x5E), а байт (0x7D) — последовательностью байтов (0x7D, 0x5D).
Во время простоя среды передачи при синхронном соединении последовательность 0x7E ('01111110') постоянно передаётся по каналу для поддержания битовой синхронизации. Может иметь место совмещение последнего бита 0 одного флага и начального бита 0 следующего. Время простоя также называется межкадровым временны́м заполнением.
Структура кадров
Структура кадра HDLC, включая флаги FD:
Флаг FD | Адрес | Управляющее поле | Информационное поле | FCS | Флаг FD |
---|---|---|---|---|---|
8 бит | кратно 8 битам | 8 или 16 бит | 0 или более бит, кратно 8 | 16 бит | 8 бит |
- Флаги FD — открывающий и закрывающий флаги, представляющие собой коды 01111110, обрамляют HDLC-кадр, позволяя приёмнику определить начало и конец кадра. Благодаря этим флагам в HDLC-кадре отсутствует поле длины кадра. Иногда флаг конца одного кадра может (но не обязательно) быть начальным флагом следующего кадра.
- Адрес выполняет свою обычную функцию идентификации одного из нескольких возможных устройств только в конфигурациях точка-многоточка. В двухточечной конфигурации адрес HDLC используется для обозначения направления передачи — из сети к устройству пользователя (10000000) или наоборот (11000000).
- Управляющее поле занимает 1 или 2 байта. Его структура зависит от типа передаваемого кадра. Тип кадра определяется первыми битами управляющего поля: 0 — информационный, 10 — управляющий, 11 — ненумерованный тип. В структуру управляющего поля кадров всех типов входит бит P/F, он по-разному используется в кадрах-командах и кадрах-ответах. Например, станция-приёмник при получении от станции-передатчика кадра-команды с установленным битом P немедленно должна ответить управляющим кадром-ответом, установив бит F.
- Информационное поле предназначено для передачи по сети пакетов протоколов вышележащих уровней — сетевых протоколов IP, IPX, AppleTalk, DECnet, в редких случаях — прикладных протоколов, когда те выкладывают свои сообщения непосредственно в кадры канального уровня. Информационное поле может отсутствовать в управляющих кадрах и некоторых ненумерованых кадрах.
- Поле FCS (Frame Check Sequence) — контрольная последовательность, необходимая для обнаружения ошибок передачи. Её вычисление в основном производится методом циклического кодирования с производящим полиномом X16+X12+X5+1 (CRC-16) в соответствии с рекомендацией CCITT V.41. Полученная CRC побитово инвертируется и записывется в обратной последовательности. Это позволяет обнаруживать всевозможные кортежи ошибок длиной до 16 бит вызываемые одиночной ошибкой, а также 99,9984 % всевозможных более длинных кортежей ошибок. FCS составляется по полям Адрес, Управляющее поле, Информационное поле. В редких случаях используются другие методы циклического кодирования. После просчёта FCS на стороне приёмника он отвечает положительной или отрицательной квитанцией. Повтор кадра передающей стороной выполняется по приходе отрицательной квитанции или по истечении тайм-аута.
Типы кадров
I-кадры (информационные кадры, кадры данных)
Предназначены для передачи данных пользователя. В процессе передачи информационных блоков осуществляется их нумерация в соответствии с алгоритмом скользящего окна. После установления соединения данные и положительные квитанции начинают передаваться в информационных кадрах. Логический канал HDLC является дуплексным, так что информационные кадры, а значит, и положительные квитанции могут передаваться в обоих направлениях. Если же потока информационных кадров в обратном направлении нет или же нужно передать отрицательную квитанцию, то используются управляющие кадры. При работе HDLC для обеспечения надёжности передачи используется скользящее окно размером в 7 кадров (при размере управляющего поля 1 байт) или 127 (при размере управляющего поля 2 байта). Для поддержания алгоритма окна в информационных кадрах станции-отправителя отводится 2 поля:
- N(S) — номер отправляемого кадра;
- N(R) — номер кадра, который станция ожидает получить от своего партнера по диалогу.
Предположим для определённости, что станция A отправила станции B информационный кадр с некоторыми значениями NA(S) и NA(R). Если в ответ на этот кадр приходит кадр от станции B, в котором номер посланного этой станцией кадра NB(S) совпадает с номером ожидаемого станцией A кадра NA(R), то передача считается корректной. Если станция A принимает кадр-ответ, в котором номер отправленного кадра NB(S) не равен номеру ожидаемого NA(R), то станция A этот кадр отбрасывает и посылает отрицательную квитанцию REJ (от англ. reject — отказ) с номером NA(R). Приняв отрицательную квитанцию, станция B обязана повторить передачу кадра с номером NA(R), а также всех кадров с бо́льшими номерами, которые она уже успела отослать, пользуясь механизмом скользящего окна.
I-кадры также содержат бит опрос/ответ P/F (poll/final). В режиме NRM ведущий терминал использует бит P для опроса, ведомый — бит F в последнем I-кадре ответа. В режимах ARM и ABM биты P/F используются для форсирования ответа.
Команда/
Ответ |
Описание | Формат упр. поля
8…7…6…5…4…3…2…1…. |
---|---|---|
C/R | Данные пользователя | .-N(R)-… P/F….-N(S)-..0 |
S-кадры (управляющие)
Используются для контроля потока ошибок передачи. В управляющих кадрах передаются команды и ответы в контексте установленного логического соединения, в том числе запросы на повторную передачу искаженных информационных блоков:
Готов к приёму (RR)
- Используется как положительная квитанция (до N(r)−1).
- Ведущая станция может сделать опрос, установив бит P.
- Ведомая станция на опрос может ответить кадром с установленным битом F, если у неё нет данных для передачи.
Не готов к приёму (RNR)
- Используется как положительная квитанция и запрос остановить передачу I-кадров до получения следующего кадра RR.
- Ведущая или комбинированная станции могут установить бит P для уточнения статуса приёма ведомой/комбинированной станции.
- Ведомая/комбинированная станции могут ответить установкой бита P как индикации занятости станции.
Неприём (REJ)
- Часто используется как отрицательная квитанция приёмника
- Неприём кадров последнего окна (повтор передачи с кадра N(r))
Выборочный неприём (SREJ)
- Неприём конкретного кадра (повтор передачи одного кадра)
Имя | Команда/
Ответ |
Описание | Info | Формат упр. поля
8…7…6…5…4…3…2…1…. |
---|---|---|---|---|
Готов к приёму (RR) | C/R | Положительная квитанция | Готов к приёму I-кадра | .-N(R)-… P/F…0…0…0…1 |
Не готов к приёму (RNR) | C/R | Положительная квитанция | Не готов к приёму | .-N(R)-… P/F…0…1…0…1 |
Неприём (REJ) | C/R | Отрицательная квитанция | Повтор N кадров | .-N(R)-… P/F…1…0…1…0 |
Выборочный неприём (SREJ) | C/R | Отрицательная квитанция | Повтор 1 кадра | .-N(R)-… P/F…1…1…0…1 |
U-кадры (ненумерованные)
U-кадры определяются по двум младшим битам, установленным в 1. Таким образом, вместе с флагом P/F это оставляет 5 бит для типа кадра. Так как используется менее 32 значений, некоторые типы кадров имеют разный смысл в зависимости от способа отправки: как запрос или как ответ. Так, понятна связь между командой DISC (disconnect) и ответом RD (request disconnect), но причины, по которым команда SARM и ответ DM имеют одно цифровое значение, непонятны[кому?].
U-кадры предназначены для установления и разрыва логического соединения, а также информирования об ошибках.
Поле M ненумерованных кадров содержит коды, определяющие тип команд, которыми пользуются два узла на этапе установления соединения (например, SABME, UA, REST).
- Установка режима (SNRM, SNRME, SARM, SARME, SABM, SABME, UA, DM, RIM, SIM, RD, DISC)
- Ненумерованная информация (UP, UI)
- Восстановление (FRMR, RSET)
- Неверное поле управления
- Превышена длина поля данных
- Неверная длина для данного типа кадров
- Неверный номер кадра
- Остальные (XID, TEST)
Имя | Команда/
Ответ |
Описание | Info | Формат упр. поля
8…7…6…5…4…3…2…1…. |
---|---|---|---|---|
Установить режим нормального ответа SNRM | C | Установить режим | ..1…0…0…P…1…1…0…1 | |
Установить расширенный режим нормального ответа SNRME | C | Установить режим | ..1…1…0…P…1…1…1…1 | |
Установить режим асинхронного ответа SARM | C | Установить режим | ..0…0…0..P/F..1…1…0…1 | |
Установить расширенный режим асинхронного ответа SARME | C | Установить режим | ..0…1…0…P..1…1…1…1 | |
Установить асинхронный сбалансированный режим SABM | C | Установить режим | ..0…0…1..P/F..1…1…1…1 | |
Установить расширенный асинхронный сбалансированный режим SABME | C | Установить режим | ..0…1…1…P…1…1…1…1 | |
Установить режим инициализации SIM | C | Инициировать функцию контроля за линией в адресуемой станции | ..0…0…0..P/F..0…1…1…1 | |
Разрыв соединения DISC | C | Разорвать логическое соединение | ..0…1…0..P/F..0…0…1…1 | |
Ненумерованное подтверждение UA | R | Подтверждение приёма одной из команд установки режимов | ..0…1…0….F..0…0…1…1 | |
Режим разъединения DM | R | Индикация режима лог. разъединения | ||
Запрос разъединения RD | R | Ответ на команду DISC | ..0…1…0..P/F..0…0…1…1 | |
Запрос инициализации RIM | R | Необходима инициализация | Запрос команды SIM | |
Ненумерованная информация UI | C/R | Используется для обмена информацией управления | ..0…0…0..P/F..0…0…1…1 | |
Ненумерованный опрос UP | C | Используется для запроса управляющей информации | ..0…0…1..P….0…0…1…1 | |
Перезапуск счётчиков RSET | C | Исп. для восстановления | Обнуляет N(R), N(S) | ..1…0…0..P….1…1…1…1 |
Обмен статусом XID | C/R | Исп. для запроса / передачи статуса | ..1…0…1..P/F..1…1…1…1 | |
Тест TEST | C/R | Обмен идентичными инф. полями для теста | ..1…1…1..P/F..0…0…1…1 | |
Неприём кадра FRMR | C/R | Извещение о неверном кадре |
Кадры UI, XID, TEST содержат полезные данные и могут быть использованы как в качестве команд, так и в качестве ответов.
- Кадр UI содержит пользовательскую информацию, но (в отличие от I-кадра) он передаётся повторно при потере.
- Кадр TEST является аналогом команды ping и используется для отладочных целей. Полезные данные команды TEST возвращаются в ответе TEST.
См. также
- Протокол PPP
- Протокол SLIP
- Стек протоколов TCP/IP
- RFC 1662, standard 51, PPP in HDLC-like Framing
- RFC 2687, Proposed Standard, PPP in a Real-time Oriented HDLC-like Framing
- RFC 4349, Proposed Standard, HDLC frames over L2TPv3
Примечания
- ↑ Отличие bit-oriented от byte-oriented протоколов . Дата обращения: 13 июня 2011. Архивировано 9 октября 2018 года.
Литература
- Галкин В. А., Григорьев Ю. А. Телекоммуникации и Сети. — М.: МГТУ им. Н. Э. Баумана, 2003. С. 608. ISBN 5-7038-1961-X
- Олифер В. Г., Олифер Н. А. Компьютерные сети. Принципы, технологии, протоколы: Учебник для вузов. 3-е изд. — СПб.: Питер, 2006.
Ссылки