Export translations
Views
Special page
From OpenSCADAWiki
Jump to:
navigation
,
search
Settings
Group
About
Documents
Documents/API
Documents/DAQ
Documents/FAQ
Documents/How to
Documents/How to/Build from source
Documents/How to/Crash report
Documents/How to/Create module
Documents/How to/Create multi language project
Documents/How to/Cyclic programming
Documents/How to/Debug
Documents/How to/Install
Documents/How to/Live disk
Documents/How to/Release
Documents/How to/Transferring project configuration
Documents/How to/Violations, alarms and notifications
Documents/Program manual
Documents/Quick start
Documents/Release 0.8.0
Documents/Release 0.8.0/Update10
Documents/Release 0.8.0/Update11
Documents/Release 0.8.0/Update12
Documents/Release 0.8.0/Update13
Documents/Release 0.8.0/Update14
Documents/Release 0.8.0/Update15
Documents/Release 0.8.0/Update16
Documents/Release 0.8.0/Update17
Documents/Release 0.8.0/Update18
Documents/Release 0.8.0/Update19
Documents/Release 0.8.0/Update20
Documents/Release 0.8.0/Update3
Documents/Release 0.8.0/Update4
Documents/Release 0.8.0/Update5
Documents/Release 0.8.0/Update6
Documents/Release 0.8.0/Update7
Documents/Release 0.8.0/Update8
Documents/Release 0.8.0/Update9
Documents/Release 0.9
Documents/Release 0.9/Update 7
Documents/Release 0.9/Update 8
Documents/Release 0.9/Update1
Documents/Release 0.9/Update2
Documents/Release 0.9/Update3
Documents/Release 0.9/Update4
Documents/Release 0.9/Update5
Documents/Release 0.9/Update6
Documents/Release 0.9/Updating 0.8.0 LTS
Documents/Terms
Documents/User API
Functions and demands
Home
Libs
Libs/Devices
Libs/Documents
Libs/Electrical elements
Libs/Generic list
Libs/LowLevelDevices
Libs/Main
Libs/Main graphical elements
Libs/Mnemo elements
Libs/Prescriptions
Libs/Regulation elements
Libs/Service procedures
Libs/Technological apparatuses
Modules
Modules/BFN
Modules/BlockCalc
Modules/Comedi
Modules/DAQGate
Modules/DBArch
Modules/DBF
Modules/DBGate
Modules/DCON
Modules/DiamondBoards
Modules/FireBird
Modules/FLibComplex1
Modules/FLibMath
Modules/FLibSYS
Modules/FSArch
Modules/GPIO
Modules/HTTP
Modules/ICP DAS
Modules/JavaLikeCalc
Modules/LDAP
Modules/LogicLev
Modules/ModBus
Modules/MySQL
Modules/OPC UA
Modules/PostgreSQL
Modules/QTCfg
Modules/QTStarter
Modules/SelfSystem
Modules/Serial
Modules/Siemens
Modules/SMH2Gi
Modules/SNMP
Modules/Sockets
Modules/SoundCard
Modules/SQLite
Modules/SSL
Modules/System
Modules/SystemTests
Modules/UserProtocol
Modules/VCAEngine
Modules/Vision
Modules/WebCfg
Modules/WebCfgD
Modules/WebUser
Modules/WebVision
Sub-projects
Sub-projects/Automatic Builder of OpenSCADA
Sub-projects/Automation Linux distributive
Sub-projects/Embedding and PLC
Sub-projects/Server
Sub-projects/VCA
User:RomanSavochenko
Using
Using/HouseSpirit
Using/Kramatorsk Ball Mills
Using/Kramatorsk Water
Using/Model AGLKS
Using/Model Boiler
Using/OpenWrt TELEOFIS RTU968
Using/Yaroslavskij broiler
Works
Works/Road map
Works/Technical Support
Works/Technical Support/Agreement
Works/To do
Language
aa - Afar
ab - Abkhazian
ace - Achinese
ady - Adyghe
ady-cyrl - адыгабзэ
aeb - Tunisian Arabic
aeb-arab - تونسي
aeb-latn - Tûnsî
af - Afrikaans
ak - Akan
aln - Gheg Albanian
am - Amharic
an - Aragonese
ang - Old English
anp - Angika
ar - Arabic
arc - Aramaic
arn - Mapuche
arq - Algerian Arabic
ary - Moroccan Arabic
arz - Egyptian Arabic
as - Assamese
ase - American Sign Language
ast - Asturian
av - Avaric
avk - Kotava
awa - Awadhi
ay - Aymara
az - Azerbaijani
azb - تۆرکجه
ba - Bashkir
bar - Bavarian
bbc - Batak Toba
bbc-latn - Batak Toba
bcc - Southern Balochi
bcl - Bikol Central
be - Belarusian
be-tarask - Belarusian (Taraškievica orthography)
bg - Bulgarian
bgn - Western Balochi
bho - Bhojpuri
bi - Bislama
bjn - Banjar
bm - Bambara
bn - Bengali
bo - Tibetan
bpy - Bishnupriya
bqi - Bakhtiari
br - Breton
brh - Brahui
bs - Bosnian
bto - Iriga Bicolano
bug - Buginese
bxr - буряад
ca - Catalan
cbk-zam - Chavacano de Zamboanga
cdo - Min Dong Chinese
ce - Chechen
ceb - Cebuano
ch - Chamorro
cho - Choctaw
chr - Cherokee
chy - Cheyenne
ckb - Central Kurdish
co - Corsican
cps - Capiznon
cr - Cree
crh - Crimean Turkish
crh-cyrl - Crimean Turkish (Cyrillic script)
crh-latn - Crimean Turkish (Latin script)
cs - Czech
csb - Kashubian
cu - Church Slavic
cv - Chuvash
cy - Welsh
da - Danish
de - German
de-at - Austrian German
de-ch - Swiss High German
de-formal - German (formal address)
diq - Zazaki
dsb - Lower Sorbian
dtp - Central Dusun
dty - डोटेली
dv - Divehi
dz - Dzongkha
ee - Ewe
egl - Emilian
el - Greek
eml - Emiliano-Romagnolo
en - English
en-ca - Canadian English
en-gb - British English
eo - Esperanto
es - Spanish
et - Estonian
eu - Basque
ext - Extremaduran
fa - Persian
ff - Fulah
fi - Finnish
fit - Tornedalen Finnish
fj - Fijian
fo - Faroese
fr - French
frc - Cajun French
frp - Arpitan
frr - Northern Frisian
fur - Friulian
fy - Western Frisian
ga - Irish
gag - Gagauz
gan - Gan Chinese
gan-hans - Simplified Gan script
gan-hant - Traditional Gan script
gd - Scottish Gaelic
gl - Galician
glk - Gilaki
gn - Guarani
gom - Goan Konkani
gom-deva - Goan Konkani (Devanagari script)
gom-latn - Goan Konkani (Latin script)
got - Gothic
grc - Ancient Greek
gsw - Swiss German
gu - Gujarati
gv - Manx
ha - Hausa
hak - Hakka Chinese
haw - Hawaiian
he - Hebrew
hi - Hindi
hif - Fiji Hindi
hif-latn - Fiji Hindi (Latin script)
hil - Hiligaynon
ho - Hiri Motu
hr - Croatian
hrx - Hunsrik
hsb - Upper Sorbian
ht - Haitian Creole
hu - Hungarian
hy - Armenian
hz - Herero
ia - Interlingua
id - Indonesian
ie - Interlingue
ig - Igbo
ii - Sichuan Yi
ik - Inupiaq
ike-cans - Eastern Canadian (Aboriginal syllabics)
ike-latn - Eastern Canadian (Latin script)
ilo - Iloko
inh - Ingush
io - Ido
is - Icelandic
it - Italian
iu - Inuktitut
ja - Japanese
jam - Jamaican Creole English
jbo - Lojban
jut - Jutish
jv - Javanese
ka - Georgian
kaa - Kara-Kalpak
kab - Kabyle
kbd - Kabardian
kbd-cyrl - Адыгэбзэ
kg - Kongo
khw - Khowar
ki - Kikuyu
kiu - Kirmanjki
kj - Kuanyama
kk - Kazakh
kk-arab - Kazakh (Arabic script)
kk-cn - Kazakh (China)
kk-cyrl - Kazakh (Cyrillic script)
kk-kz - Kazakh (Kazakhstan)
kk-latn - Kazakh (Latin script)
kk-tr - Kazakh (Turkey)
kl - Kalaallisut
km - Khmer
kn - Kannada
ko - Korean
ko-kp - 한국어 (조선)
koi - Komi-Permyak
kr - Kanuri
krc - Karachay-Balkar
kri - Krio
krj - Kinaray-a
ks - Kashmiri
ks-arab - Kashmiri (Arabic script)
ks-deva - Kashmiri (Devanagari script)
ksh - Colognian
ku - Kurdish
ku-arab - كوردي (عەرەبی)
ku-latn - Kurdish (Latin script)
kv - Komi
kw - Cornish
ky - Kyrgyz
la - Latin
lad - Ladino
lb - Luxembourgish
lbe - лакку
lez - Lezghian
lfn - Lingua Franca Nova
lg - Ganda
li - Limburgish
lij - Ligurian
liv - Livonian
lmo - Lombard
ln - Lingala
lo - Lao
loz - Lozi
lrc - Northern Luri
lt - Lithuanian
ltg - Latgalian
lus - Mizo
luz - Southern Luri
lv - Latvian
lzh - Literary Chinese
lzz - Laz
mai - Maithili
map-bms - Basa Banyumasan
mdf - Moksha
mg - Malagasy
mh - Marshallese
mhr - Eastern Mari
mi - Maori
min - Minangkabau
mk - Macedonian
ml - Malayalam
mn - Mongolian
mo - молдовеняскэ
mr - Marathi
mrj - Western Mari
ms - Malay
mt - Maltese
mus - Creek
mwl - Mirandese
my - Burmese
myv - Erzya
mzn - Mazanderani
na - Nauru
nah - Nāhuatl
nan - Min Nan Chinese
nap - Neapolitan
nb - Norwegian Bokmål
nds - Low German
nds-nl - Low Saxon
ne - Nepali
new - Newari
ng - Ndonga
niu - Niuean
nl - Dutch
nl-informal - Nederlands (informeel)
nn - Norwegian Nynorsk
nov - Novial
nrm - Nouormand
nso - Northern Sotho
nv - Navajo
ny - Nyanja
oc - Occitan
olo - Livvi-Karelian
om - Oromo
or - Oriya
os - Ossetic
pa - Punjabi
pag - Pangasinan
pam - Pampanga
pap - Papiamento
pcd - Picard
pdc - Pennsylvania German
pdt - Plautdietsch
pfl - Palatine German
pi - Pali
pih - Norfuk / Pitkern
pl - Polish
pms - Piedmontese
pnb - Western Punjabi
pnt - Pontic
prg - Prussian
ps - Pashto
pt - Portuguese
pt-br - Brazilian Portuguese
qu - Quechua
qug - Chimborazo Highland Quichua
rgn - Romagnol
rif - Riffian
rm - Romansh
rmy - Romani
rn - Rundi
ro - Romanian
roa-tara - tarandíne
ru - Russian
rue - Rusyn
rup - Aromanian
ruq - Megleno-Romanian
ruq-cyrl - Megleno-Romanian (Cyrillic script)
ruq-latn - Megleno-Romanian (Latin script)
rw - Kinyarwanda
sa - Sanskrit
sah - Sakha
sat - Santali
sc - Sardinian
scn - Sicilian
sco - Scots
sd - Sindhi
sdc - Sassarese Sardinian
sdh - Southern Kurdish
se - Northern Sami
sei - Seri
ses - Koyraboro Senni
sg - Sango
sgs - Samogitian
sh - Serbo-Croatian
shi - Tachelhit
shi-latn - Tašlḥiyt
shi-tfng - ⵜⴰⵛⵍⵃⵉⵜ
si - Sinhala
sk - Slovak
sl - Slovenian
sli - Lower Silesian
sm - Samoan
sma - Southern Sami
sn - Shona
so - Somali
sq - Albanian
sr - Serbian
sr-ec - Serbian (Cyrillic script)
sr-el - Serbian (Latin script)
srn - Sranan Tongo
ss - Swati
st - Southern Sotho
stq - Saterland Frisian
su - Sundanese
sv - Swedish
sw - Swahili
szl - Silesian
ta - Tamil
tcy - Tulu
te - Telugu
tet - Tetum
tg - Tajik
tg-cyrl - Tajik (Cyrillic script)
tg-latn - Tajik (Latin script)
th - Thai
ti - Tigrinya
tk - Turkmen
tl - Tagalog
tly - Talysh
tn - Tswana
to - Tongan
tokipona - Toki Pona
tpi - Tok Pisin
tr - Turkish
tru - Turoyo
ts - Tsonga
tt - Tatar
tt-cyrl - Tatar (Cyrillic script)
tt-latn - Tatar (Latin script)
tum - Tumbuka
tw - Twi
ty - Tahitian
tyv - Tuvinian
tzm - Central Atlas Tamazight
udm - Udmurt
ug - Uyghur
ug-arab - Uyghur (Arabic script)
ug-latn - Uyghur (Latin script)
uk - Ukrainian
ur - Urdu
uz - Uzbek
uz-cyrl - ўзбекча
uz-latn - oʻzbekcha
ve - Venda
vec - Venetian
vep - Veps
vi - Vietnamese
vls - West Flemish
vmf - Main-Franconian
vo - Volapük
vot - Votic
vro - Võro
wa - Walloon
war - Waray
wo - Wolof
wuu - Wu Chinese
xal - Kalmyk
xh - Xhosa
xmf - Mingrelian
yi - Yiddish
yo - Yoruba
yue - Cantonese
za - Zhuang
zea - Zeelandic
zh - Chinese
zh-cn - Chinese (China)
zh-hans - Simplified Chinese
zh-hant - Traditional Chinese
zh-hk - Chinese (Hong Kong)
zh-mo - 中文(澳門)
zh-my - 中文(马来西亚)
zh-sg - Chinese (Singapore)
zh-tw - Chinese (Taiwan)
zu - Zulu
qqq - Message documentation
Format
Export for off-line translation
Export in native format
{{DISPLAYTITLE:Модулі/Serial}}<languages/> {| class="wikitable" |- ! Модуль !! Ім'я !! Версія !! Ліцензія !! Джерело !! Мови !! Платформи !! Тип !! Автор !! Опис |- <section begin=info /> | [[Special:MyLanguage/Modules/Serial|Serial]] || Послідовні інтерфейси | 2.7 || GPL2 || tr_Serial.so || en,uk,ru,de || x86,x86_64,ARM <section end=info /> | Транспорт || {{Author|Роман Савоченко|Максим Кочетков (2016)}} || Надає транспорт заснований на послідовних інтерфейсах. Використовується для обміну даними через послідовні інтерфейси типу RS232, RS485, GSM та схожі. * '''[[Special:MyLanguage/Works/To_do|Завдання (To Do)]]:''' <section begin=ToDo /> : - перевірити режим модему та додати до нього поле вводу PIN. <section end=ToDo /> |} Модуль надає до програми підтримку транспортів, заснованих на послідовних інтерфейсах типу RS232, RS485, GSM та схожі. Підтримуються вхідні та вихідні транспорти. Додати нові вхідні та вихідні інтерфейси можна за посередництвом конфігурації транспортної підсистеми у будь якому конфігураторі OpenSCADA. Модулем, у режимі модему, підтримується змішаний режим роботи, який передбачає наявність вхідного транспорту, що очікує зовнішніх підключень, а також вихідного транспорту на тому-ж пристрої. Тобто вхідний транспорт буде ігнорувати всі запити при наявності встановленого вихідним транспортом підключення, в той-же час вихідний транспорт не буде здійснювати спроб встановлення підключення при наявності підключення до вхідного транспорту або підключення іншого вихідного транспорту, наприклад, за іншим номером телефону. [[File:at.png]] У звичайному режимі послідовного інтерфейсу не допускається багаторазове використання одного й того-ж порту у вхідних та вихідних транспортах. Глобального блокування послідовного пристрою не здійснюється у зв'язку із неоднозначністю цього процесу на системному рівні, а багаторазове використання може призвести до непередбачуваних та складно-вловимих проблем. При потребі організації локального послідовного каналу з парою пов'язаних портів рекомендується використовувати команду {{InLineCode|<nowiki>socat -d -d pty,raw,echo=0,perm=0666 pty,raw,echo=0,perm=0666</nowiki>}}. == Вхідні транспорти == Сконфігурований та запущений вхідний транспорт відкриває порт послідовного інтерфейсу для очікування запитів клієнтів. Кожний вхідний інтерфейс обов'язково пов'язується з одним із доступних транспортних протоколів, до якого передаються вхідні повідомлення. [[File:serial_in_uk.png|center|frame|Рис.1. Загальні діалоги конфігурації вхідного послідовного інтерфейсу.]] За допомогою основного діалогу можна встановити: * Стан транспорту, а саме: статус, "Підключення" та ім'я БД, яка містить конфігурацію. * Ідентифікатор, ім'я та опис транспорту. * Адреса інтерфейсу у форматі рядка: "'''{dev}[:{spd}[:{format}[:{opts}[:{mdm}]]]]'''", де: ** ''dev'' — адреса послідовного пристрою (/dev/ttyS0); ** ''spd'' — швидкість послідовного пристрою із ряду: 300, 600, 1200, 2400, 4800, 9600, 19200, 38400, 57600, 115200, 230400, 460800, 500000, 576000 або 921600; ** ''format'' — формат асинхронних даних "'''{розмір}{парність}{стоп}'''" (8N1, 7E1, 5O2, ...); ** ''opts'' — різноманітні параметри, переважно для керування потоком, поділені символом ',': *** "[-]h" — апаратне (CRTSCTS); *** "[-]s" — програмне (IXON|IXOFF); *** "rts" — використання RTS сигналу для передачі(false) та перевірки на луну, для сирого RS-485; *** "rts1" — використання RTS сигналу для передачі(true) та перевірки на луну, для сирого RS-485; *** "rtsne" — використання RTS сигналу для передачі(false) без перевірки на луну, для сирого RS-485; *** "rts1ne" — використання RTS сигналу для передачі(true) без перевірки на луну, для сирого RS-485; *** "[-]RS485" — використовувати RS-485 режим, за посередництвом TIOCSRS485. ** ''mdm'' — режим модему, очікування 'RING'. * Вибір транспортних протоколів. * Стан "Підключення", у який переводити транспорт при завантажені. За допомогою додаткового діалогу можна встановити: * Інтервали часу інтерфейсу у форматі рядка: "'''{symbol}:{frm}[::{rtsDelay1}:{rtsDelay2}]'''", де: ** ''symbol'' — час символу у мілісекундах, використовується для контролю факту закінчення фрейму; ** ''frm'' — максимальний час фрейму у мілісекундах, використовується для обмеження максимального розміру пакету запиту — фрейму; ** ''rtsDelay1'' — затримка між включенням передавача сигналом RTS та початком передачі, у мілісекундах; ** ''rtsDelay2'' — затримка між закінченням передачі та відключенням передавача сигналом RTS, у мілісекундах. * Пріоритет задачі вхідного потоку. * [MODEM] Параметри модему. Цей режим включається п'ятим параметром адреси та передбачає очікування дзвінка від віддаленого модему (запит "RING"), відповіді на дзвінок (команда "ATA") та наступної передачі запитів від віддаленої станції до транспортного протоколу. Відключення сеансу зв'язку здійснюється ініціатором з'єднання та призводить до перепідключення модему приймача на очікування нових дзвінків. ** Час очікування (таймаут) модему на запит, у секундах. ** Витримка часу перед ініціалізацією модему, в секундах. ** Витримка часу після ініціалізації модема, в секундах. ** Перший рядок ініціалізації (зазвичай містить команду скидання налаштувань модему "ATZ"). ** Другий рядок ініціалізації. ** Рядок результату ініціалізації модему (зазвичай "OK"), яким відповідає модем на ініціалізацію та якого треба очікувати. ** Запит дзвінка (зазвичай "RING"), який надсилає модем у випадку надходження вихідного виклику. ** Відповідь на дзвоник (зазвичай "ATA"), який надсилається модему для відповіді на дзвінок. ** Рядок результату на відповідь на дзвінок (зазвичай "CONNECT"), яким відповідає модем на команду відповіді та яку треба очікувати. * Специфічні до протоколу користувацькі параметри. * Скинути усі додаткові параметри до типових значень та очистити специфічні до протоколу користувацькі параметри. == Вихідні транспорти == Сконфігурований та виконуваний вихідний транспорт відкриває порт послідовного інтерфейсу для відправки запитів через нього. [[File:Serial_out_uk.png|center|frame|Рис.2. Загальні діалоги конфігурації вихідного послідовного інтерфейсу.]] За допомогою основного діалогу можна встановити: * Стан транспорту, а саме: статус, "Підключення" та ім'я БД, яка містить конфігурацію. * Ідентифікатор, ім'я та опис транспорту. * Адреса інтерфейсу у форматі рядка: "'''{dev}[:{spd}[:{format}[:{opts}[:{modTel}]]]]'''", де: ** ''dev'' — адреса послідовного пристрою (/dev/ttyS0); ** ''spd'' — швидкість послідовного пристрою із ряду: 300, 600, 1200, 2400, 4800, 9600, 19200, 38400, 57600, 115200, 230400, 460800, 500000, 576000 або 921600; ** ''format'' — формат асинхронних даних "'''{розмір}{парність}{стоп}'''" (8N1, 7E1, 5O2, ...); ** ''opts'' — різноманітні параметри, переважно для керування потоком, поділені символом ',': *** "[-]h" — апаратне (CRTSCTS); *** "[-]s" — програмне (IXON|IXOFF); *** "rts" — використання RTS сигналу для передачі(false) та перевірки на луну, для сирого RS-485; *** "rts1" — використання RTS сигналу для передачі(true) та перевірки на луну, для сирого RS-485; *** "rtsne" — використання RTS сигналу для передачі(false) без перевірки на луну, для сирого RS-485; *** "rts1ne" — використання RTS сигналу для передачі(true) без перевірки на луну, для сирого RS-485; *** "[-]RS485" — використовувати RS-485 режим, за посередництвом TIOCSRS485. ** ''modTel'' — телефон модему, присутність цього поля перемикає транспорт на роботу у режимі модему. За допомогою додаткового діалогу можна встановити: * Інтервали часу інтерфейсу у форматі рядка: "'''{conn}:{symbol}[-{NextReqMult}][:{KeepAliveTm}[:{rtsDelay1}:{rtsDelay2}]]'''", де: ** ''conn'' — максимальний час очікування відповіді підключення, у мілісекундах — тобто відповіді від віддаленого пристрою; ** ''symbol'' — максимальний час одного символу, використовується для виявлення закінчення фрейму та таймауту наступного запиту, у мілісекундах; ** ''NextReqMult'' — множник часу наступного запиту до часу символу ''symbol'', 4 по замовченню; ** ''KeepAliveTm'' — таймаут життя для перезавантаження транспорту, в секундах; використовуйте значення < 0 для зупинки транспорту після відсутності відповіді на будь-який запит; ** ''rtsDelay1'' — затримка між включенням передавача сигналом RTS та початком передачі, у мілісекундах; ** ''rtsDelay2'' — затримка між закінченням передачі та відключенням передавача сигналом RTS, у мілісекундах. : Може бути пріоритетно визначено другим глобальним аргументом поля адреси, на кшталт "'''/dev/rfcomm0:9600||1000:40-20'''". * Не відключати при обробці. Інколи закриття відкритого пристрою може бути руйнівним, наприклад, на ПЛК LP від ICP-DAS, та Ви можете попередити це цією опцією. * [MODEM] Параметри модему. Цей режим включається наявністю п'ятого параметру адреси та передбачає здійснення дзвінка за телефоном, вказаним цим параметром, на момент запуску транспорту. Після встановлення зв'язку з віддаленим модемом всі запити передачі спрямовуються станції за віддаленим модемом. Відключення сеансу зв'язку, із зупинкою транспорту, здійснюється за таймаутом активності. ** Час очікування (таймаут) модема на запити, в секундах. ** Час життя підключення, в секундах. Якщо протягом цього часу буде відсутня передача даних через транспорт, то підключення буде розірвано. ** Витримка часу перед ініціалізацією модема, в секундах. ** Витримка часу після ініціалізації модему, в секундах. ** Перший рядок ініціалізації (зазвичай містить команду скидання налаштувань модему "ATZ"). ** Другий рядок ініціалізації. ** Рядок результату ініціалізації модему (зазвичай "OK"), яким відповідає модем на ініціалізацію та якого треба очікувати. ** Рядок додзвону до віддаленого модему (зазвичай "ATDT"). При додзвоні номер телефону додається до даного префіксу. ** Рядок результату вдалого підключення (зазвичай "CONNECT"). ** Рядок результату зайнятості лінії (зазвичай "BUSY"). ** Рядок результату відсутності несущої в лінії (зазвичай "NO CARRIER"). ** Рядок результату відсутності гудка лінії (зазвичай "NO DIALTONE"). ** Рядок виходу з режиму даних (зазвичай "+++") та використовується "Час перед ініціалізацією модему", після неї. ** Команда повісити трубку (зазвичай "+++ATH"). Ця команда викликається завжди, коли потрібно розірвати підключення. ** Рядок результату команди повісити трубку (зазвичай "OK"), яким відповідає модем на команду та який треба очікувати. * Специфічні до протоколу користувацькі параметри. * Скинути усі додаткові параметри до типових значень та очистити специфічні до протоколу користувацькі параметри. Транспорт може працювати з апаратною шиною I2С, якщо у якості пристрою обрати "/dev/i2c-{N}" та шина дозволить встановити адресу підлеглого пристрою командою I2C_SLAVE, із '''першого байту запиту'''. Швидкість та формат не відіграють ролі в цьому режимі. Із таймаутів тут фактично працює тільки час символу і переважно для розрахунку очікування повтору запиту. == API користувацького програмування == '''Об'єкт "Вихідний транспорт" (SYS.Transport.Serial.out_{OutTransport})''' * ''bool TS( bool rts = EVAL )'' — керує відправкою, за посередництвом встановлення запиту ''rts'', та повертає стан дозволу CTS. * ''bool DR( bool dtr = EVAL )'' — керує готовністю пристрою, за посередництвом встановлення готовності терміналу ''dtr'', та повертає стан готовності DSR. * ''bool DCD()'' — стан виявлення несущої даних. * ''bool RI()'' — індикатор дзвінка. * ''int sendbreak( int duration = 0 )'' — надсилає до потоку переривання нулями протягом ''duration'' (0 — деякий інтервал по замовченню). == {{Anch|Notes|Зауваження}} == Комунікації через послідовні інтерфейси мають низку особливостей. Найбільш важливою особливістю є критерій закінчення повідомлення та час очікування цього критерію. У одних протоколах таким критерієм виступає ознака закінчення або вказаний розмір повідомлення. В інших протоколах таким критерієм є відсутність даних у вхідному потоці протягом вказаного часу — час символу. У обох випадках час очікування критерію, або символу, є ключовим та сильно впливає на загальний час обміну і цілісність даних. Відповідно, чим менше цей час тим краще, якщо відсутні втрати хвоста даних. Тут і виникає проблема латентності обладнання та його драйверів. Перевірити латентність каналу обміну, тим самим оптимально налаштувати час доочікування-символу, можна за допомогою інтерфейсу вкладки "Запит" вихідного транспорту. Для цього потрібно вказати зразковий запит відповідного протоколу, вказати "Очікувати таймаут", надіслати запит та проконтролювати його цілісність. Для отримання більш репрезентативного результату треба запит повторити декілька разів. Якщо спостерігається отримання неповних відповідей, то час символу треба збільшити, інакше можна зменшити. На вбудованому обладнані послідовних інтерфейсів RS232/422/485 можна добитися низького рівня латентності — впритул до одиниць мілісекунд. Однак, на високо-навантажених системах з безліччю задач у пріоритеті реального часу, латентність може стати недетермінованою, у зв'язку з виконанням потоку обслуговування подій ядра Linux у низькому пріоритеті. Для вирішення цієї проблеми треба встановити високий пріоритет цим потокам, що можна здійснити за допомогою скрипту, помістивши його, наприклад, у "/etc/rc.local": <syntaxhighlight lang="BASH"> #!/bin/sh # Setting the high priority for events kernel threads to rise the serial interfaces reaction events=`ps -Ao pid,comm | sed -n '/[ ]*\([^ ]\)[ ]*events\/[0-9]/s//\1/p'` for ie in $events; do chrt -pr 21 $ie done </syntaxhighlight> Цей скрипт не має сенсу для ядер Linux реального часу, з патчем PREEMPT_RT, оскільки всі потоки переривань та повідомлень там вже запускаються у пріоритеті реального часу. На зовнішньому обладнані послідовних інтерфейсів, наприклад, у перетворювачах USB->RS232/422/485, може виникнути проблема високої латентності, пов'язана з особливістю апаратної реалізації або його драйверу. Вирішувати цю проблему треба шляхом вивчення налаштувань цього обладнання або встановленням більшого часу очікування-символу! Схожим чином визначається й оптимальний час підключення, а саме: встановити час підключення у значення по замовченню для даної швидкості (ставиться при зміні швидкості у адресі), зняти "Очікувати таймаут", надіслати запит. Якщо відповідь прийшла то беремо виміряний час відгуку пристрою, подвоюємо та встановлюємо отримане значення, як час підключення. Необґрунтоване перевищення часу підключення призведе до великих очікувань у випадку відсутності пристрою, а також спрацьовуванню захисних таймаутів внутрішніх процедур! [[File:at.png]] На ринку зустрічаються USB->Serial перетворювачі, які працюють тільки з терміналами, тобто вони можуть передавати та опрацьовувати виключно ASCII символи та не можуть бути переключені у бінарний режим. Відомі екземпляри таких перетворювачів: PL2303TA (Y-105). === Віртуальні/локальні послідовні інтерфейси === Часто для локальної перевірки, без фізичного обладнання, потрібна пара портів підключених у одну мережу. Створення таких портів та виконання багатьох інших операцій над послідовним потоком дозволяє виконувати утиліта '''socat'''. Наприклад, для створення двох пов'язаних портів треба виконати команду, яка створить їх та повідомить адреси: <syntaxhighlight lang="BASH"> socat -d -d pty,raw,echo=0,perm=0666 pty,raw,echo=0,perm=0666 #2013/07/02 16:37:29 socat[10402] N PTY is /dev/pts/6 #2013/07/02 16:37:30 socat[10402] N PTY is /dev/pts/7 #2013/07/02 16:37:30 socat[10402] N starting data transfer loop with FDs [3,3] and [5,5] </syntaxhighlight> === Перекидання послідовного інтерфейсу через мережу Ethernet === У деяких випадках буває корисним перекинути порт послідовного інтерфейсу віддаленої машини на локальний порт, наприклад, для опитування пристроїв, підключених до послідовного інтерфейсу віддаленої машини. Звісно, якщо встановити на віддалену машину OpenSCADA у конфігурації ПЛК, то можна буде одразу виконувати обробку цих даних, попереднє буферування/архівування та інше, але інколи обладнання може бути складним для запуску OpenSCADA, де й рятує можливість перекидання послідовного потоку через мережу. Для вирішення цього завдання можна скористатися тією-ж утилітою '''socat''' або '''remserial''', '''ser2net''', яку вдасться зібрати та запустити на віддаленій машині. Приклади перекидання послідовного порту: <syntaxhighlight lang="BASH"> # Створення сокету на порту 5555 віддаленої машини, для порту /dev/ttyS0 socat tcp-l:5555,reuseaddr,fork file:/dev/ttyS0,raw # Підключення до сокету віддзеркаленого порту віддаленої машини та формування файлу віддзеркаленого локального інтерфейсу socat -d -d pty,raw,echo=0,perm=0666 tcp:192.168.2.4:5555,mss=1400 #2013/07/04 10:09:09 socat[12947] N PTY is /dev/pts/4 #2013/07/04 10:09:09 socat[12947] N opening connection to AF=2 192.168.2.4:5555 #2013/07/04 10:09:09 socat[12947] N successfully connected from local address AF=2 192.168.2.61:33493 #2013/07/04 10:09:09 socat[12947] N starting data transfer loop with FDs [3,3] and [5,5] </syntaxhighlight> У випадку з "socat", а можливо й інших утиліт, можна на клієнтському боці опустити запуск драйверу EthernetTCP->Serial та підключатися із OpenSCADA прямо на TCP-порт віддаленого пристрою. [[File:at.png]] У роботі через драйвер EthernetTCP->Serial є особливість, яка пов'язана із наявністю двох таймаутів підключення: один у драйвері та інший у [[Special:MyLanguage/Modules/Sockets|Transport.Sockets]]. Важливо щоб значення цього таймауту у [[Special:MyLanguage/Modules/Sockets|Transport.Sockets]] було більше ніж у драйвері інакше можливий зсув та отримання запізнілих відповідей від попередніх запитів. Багато виробників промислового комунікаційного обладнання випускають готові конвертери із Ethernet у RS-232/422/485, які можуть використовуватися з OpenSCADA таким-же чином. Коментарі та перелік перетворювачів з якими роботу OpenSCADA перевірено: * [http://www.icpdas.com ICP DAS]: [http://www.icpdas.com/products/Industrial/pds/tds-700.htm tDS-7xx] — налаштовується через WEB-інтерфейс та працює за прямим підключенням до TCP-порту; * [http://tibbo.com Tibbo]: [http://tibbo.com/products/controllers/ds100.html DS100] — <span style="color: red">налаштовується тільки через програму для MS Windows®</span>, надає власний драйвер для формування віртуальних послідовних інтерфейсів на Linux, працює за прямим підключенням до TCP-порту.
Navigation menu
OpenSCADA
Site
Download
Old Wiki
OpenSCADA Wiki
Home
About OpenSCADA
Functions and demands
Tasks
Using
Fund
Recent changes
Random page
Search
Tools
Special pages
Printable version
MediaWiki
Help
Personal tools
English
Log in