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/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.png|center|frame|Fig.1. The generic configuration dialogues of the input serial interface.]] Using the main dialog you can set: * State of transport, that is: status, "Connect" and name of the database, containing the configuration. * Identifier, name and description of the transport. * Address of the transport in the format "'''{dev}[:{spd}[:{format}[:{opts}[:{mdm}]]]]'''", where: ** ''dev'' — address of the serial device (/dev/ttyS0); ** ''spd'' — speed of the serial devices from a number: 300, 600, 1200, 2400, 4800, 9600, 19200, 38400, 57600, 115200, 230400, 460800, 500000, 576000 or 921600; ** ''format'' — asynchronous data format "'''{size}{parity}{stop}'''" (8N1, 7E1, 5O2, ...); ** ''opts'' — different options, mostly for flow control, separated by ',': *** "[-]h" — hardware (CRTSCTS); *** "[-]s" — software (IXON|IXOFF); *** "rts" — using of the RTS signal for transferring(false) and checking for echo, for raw RS-485; *** "rts1" — using of the RTS signal for transferring(true) and checking for echo, for raw RS-485; *** "rtsne" — using of the RTS signal for transferring(false) and without checking for echo, for raw RS-485; *** "rts1ne" — using of the RTS signal for transferring(true) and without checking for echo, for raw RS-485; *** "[-]RS485" — using RS-485 mode, through TIOCSRS485. ** ''mdm'' — modem mode, listen for "RING". * Choice of transport protocols. * The state "Connect", in which the transport must be translated at boot. Using the additional dialog you can set: * Time intervals of the interface in the format of string "'''{symbol}:{frm}[::{rtsDelay1}:{rtsDelay2}]'''", where: ** ''symbol'' — character time in milliseconds, used to control of the frame end; ** ''frm'' — maximum time of the frame in milliseconds, used to limit the package maximum size of the request — the frame; ** ''rtsDelay1'' — delay between the transmitter activation with RTS signal and start up of the transmission, in milliseconds; ** ''rtsDelay2'' — delay between the transmitting and disconnecting the transmitter with RTS signal, in milliseconds. * Priority of the input stream task. * [MODEM] Modem parameters. This mode is activated by the fifth parameter of the address and includes call waiting from the remote modem (the request "RING"), answering the call (the command "ATA") and the subsequent transfer of requests from the remote station to the transport protocol. The disconnection of the communication session is performed by the connection initiator and leads to the reconnection of the receiver modem to wait for new calls. ** Requests timeout of the modem, in seconds. ** Time delay before initializing the modem, in seconds. ** Time delay after initializing the modem, in seconds. ** First initialization string (typically contains the reset command of the modem "ATZ"). ** Second initialization string. ** Result string of the modem's initialization (usually "OK"), with which the modem answers for initializing and which must be expected. ** Call's request (usually "RING"), which is sent by the modem in the case of an output call. ** Answer to the call (usually "ATA"), which is sent to the modem to answer the call. ** Result line for the answer to the call (usually "CONNECT"), with which the modem answers to the answer command, and that is to be expected. * Protocols' specific custom parameters. * Reset all the additional parameters to default values and cleanup the protocols' specific custom parameters. == Выходные транспорты == Сконфигурированный и исполняющийся выходной транспорт открывает порт последовательного интерфейса для отправки запросов через него. [[File:Serial_out.png|center|frame|Fig.2. The generic configuration dialogues of the output serial interface.]] Using the main dialog you can set: * The state of transport, that is: status, "Connect" and name of the database, containing the configuration. * Identifier, name and description of the transport. * Address of the transport in the format "'''{dev}[:{spd}[:{format}[:{opts}[:{modTel}]]]]'''", where: ** ''dev'' — address of the serial device (/dev/ttyS0); ** ''spd'' — speed of the serial devices from a number: 300, 600, 1200, 2400, 4800, 9600, 19200, 38400, 57600, 115200, 230400, 460800, 500000, 576000 or 921600; ** ''format'' — asynchronous data format "'''{size}{parity}{stop}'''" (8N1, 7E1, 5O2, ...); ** ''opts'' — different options, mostly for flow control, separated by ',': *** "[-]h" — hardware (CRTSCTS); *** "[-]s" — software (IXON|IXOFF); *** "rts" — using of the RTS signal for transferring(false) and checking for echo, for raw RS-485; *** "rts1" — using of the RTS signal for transferring(true) and checking for echo, for raw RS-485; *** "rtsne" — using of the RTS signal for transferring(false) and without checking for echo, for raw RS-485; *** "rts1ne" — using of the RTS signal for transferring(true) and without checking for echo, for raw RS-485; *** "[-]RS485" — using RS-485 mode, through TIOCSRS485. ** ''modTel'' — modem phone, presence of this field switches transport to work in the modem mode. Using the additional dialog you can set: * Time intervals of the interface in format of the string "'''{conn}:{symbol}[-{NextReqMult}][:{KeepAliveTm}[:{rtsDelay1}:{rtsDelay2}]]'''", where: ** ''conn'' — maximum time of waiting the connecting response, in milliseconds; ** ''symbol'' — maximum time of one symbol, used for the frame end detection, in milliseconds; ** ''NextReqMult'' — next request's multiplicator to the ''symbol'' time, 4 by default; ** ''KeepAliveTm'' — keep alive timeout to restart the transport, in seconds; use the value < 0 for stopping the transport after missing response at each request; ** ''rtsDelay1'' — delay between the transmitter activation with RTS signal and start up of the transmission, in milliseconds; ** ''rtsDelay2'' — delay between the transmitting and disconnecting the transmitter with RTS signal, in milliseconds. : Can be prioritatile specified into the address field as the second global argument, as such "'''/dev/rfcomm0:9600||1000:40-20'''". * Do not disconnect at processing. Sometimes the closing of an open device can be destructive, for example, on an ICP-DAS LP PLC, and you can prevent it with this option. * [MODEM] Modem parameters. This mode is enabled by the fifth parameter presence of the address and it involves making a call on the phone specified by this parameter at the start time of the transport. After establishing a connection to the remote modem, all transmission requests are sent to the remote modem station. Disconnection of a communication session, with the transport stopping, is carried out according to the activity timeout. ** Requests timeout of the modem, in seconds. ** Lifetime of the connection, in seconds. If during this time there will be no data transmission over the transport the connection will be aborted. ** Delay time before initializing the modem, in seconds. ** Delay time after initializing the modem, in seconds. ** First initialization string (typically contains the reset command "ATZ" of the modem). ** Second initialization string. ** Result string of the modem's initialization (usually "OK"), with which the modem answers for initializing and which must be expected. ** Dialling string to the remote modem (usually "ATDT"). When dialing, the phone number is added to this prefix. ** Result string of the successful connection (usually "CONNECT"). ** Result string of the busy line (usually is "BUSY"). ** Result string of the absence of the carrier in line (usually "NO CARRIER"). ** Result string of the dial tone lack in the line (usually "NO DIALTONE"). ** Exit string from the data mode (usually "+++") and the "Delay time before initializing the modem" is used, after it. ** Hang up command (usually "+++ATH"). This command is called whenever there is need to break the connection. ** Result string of the hanging up command (usually "OK"), with which the modem answers to the command and which must be expected. * Protocols' specific custom parameters. * Reset all the additional parameters to default values and cleanup the protocols' specific custom parameters. Транспорт может работать с аппаратной шиной 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|Notes}} == Communications via the serial interfaces have a number of features. The most important feature is the criterion for the end of the message and the waiting time of this criterion. In some protocols, such a criterion is a sign of the end or the specified message size. In other protocols, such a criterion is no data in the input stream for a specified time — the symbol time. In both cases, the criterion waiting time, or the symbol, is a crucial and strongly affects the overall exchange time and the data integrity. Consequently, the smaller this time, the better if you have no loss the data tail. Here the problem of hardware and its drivers latency happens. Проверить латентность канала обмена, и тем самым оптимально настроить время дожидания-символа, можно с помощью интерфейса вкладки "Запрос" выходного транспорта. Для этого необходимо указать образцовый запрос соответствующего протокола, указать "Ожидать таймаут", отослать запрос и проконтролировать его целостность. Для получения более репрезентативного результата необходимо запрос повторить несколько раз. Если наблюдается получение неполных ответов, то время символа необходимо увеличить, иначе можно уменьшить. На встроенном оборудовании последовательных интерфейсов 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