Протокол передачи данных HDLC

 

Классический бит-ориентированный про­токол HDLC (High-level Data Link Control – высокоуровневый протокол управления каналом) относится к группе тесно связанных друг с другом протоко­лов, про­изошедших от одного из первых протоколов передачи данных SDLC (Synchronous Data Link Control – синхронный протокол управления каналом). После разработки прото­кола SDLC корпорация IBM представила его на рассмотрение институтов ANSI (American National Standards Institute – Американский национальный институт стандартов) и ISO для утверждения в качестве стандарта США и международного стандарта. Институт ANSI модифицировал протокол в ADCCP (Advanced Data Communication Control Procedure – усовершенствованная процедура управле­ния информационным обменом), a международная организация стандартов ISO переделала его в HDLC. После этого протокол HDLC был адаптирован для протокола доступа к каналу LAP (Link Access Procedure – процедура доступа к каналу), а затем протокол LAP модифицирован в протокол LAP-B(Link Access Procedure Balanced – процедура сбалансированного доступа), который более совместим с новой версией протокола HDLC. В основе всех этих протоколов лежат одни и те же принципы. Все они являют­ся бит-ориентированными, и во всех применяется битовое заполнение, обеспечи­вающее прозрачность данных. Они различаются только в незначительных, но, тем не менее, существенных деталях.

Во всех бит-ориентированных протоколах используется формат кадра, пока­занный на рис. 8.3. Поле Address (Адрес) чрезвычайно важно для линий связи с не­сколькими машинами (многоточечных сетях), где оно используется для идентификации одной из машин. В двухточечных сетях это поле иногда используется, чтобы отли­чать команды от ответов. Поле Control (Управляющая информация) используется для хранения поряд­ковых номеров, подтверждений и других служебных данных. Поле Data (Данные) может содержать произвольную информацию. Оно мо­жет быть любой длины, хотя эффективность контрольной суммы снижается с увеличением длины кадра из-за увеличения вероятности многочисленных паке­тов ошибок. Поле Checksum (Контрольная сумма) является разновидностью циклического избыточного кода.

В качестве заголовка и трейлера кадра используется флаговый байт (01111110). В линиях «точка–точка», которые в текущий момент времени про­стаивают, флаговые последовательности передаются постоянно. Кадр минималь­ного размера состоит из трех полей, занимающих в общей сложности 32 бита (не считая флаги в начале и в конце кадра).

 

Биты 8 8 8 16 8

      Address   Control   Data   Checksum    

 

Рис. 8.3. Формат кадра бит-ориентированных протоколов

 

Все кадры можно разделить на три категории: информационные, супервизорные и ненумерованные. Содержимое поля Control для этих трех типов кад­ров показано на рис. 8.4.

 

Биты 1 3 1 3

 

а   Seq P/F   Next  

 

б   Type P/F   Next  

 

в   Type P/F   Modifier  

 

 

Рис. 8.4. Управляющее поле: а – информационного кадра;

б – супервизорного кадра; в – ненумерованного кадра

 

В каждый момент времени в сети может находиться не бо­лее семи неподтвержденных кадров. Поле Seq содержит порядко­вый номер кадра. Поле Next является пересылаемым вместе с кадром подтвер­ждением. Однако все протоколы придерживаются соглашения о том, что вместо номера последнего правильно принятого кадра в поле Next пересылается номер первого не принятого кадра (то есть следующего ожидаемого кадра). Впрочем, номер кадра, используемого для подтверждения, не принципиален. Важно лишь, чтобы все участники придерживались одного и того же соглашения. Бит P/F означает Poll/Final (Опрос/Финальный). Он используется, когда получатель опрашивает группу отправителей. В случае значе­ния Р получатель предлагает отправителю посылать данные. Во всех кадрах, посылаемых отправителем (кроме последнего), бит P/F устанавливается в Р. В последнем кадре этот бит устанавливается в F. Некоторые протоколы используют бит P/F, чтобы заставить другую машину послать супервизорный кадр немедленно, не ожидая попутного потока данных. Этот бит также изредка используется в ненумерованных кадрах.

