《電子技術(shù)應(yīng)用》
您所在的位置:首頁 > 嵌入式技術(shù) > 設(shè)計(jì)應(yīng)用 > 基于嵌入式Linux的無紙記錄儀通信設(shè)計(jì)
基于嵌入式Linux的無紙記錄儀通信設(shè)計(jì)
EDN
摘要: 本文將使用嵌入式Linux作為無紙記錄儀上位機(jī)操作系統(tǒng),并利用其多線程編程技術(shù)實(shí)現(xiàn)上位機(jī)與下位機(jī)的串口通信。
Abstract:
Key words :

引言

  在工業(yè)自動(dòng)化控制系統(tǒng)中,記錄儀起著十分重要的作用,它可以實(shí)時(shí)采集、監(jiān)測和記錄一些影響工藝過程和產(chǎn)品質(zhì)量的重要參數(shù),被廣泛應(yīng)用于石化、冶金、電力、機(jī)械、醫(yī)藥、輕工業(yè)等行業(yè)。隨著電子技術(shù)的不斷發(fā)展,記錄儀已從傳統(tǒng)的有紙模擬式發(fā)展到如今的無紙數(shù)字式[1]。與傳統(tǒng)的有紙記錄儀相比,無紙記錄儀無機(jī)械磨損、顯示直觀、使用方便、故障率低和設(shè)備耗材少,因此被越來越多的應(yīng)用于工業(yè)控制領(lǐng)域。

  隨著工業(yè)過程自動(dòng)化的高速發(fā)展,企業(yè)對無紙記錄儀提出了越來越高的要求,基于8位單片機(jī)的無紙記錄儀的功能已遠(yuǎn)遠(yuǎn)達(dá)不到用戶的要求。嵌入式ARM微處理核的32位RISC處理器以其強(qiáng)大的性能豐富的接口以及優(yōu)異的性價(jià)比等諸多優(yōu)勢,而被越來越多的應(yīng)用于無紙記錄儀,隨著硬件的改進(jìn),傳統(tǒng)的串行通訊方法也迫切需要改進(jìn),因此本文提出了基于嵌入式Linux串口通信方案。嵌入式Linux操作系統(tǒng)是在標(biāo)準(zhǔn)Linux的基礎(chǔ)上針對嵌入式系統(tǒng)進(jìn)行內(nèi)核裁剪和優(yōu)化后形成[2],它繼承了Linux的開放源代碼、多任務(wù)、穩(wěn)定性高,內(nèi)核可裁剪等諸多優(yōu)點(diǎn),其內(nèi)核精簡而高效,具有非常好的網(wǎng)絡(luò)性能。本文將使用嵌入式Linux作為無紙記錄儀上位機(jī)操作系統(tǒng),并利用其多線程編程技術(shù)實(shí)現(xiàn)上位機(jī)與下位機(jī)的串口通信。

  1 記錄儀中的通信協(xié)議

  由于無紙記錄儀主要在過程控制現(xiàn)場或監(jiān)控室中使用,與之進(jìn)行通信的現(xiàn)場設(shè)備接口以串口居多,因此在該裝置的開發(fā)過程中采用十分通用的MODBUS協(xié)議作為串口通信協(xié)議。?MODBUS協(xié)議是MODICON公司于1979年為建立智能設(shè)備間的主從式通信而開發(fā)的一種通信協(xié)議,它規(guī)定在一個(gè)系統(tǒng)中,每次命令應(yīng)由系統(tǒng)中主設(shè)備發(fā)起,從設(shè)備通過解析地址位決定是否應(yīng)答[3]。該協(xié)議具有兩種報(bào)文傳送幀格式,ASCII和RTU報(bào)文幀格式,分別如圖1和圖2所示。

ASCII報(bào)文幀格式

圖1  ASCII報(bào)文幀格式

RTU報(bào)文幀格式

圖2  RTU報(bào)文幀格式

  將兩種報(bào)文傳送幀格式異同總結(jié)如表1。由表1可知,兩種報(bào)文幀格式各有優(yōu)劣:ASCII格式使用的字符是RTU格式的兩倍,但ASCII格式數(shù)據(jù)的譯碼和處理更為容易一些;使用RTU報(bào)文幀格式傳輸數(shù)據(jù)時(shí),報(bào)文字符必須以連續(xù)數(shù)據(jù)流的形式傳送,而使用ASCII格式,字符之間允許長達(dá)1s的時(shí)間間隔。

