- •1. Структура управляющих устройств на базе микропроцессоров
- •2. Структура эвм в управляющих микропроцессорных устройствах
- •3. Интерфейсы микропроцессорных устройств
- •3.1. Параллельные интерфейсы
- •3.2. Последовательные интерфейсы
- •3.2.1. Способы последовательной передачи
- •3.2.2. Реализации асинхронного интерфейса
- •3.2.3. Реализации синхронного интерфейса
- •3.2.4. Реализации изохронного интерфейса
- •3.2.6. Протокол Манчестер-2
- •3.2.7. Протокол высокого уровня modbus
- •Формат каждого байта в ascii-режиме побитно:
- •1 Старт бит;
- •Формат каждого байта в rtu-режиме побитно:
- •1 Старт бит;
- •3.3. Особенности использования шин
- •4. Выбор управляющей эвм
- •4.1. Промышленные эвм
- •4.2. Промышленные контроллеры
- •4.3. Микроконтроллеры
- •5. Программирование управляющих микропроцессорных устройств
- •5.1. Программирование промышленных контроллеров
- •5.2. Программирование микроконтроллеров
- •Библиографический список
3.2.7. Протокол высокого уровня modbus
Стандартные MODBUS-порты в контроллерах обычно используют RS-232 или RS-485 совместимый последовательный интерфейс. Контроллеры могут быть соединены напрямую или через модем. Контроллеры соединяются, используя технологию главный – подчиненный, при которой только одно устройство (главный) может инициировать передачу (сделать запрос). Другие устройства (подчиненные) передают запрашиваемые главным устройством данные или производят запрашиваемые действия. Типичное главное устройство включает в себя ведущий (HOST) процессор. Типичное подчиненное устройство – программируемый контроллер. Главный может адресоваться к индивидуальному подчиненному или может инициировать широкую передачу сообщения на все подчиненные устройства. Подчиненное устройство возвращает сообщение в ответ на запрос, адресуемый именно ему. Ответы не возвращаются при широковещательном запросе от главного.
Цикл запрос-ответ имеет вид:
Запрос от главного Ответ подчиненного
Адрес устройства Адрес устройства
Код функции Код функции
Байты данных Байты данных
Контрольная сумма Контрольная сумма
Запрос: код функции в запросе говорит подчиненному устройству, какое действие необходимо провести. Байты данных содержат информацию, необходимую для выполнения запрошенной функции. Например, код функции 3 подразумевает запрос на чтение содержимого регистров подчиненного.
Ответ: если подчиненный дает нормальный ответ, код функции в ответе повторяет код функции в запросе. В байтах данных содержится затребованная информация. Если имеет место ошибка, то код функции модифицируется, и в байтах данных передается причина ошибки.
Пользователь может устанавливать продолжительность интервала таймаута, в течение которого головное устройство будет ожидать ответа от подчиненного. Если подчиненный обнаружил ошибку передачи, то он не формирует ответ главному.
В сетях MODBUS может быть использован один из двух способов передачи: ASCII или RTU.
Режим ASCII.
При использовании ASCII-режима каждый байт сообщения передается как два ASCII символа. Главное преимущество этого способа – время между передачей символов может быть до 1 сек. без возникновения ошибок при передаче. Система кодировки: шестнадцатиричная, ASCII-символы 0-9, A-F.
Формат каждого байта в ascii-режиме побитно:
1 Старт бит;
7 бит данных, младшим битом вперед;
1 бит паритета; нет бита паритета;
1 стоп-бит, если есть паритет; 2 бита, если нет паритета.
Контрольная сумма: Longitudinal Redundancy Chek (LRC).
В ASCII-режиме, сообщение начинается с “двоеточия” (ASCII-код 3A hex), и заканчивается последовательностью “возврат каретки – перевод строки” (CRLF, ASCII-0D и 0A hex).
Допустимые символы для передачи – это шестнадцатиричные цифры 0-9, A-F. Монитор сетевого устройства в сети непрерывно отслеживает символ “двоеточие”. Когда он принят, каждое устройство декодирует следующие поле сообщения (поле адреса) и т.д.
Интервалы между символами сообщения могут быть до 1 сек. Если интервал больше, то принимающее устройство распознает это как ошибку. Типичный фрейм сообщения:
Старт(1 симв.)–Адрес(2 симв.)–Функция(2 симв.)–Данные(n симв.)–LRC(2 симв.)–Конец(2 симв.)
Адресное поле фрейма содержит два символа. Допустимый адрес от 0 до 247. Каждое подчиненное устройство имеет адрес от 1 до 247. Адрес 0 – широкополосное сообщение для всех устройств.
Поле функции фрейма содержит два символа. Допустимый диапазон от 1 до 255. Когда подчиненный отвечает главному, он использует поле кода функции для фиксации ошибки. В случае нормального ответа подчиненный повторяет оригинальный код функции. Если имеет место ошибка, возвращается код функции с установленным в 1 старшим битом.
Поле данных в сообщении от главного к подчиненному содержит дополнительную информацию, которая необходима подчиненному для выполнения указанной функции. Оно может содержать адреса регистров или выходов, их количество, счетчик передаваемых байтов данных. Например, если главный запрашивает у подчиненного прочитать группу регистров (код функции 03), поле данных содержит адрес начального регистра и количество регистров. Если главный хочет записать группу регистров (код функции 10 hex), поле данных содержит адрес начального регистра, количество регистров, счетчик количества байтов данных и данные для записи в регистры. Поле данных может не существовать (иметь нулевую длину) в определенных типах сообщений.
Поле контрольной суммы содержит два ASCII-символа. Контрольная сумма является результатом вычисления Longitudinal Redundancy Check (LRC) сделанного над содержанием сообщения, начиная с “:”, и заканчивая CRLF.
Режим RTU.
В RTU режиме данные передаются в виде 8-разрядных двоичных символов. Каждое сообщение начинается с интервала тишины, равного времени передачи 3,5 символов (байтов) при данной скорости передачи в сети, после чего передается байт адреса ведомого устройства (Slave) в диапазоне 1 – 247. Нулевой адрес обращения зарезервирован для одновременной передачи всем подчиненным (широковещательная передача). Вслед за последним передаваемым символом также следует интервал тишины продолжительностью не менее 3,5 символов.
Новое сообщение может начинаться после этого интервала. Символы кадра сообщения передаются непрерывным потоком. Если интервал тишины продолжительностью 1,5 символа возник во время передачи текущего кадра, принимающее устройство заканчивает прием сообщения и следующий байт будет воспринят как начало следующего сообщения.