Тип супервизорного кадра указывается с помощью значения поля Туре. Если Туре = 0, значит, данный кадр является подтверждением. Он официально назы­вается RECEIVE READY («к приему готов»). Такой кадр сообщает номер следующего ожидаемого кадра и применяется при отсутствии попутного потока данных для передачи подтверждения. Туре = 1 является признаком отрицательного подтверждения, официально на­зывающегося REJECT («отказ»). Он применяется для сообщения об обнаружении ошибки передачи. Поле Next в этом случае содержит номер первого неверно по­лученного кадра (то есть первого кадра, который следует переслать повторно). Отправитель должен переслать повторно все неподтвержденные кадры, начиная с кадра с номером Next. Туре = 2 означает RECEIVE NOT READY («к приему не готов»). При этом, как и в слу­чае RECEIVE READY, подтверждается прием всех кадров вплоть до Next – 1, однако от­правителю сообщается, что передачу следует приостановить. Сигнал неготовно­сти к приему предназначен не для обозначения наличия у получателя каких-либо времен­ных проблем, например отсутствия свободной памяти в буферах. Когда получа­тель сможет продолжить работу, он пошлет сигнал готовности, отказа или дру­гой управляющий кадр. Туре = 3 означает SELECTIVE REJECT («выборочный отказ»). Такой байт представ­ляет собой запрос повторной передачи только указанных кадров. Таким образом, если получатель хочет сохранить в буфере несвоевременные кадры для последующего использования, он может запросить повторную передачу любого кадра с помощью SELECTIVE REJECT. Протоколы HDLC и ADCCP поддерживают этот тип кадра, а протоколы SDLC и LAP-B – нет, то есть в этих протоколах нет команды выборочного отказа, а кадры со значением Туре = 3 не используются.

Третий класс кадров составляют ненумерованные кадры. Иногда они приме­няются для служебных целей, но могут переносить и данные, когда требуется ненадежный, не требующий соединения сервис. В отличие от предыдущих двух классов, в которых различные бит-ориентированные протоколы были почти иден­тичными, в вопросе использования ненумерованных кадров они очень сильно различаются. Для обозначения типа кадра зарезервировано 5 бит, однако исполь­зуются значительно меньше, чем 32 возможных комбинации.

Все протоколы поддерживают команду DISC (Disconnect – прервать связь), позволяющую предупредить, что машина скоро будет выключена (например, для профилактического обслуживания). Также имеется команда SNRM (Set Normal Response Mode – установить нормальный режим отве­та), позволяющая ма­шине, только что вернувшейся в подключенный режим (on-line), заявить о своем присутствии и принудительно обнулить все порядковые номера. Третьей командой, поддерживаемой всеми указанными протоколами, является FRMR (FRaMe Reject – отклонить кадр), применяющаяся тогда, когда приходит кадр с вер­ной контрольной суммой, но недопустимой семантикой (например, супервизорный кадр со значением Туре = 3 в протоколе LAP-B, кадр с длиной менее 32 бит, недопустимый управляющий кадр и т. д.).

Управляющие кадры могут быть повреждены или потеряны так же, как и ин­формационные кадры, поэтому им тоже нужны подтверждения. Для этой цели предназначен специальный служебный кадр, называемый UA (Unnumbered Acknowledgement – ненумерованное подтверждение).








Дата добавления: 2015-12-17; просмотров: 1032;


Поиск по сайту:

При помощи поиска вы сможете найти нужную вам информацию.

Поделитесь с друзьями:

Если вам перенёс пользу информационный материал, или помог в учебе – поделитесь этим сайтом с друзьями и знакомыми.
helpiks.org - Хелпикс.Орг - 2014-2024 год. Материал сайта представляется для ознакомительного и учебного использования. | Поддержка
Генерация страницы за: 0.007 сек.