表1 ASCII與RTU報(bào)文幀格式比較

ASCII與RTU報(bào)文幀格式比較

  通常情況下,在一個(gè)MODBUS網(wǎng)絡(luò)中只采用一種報(bào)文幀格式進(jìn)行數(shù)據(jù)交換。但在一些特殊情況下,同一系統(tǒng)中需要用到不同傳輸模式的控制器,即同時(shí)采用兩種報(bào)文幀傳輸格式。為了使無紙記錄儀具有更強(qiáng)的通用性,本文提出了一種新的可同時(shí)使用兩種報(bào)文幀格式的串口通信方案。在以下闡述過程中, 以ASCII和RTU報(bào)文幀格式傳輸?shù)臄?shù)據(jù)將分別簡稱為ASCII和RTU數(shù)據(jù)。

  2 記錄儀的通信實(shí)現(xiàn)

  2.1 整體設(shè)計(jì)

  無紙記錄儀主要通信對象為工業(yè)現(xiàn)場設(shè)備,因此通信過程中數(shù)據(jù)交換應(yīng)快速、準(zhǔn)確無誤。在MODBUS協(xié)議中,ASCII與RTU數(shù)據(jù)打包與解碼均不相同,數(shù)據(jù)讀寫方面需要獨(dú)立起來。串口通信功能框架如圖3所示。

串口通信功能框架圖

圖3 串口通信功能框架圖

  設(shè)備注冊掃描模塊主要負(fù)責(zé)設(shè)備地址表的維護(hù),每間隔一定時(shí)間掃描在線設(shè)備,并記錄下設(shè)備地址和使用的報(bào)文幀格式,同時(shí)根據(jù)掃描得到信息動(dòng)態(tài)開辟ASCII和RTU數(shù)據(jù)緩存區(qū)。ASCII數(shù)據(jù)讀寫模塊負(fù)責(zé)打包和解碼ASCII數(shù)據(jù),RTU數(shù)據(jù)讀寫模塊負(fù)責(zé)打包和解碼RTU數(shù)據(jù)。數(shù)據(jù)發(fā)送模塊根據(jù)優(yōu)先級排列好打包好的數(shù)據(jù)依次發(fā)送。數(shù)據(jù)接收模塊僅解碼下位機(jī)儀表每次傳回?cái)?shù)據(jù)的首位,判斷是RTU數(shù)據(jù)還是ASCII數(shù)據(jù),存入RTU或ASCII數(shù)據(jù)緩存區(qū),以待處理。

  為了實(shí)現(xiàn)ASCII與RTU數(shù)據(jù)的共存,首要問題是每次設(shè)備掃描注冊時(shí)對使用ASCII和使用RTU數(shù)據(jù)的設(shè)備加以區(qū)分。由ASCII和RTU的報(bào)文幀格式可知,傳輸數(shù)據(jù)首位是判斷數(shù)據(jù)類型的關(guān)鍵,所以使用RTU報(bào)文幀格式的設(shè)備地址需避開ASCII數(shù)據(jù)的起始位和結(jié)束符。在未知在線設(shè)備情況下,上位機(jī)將所有設(shè)備地址輪詢一遍,解析接收數(shù)據(jù)首位,如果是ASCII的起始位,則ASCII設(shè)備注冊,反之,則RTU設(shè)備注冊。

  2.2 編程實(shí)現(xiàn)

  軟件實(shí)現(xiàn)上,采用Linux的多線程編程技術(shù),可以更好的滿足工業(yè)現(xiàn)場的實(shí)時(shí)性要求。多線程程序采用多任務(wù)、并發(fā)的工作方式[4],可以提高應(yīng)用程序響應(yīng)時(shí)間并且改善程序結(jié)構(gòu)。Linux操作系統(tǒng)中提供了Linuxthread 庫[5],它實(shí)現(xiàn)了符合POSIX1003.1c標(biāo)準(zhǔn)的多線程支持,而且是內(nèi)核級方式。

  串口通信通過三個(gè)線程來實(shí)現(xiàn),主線程、發(fā)送子線程和接收數(shù)據(jù)處理子線程,如圖4所示。同時(shí),為了使收發(fā)數(shù)據(jù)管理更加方便,建立了四個(gè)數(shù)據(jù)緩存區(qū):⑴ 發(fā)送緩存區(qū),存放準(zhǔn)備發(fā)送的命令; ⑵ 已發(fā)送緩存區(qū),存放已發(fā)送好但未經(jīng)接收確認(rèn)的命令;⑶ RTU接收緩存區(qū),存放接收到的RTU數(shù)據(jù);⑷ ASCII接收緩存區(qū),存放接收到的ASCII數(shù)據(jù)。所有線程共享上述四個(gè)數(shù)據(jù)緩存區(qū)的數(shù)據(jù),并設(shè)置互斥鎖用來確保一個(gè)時(shí)間段內(nèi)只有一個(gè)任務(wù)在訪問共享數(shù)據(jù)。

 

串口通信多線程程序流程圖

圖4  串口通信多線程程序流程圖

  主線程主要負(fù)責(zé)設(shè)備的注冊,掃描是否有數(shù)據(jù)發(fā)送,如果有發(fā)送數(shù)據(jù),進(jìn)行優(yōu)先級設(shè)置,將發(fā)送數(shù)據(jù)轉(zhuǎn)為發(fā)送所需的ASCII和RTU格式,存入發(fā)送緩存區(qū)以待發(fā)送。串口初始化主要功能為設(shè)置串口通信屬性,如波特率、數(shù)據(jù)位、校驗(yàn)位和流控制等。串口通信采用異步通信模式,并以全局變量作為接收標(biāo)志。解析數(shù)據(jù)時(shí)應(yīng)將已收到數(shù)據(jù)和已發(fā)送數(shù)據(jù)進(jìn)行匹配,根據(jù)發(fā)送的數(shù)據(jù)分析接收數(shù)據(jù)是否正確,如果接收數(shù)據(jù)正確則丟棄已發(fā)送命令,否則重發(fā)。

3 快速數(shù)據(jù)轉(zhuǎn)換算法

  由于上位機(jī)與下位機(jī)的個(gè)別數(shù)據(jù)存儲(chǔ)格式不同,需要轉(zhuǎn)換為對方能夠識別的數(shù)據(jù)。下面以浮點(diǎn)數(shù)為例,說明本次設(shè)計(jì)中的數(shù)據(jù)轉(zhuǎn)換機(jī)制。

  上位機(jī)采用Linux操作系統(tǒng),浮點(diǎn)數(shù)采用IEEE-754數(shù)據(jù)存儲(chǔ)格式。IEEE規(guī)定一個(gè)浮點(diǎn)數(shù)在內(nèi)存中占四字節(jié),其數(shù)據(jù)格式如圖5所示。

IEEE浮點(diǎn)數(shù)數(shù)據(jù)格式

圖5  IEEE浮點(diǎn)數(shù)數(shù)據(jù)格式

  在IEEE浮點(diǎn)數(shù)數(shù)據(jù)存儲(chǔ)格式下,第1位為符號位,指示浮點(diǎn)數(shù)的正負(fù)。指數(shù)部分共8位,第一個(gè)字節(jié)的后7位和第二個(gè)字節(jié)的第1位,表示范圍是0 ~ 255。實(shí)際上的指數(shù)值應(yīng)是-128 ~ 127的有符號整數(shù),為了存儲(chǔ)方便,指數(shù)值都加127轉(zhuǎn)為0 ~ 255存儲(chǔ),即實(shí)際指數(shù)值是E-127。最后23位為小數(shù)部分,需要注意的是,在計(jì)算時(shí),要將小數(shù)部分最高位補(bǔ)1。因此,實(shí)際的浮點(diǎn)數(shù)值可以通過下面的公式計(jì)算:

Real =(-1)*Sign*(D/224)*2E-126

  下位機(jī)浮點(diǎn)數(shù)在內(nèi)存中同樣占四字節(jié),其數(shù)據(jù)格式如圖6所示。

下位機(jī)浮點(diǎn)數(shù)數(shù)據(jù)格式

圖6  下位機(jī)浮點(diǎn)數(shù)數(shù)據(jù)格式

  下位機(jī)浮點(diǎn)數(shù)數(shù)據(jù)格式中,數(shù)符用來指示浮點(diǎn)數(shù)的正負(fù),階符用于指示指數(shù)的正負(fù),階碼有6位,即指數(shù)范圍是0~64,小數(shù)部分比IEEE浮點(diǎn)數(shù)數(shù)據(jù)格式中多1位,因此在計(jì)算時(shí)高位無需補(bǔ)1。實(shí)際的浮點(diǎn)數(shù)數(shù)值可以通過下面公式計(jì)算:

Real =(-1)*Sign*(D/224)*2(-1)*SignE*E

  實(shí)際傳輸過程中,從下位機(jī)傳來的浮點(diǎn)數(shù),需要先轉(zhuǎn)為IEEE標(biāo)準(zhǔn)格式,傳給下位機(jī)的數(shù)據(jù)同樣需要轉(zhuǎn)為下位機(jī)能夠識別的格式。由于浮點(diǎn)數(shù)存儲(chǔ)格式復(fù)雜,在轉(zhuǎn)換數(shù)據(jù)時(shí)應(yīng)盡量避免使用浮點(diǎn)數(shù)運(yùn)算。通過比較圖5和圖6可知,兩種存儲(chǔ)格式的最后23位相同,可以共用。因此,在編程時(shí),采用共同體能夠更快的解決兩者之間的轉(zhuǎn)換。編寫共同體如下:

  union {

  float fdata;

  unsigned char byte[4];

  }data_change;

  fdata中存放轉(zhuǎn)換前得浮點(diǎn)數(shù),而字符型數(shù)組byte直接對應(yīng)浮點(diǎn)數(shù)在計(jì)算機(jī)中以二進(jìn)制存儲(chǔ)的四個(gè)字節(jié)。通過對字符型數(shù)組的簡單的加減法及移位計(jì)算就可以快速在兩種存儲(chǔ)格式之間轉(zhuǎn)換。 實(shí)際測試時(shí),采用共同體的數(shù)據(jù)轉(zhuǎn)換在響應(yīng)時(shí)間上要明顯優(yōu)于未采用共同體的數(shù)制轉(zhuǎn)換,提高了串口通信的實(shí)時(shí)性。

  4 結(jié)論

  本文創(chuàng)新點(diǎn):(1)將嵌入式Linux系統(tǒng)應(yīng)用于無紙記錄儀,使得該裝置體積小,功能強(qiáng),實(shí)時(shí)性能及可擴(kuò)展性能良好;(2)實(shí)現(xiàn)了MODBUS協(xié)議中RTU與ASCII傳輸模式的共存,使無紙記錄儀具有更強(qiáng)的通用性;(3)通過在數(shù)據(jù)轉(zhuǎn)換編程中采用共同體這方面的改進(jìn),提高了無紙記錄儀串口通信的實(shí)時(shí)性。

此內(nèi)容為AET網(wǎng)站原創(chuàng),未經(jīng)授權(quán)禁止轉(zhuǎn)載。
亚洲一区二区欧美_亚洲丝袜一区_99re亚洲国产精品_日韩亚洲一区二区
一区视频在线| 亚洲天堂av图片| 国产精品久久久久久模特 | 亚洲综合日本| 亚洲一二三区精品| 在线视频欧美一区| 中文一区在线| 亚洲自拍16p| 亚洲一区尤物| 亚洲欧美日韩在线不卡| 午夜精品亚洲| 欧美专区在线播放| 久久精品一区中文字幕| 久久久九九九九| 免费不卡视频| 欧美激情视频网站| 欧美人在线视频| 欧美日韩在线播放三区四区| 欧美视频在线观看| 国产精品视频999| 国产日韩欧美成人| 国产一区二区丝袜高跟鞋图片| 国内伊人久久久久久网站视频| 伊人春色精品| 亚洲精品乱码久久久久久日本蜜臀| 亚洲三级影片| 一区二区三区黄色| 亚洲一区黄色| 欧美淫片网站| 亚洲高清免费| 一本大道久久a久久精二百| 亚洲图片自拍偷拍| 欧美一区二区女人| 快射av在线播放一区| 欧美国产欧美亚洲国产日韩mv天天看完整 | 午夜国产精品影院在线观看| 久久精品成人一区二区三区蜜臀| 亚洲精品久久久久| 亚洲伊人网站| 久久久久国产精品麻豆ai换脸| 欧美jizzhd精品欧美喷水| 欧美视频导航| 国产日韩欧美综合一区| 亚洲承认在线| 亚洲婷婷综合久久一本伊一区| 性18欧美另类| 亚洲美女毛片| 午夜在线一区| 欧美gay视频激情| 国产精品高潮呻吟久久av无限| 国产一区av在线| 日韩视频精品| 久久av老司机精品网站导航| 99亚洲视频| 久久爱www| 欧美日本韩国一区| 国产免费亚洲高清| 91久久线看在观草草青青| 亚洲永久字幕| 亚洲精品自在在线观看| 欧美一区二区三区日韩视频| 欧美大片专区| 国产精自产拍久久久久久蜜| 亚洲福利在线视频| 亚洲欧美日韩一区二区在线| 日韩午夜视频在线观看| 欧美中文字幕在线视频| 欧美国产成人精品| 国产亚洲网站| 一区二区激情| 91久久精品视频| 欧美一级网站| 欧美日韩亚洲视频一区| 国内揄拍国内精品久久| 亚洲无毛电影| 日韩视频在线观看| 久久久久久**毛片大全| 亚洲三级影院| 久久久噜噜噜久久中文字幕色伊伊| 欧美日韩精品系列| 伊人久久大香线蕉综合热线| 亚洲私人影院在线观看| 亚洲欧洲在线播放| 久久精品日韩欧美| 国产精品xxxxx| 亚洲精品美女在线观看| 亚洲国产一区在线观看| 欧美专区福利在线| 国产精品国产三级国产专区53 | 午夜精品一区二区在线观看| 亚洲视频第一页| 欧美国产激情| 亚洲大胆人体在线| 亚洲第一精品电影| 久久国产黑丝| 国产精品自拍小视频| 中文一区二区| 亚洲视频免费看| 欧美激情综合亚洲一二区| 国产在线视频不卡二| 午夜精品一区二区三区在线播放| 亚洲免费在线播放| 欧美吻胸吃奶大尺度电影| 亚洲麻豆一区| 99精品国产在热久久下载| 免费h精品视频在线播放| 国产亚洲aⅴaaaaaa毛片| 亚洲影音一区| 性8sex亚洲区入口| 国产精品久久久亚洲一区| 一区二区三区久久久| 一区二区三区久久精品| 欧美人成在线视频| 亚洲麻豆国产自偷在线| 一二三区精品福利视频| 欧美激情综合五月色丁香小说| 亚洲国产一区二区三区在线播| 亚洲狠狠丁香婷婷综合久久久| 久久午夜电影网| 韩国一区二区三区在线观看| 欧美一区亚洲| 久久久久久亚洲精品中文字幕| 国产综合在线看| 久久精品国产一区二区三| 久久综合国产精品台湾中文娱乐网| 国产丝袜一区二区| 欧美在线视频a| 久久久综合网站| 激情欧美日韩一区| 亚洲精品欧美日韩专区| 欧美另类人妖| 亚洲视频在线播放| 午夜免费日韩视频| 国产视频自拍一区| 亚洲国产激情| 欧美国产成人精品| 99riav国产精品| 欧美一级大片在线免费观看| 国产婷婷色综合av蜜臀av| 久久经典综合| 欧美激情视频在线播放| 亚洲精品少妇网址| 亚洲欧美国产另类| 国产亚洲精品aa午夜观看| 久久精品人人| 欧美日韩激情小视频| 亚洲一区一卡| 久久五月婷婷丁香社区| 亚洲黄色大片| 午夜精品福利一区二区蜜股av| 国产亚洲激情在线| 亚洲激情在线观看视频免费| 欧美精品一区视频| 亚洲视频在线观看视频| 久久精品在线| 亚洲精品久久久久久久久久久久久| 亚洲一区二区三区高清不卡| 国产视频一区二区三区在线观看| 亚洲观看高清完整版在线观看| 欧美人与禽猛交乱配| 亚洲欧美国产三级| 蜜桃伊人久久| 亚洲网站视频福利| 毛片基地黄久久久久久天堂| 亚洲三级观看| 久久国产视频网站| 亚洲精品激情| 久久精品国产一区二区电影| 亚洲黄色免费| 欧美在线黄色| 91久久精品国产91性色| 欧美一级大片在线免费观看| 亚洲国产精彩中文乱码av在线播放| 国产精品99久久久久久人| 国产在线精品一区二区夜色| 一本色道久久加勒比88综合| 国产午夜精品一区二区三区视频 | 夜夜精品视频一区二区| 久久久www成人免费精品| 亚洲裸体俱乐部裸体舞表演av| 欧美一区二区视频网站| 亚洲激情欧美| 久久精品视频99| 一区二区三区 在线观看视频| 久久综合成人精品亚洲另类欧美| 一区二区欧美在线| 美女诱惑黄网站一区| 亚洲女人天堂成人av在线| 欧美黄色免费| 欧美在线高清视频| 国产精品家教| 夜夜夜久久久| 在线精品国产欧美| 久久成人一区二区| 一区二区三区高清在线| 欧美www在线| 久久国产视频网| 国产精品美女在线| 一二三四社区欧美黄| 亚洲大胆在线|