www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 工業(yè)控制 > 《機電信息》
[導(dǎo)讀]摘要:電力終端需要經(jīng)常升級換代,對應(yīng)的軟件也需要不斷升級。現(xiàn)有操作系統(tǒng)不能滿足當前功能、可靠性等的要求,故需要切換到LinuX系統(tǒng),但切換系統(tǒng)會導(dǎo)致原有的軟件程序不能使用,正常移植程序需要重構(gòu)代碼,工作量大,那么如何將程序快速移植到現(xiàn)有操作系統(tǒng)呢?現(xiàn)提出一種基于LinuX系統(tǒng)的電力終端代碼移植方法,能夠快速實現(xiàn)代碼移植,加快軟件開發(fā)進度,縮短項目周期。

引言

隨著經(jīng)濟的快速發(fā)展,大型的居民小區(qū)、密集的商業(yè)中心越來越多,城市規(guī)模不斷擴大,人口數(shù)量急劇增長。電力終端設(shè)備作為居民用戶電量采集的核心設(shè)備,其品質(zhì)尤為重要。其使用壽命達十年左右,會面臨增設(shè)需求與功能等,長期的代碼開發(fā)最終導(dǎo)致芯片內(nèi)存不夠,現(xiàn)有操作系統(tǒng)滿足不了要求,需要切換到LinuX系統(tǒng),以保證終端系統(tǒng)的穩(wěn)定性。

如何快速地將代碼移植到LinuX系統(tǒng)?本文提出了一種基于LinuX系統(tǒng)的電力終端代碼移植方法。

1動態(tài)庫Libtml的工作原理

1.1框架視圖

動態(tài)庫主要包含任務(wù)、FTL模擬層、消息的相關(guān)操作等功能,具體功能如圖1所示。

1.2Libtml的作用

SP5老程序與SP6新程序在應(yīng)用程序上是一樣的,區(qū)別在于SP5運行在SX0S系統(tǒng),而SP6運行在LinuX系統(tǒng),如何做到快速移植程序?采用接口轉(zhuǎn)換的方法,將老程序的接口通過Libtml轉(zhuǎn)換到現(xiàn)有的LinuX系統(tǒng),保證程序可以正常運行,節(jié)約開發(fā)資源。新程序與老程序的區(qū)別如圖2所示。

基于LinuX系統(tǒng)的電力終端代碼移植方法研究

使用Libtml動態(tài)庫,有如下優(yōu)勢:

(1)直接將應(yīng)用層代碼應(yīng)用到LinuX系統(tǒng):

(2)SX0S與LinuX對應(yīng)的接口不同,而Libtml動態(tài)庫能實現(xiàn)接口的轉(zhuǎn)接:

(3)有效提高了軟件的穩(wěn)定性:

(4)減少了代碼量,提高了代碼的復(fù)用率,便于后期維護。

2Libtml動態(tài)庫的主要功能

2.1守護任務(wù)模塊

2.1.1守護任務(wù)機制

守護任務(wù)用于通過周期性地調(diào)用9SP喂狗函數(shù)保障整個系統(tǒng)的可靠運行,另外守護任務(wù)監(jiān)控系統(tǒng)中所有任務(wù)是否正常運行,如果某個任務(wù)運行過程中發(fā)生堵塞、死鎖或其他異常,守護任務(wù)將正確做出判斷并停止調(diào)用硬件喂狗函數(shù),觸發(fā)系統(tǒng)硬件復(fù)位。

所有被監(jiān)控任務(wù)在運行前需要向守護任務(wù)進行注冊,并在運行的循環(huán)中向守護任務(wù)進行簽名,這就要求被監(jiān)控的任務(wù)不能運行在堵塞狀態(tài)。守護任務(wù)周期性地調(diào)用9SP喂狗函數(shù),當檢測到某個被監(jiān)控任務(wù)在一定周期內(nèi)沒有進行登記,則顯示和記錄異常信息,并停止喂狗函數(shù)的運行,等到外部硬件狗復(fù)位整個系統(tǒng)。守護任務(wù)在停止硬件喂狗前,將等待所有注冊任務(wù)安全退出,以保障系統(tǒng)的安全性。

2.1.2喂狗計數(shù)器

SP5的軟喂狗時間為300B,但SP6的軟喂狗時間為30B(經(jīng)驗值),硬喂狗時間為60B(經(jīng)驗值)。在操作系統(tǒng)程序(包括9SStlSoadr)和應(yīng)用程序中插入喂狗程序,這些喂狗程序運行時間間隔小于看門狗的時間間隔。這樣做可以保證:如果系統(tǒng)正常工作,系統(tǒng)可以在小于看門狗的時間間隔內(nèi)不斷進行喂狗動作,硬件看門狗的計數(shù)器不斷賦初值,不產(chǎn)生復(fù)位信號:如果系統(tǒng)非正常工作,喂狗動作失效,硬件看門狗的計數(shù)器在60B后溢出,對CPU產(chǎn)生復(fù)位信號使系統(tǒng)重啟。軟喂狗操作類似。

2.2FTL模擬層

FTL(FloBhTronBlotiSnLoydr)是nSrfloBh的轉(zhuǎn)換層,NTFL(NonaFloBhTronBlotiSnLoydr)是NonaFloBh的轉(zhuǎn)換層。

FloBh是一種介質(zhì),寫入前要先擦除,但FloBh是有壽命的,它不能無限次執(zhí)行擦除操作。FTL和NFTL是文件系統(tǒng)和mta之間一個轉(zhuǎn)換層,它提供的寫入均衡算法,能均衡管理每個扇區(qū)的寫入和擦除次數(shù),大大增加了FloBh的使用壽命。它的特點有:

(l)體積小,性能強:

(2)壞塊管理程序:

(3)垃圾回收功能:

(4)寫入均衡算法:

(5)斷電恢復(fù)功能。

ftl.c是FTL的代碼源文件,nftl.c是NFTL的代碼源文件。在Libtml動態(tài)庫主要介紹ftl.c。

ftl.c包含本程序所涉及的API函數(shù)實現(xiàn),主要分配了1M的ABS區(qū)8M的FTL區(qū),SP5存在1+8的9M空間,現(xiàn)在SP6為了將SP5的程序移植過來,也模擬了一個9M的空間,用來兼容SP5的程序,/media/data/flaSh.bin有256M的文件,其中的某段9M文件放在ABS和FTL中,TML主要是負責(zé)yaffS2文件系統(tǒng)與物理地址之間的轉(zhuǎn)換工作。ABS區(qū)一般存放備份數(shù)據(jù)不用改變的數(shù)據(jù),而FTL負責(zé)將邏輯區(qū)塊地址轉(zhuǎn)換到物理區(qū)塊地址。

FTL模擬層主要功能如圖3所示。

2.3消息的相關(guān)操作

消息接口主要包含:消息隊列的創(chuàng)建mSg0Create)、刪除mSg0Delete)發(fā)送mSg0Send)接收mSg0Receive)及排隊發(fā)送的消息數(shù)量mSg0NumMSgS)。消息隊列的創(chuàng)建和刪除主

要是對nОtemotpnОtfullmuteX三個信號量進行創(chuàng)建或刪除的操作。下面對消息的發(fā)送和接收進行介紹。

2.3.1mSg0Send:消息發(fā)送

功能:將一條消息發(fā)送到隊列。整體流程如圖4所示。

①初始化消息結(jié)構(gòu)體:

②判斷這條消息是否為空,若為空則結(jié)束,反之繼續(xù):

③判斷消息長度是否合法,合法則繼續(xù),反之執(zhí)行步驟⑤:

④先釋放muteX,然后獲取nОtemotp,最后獲取muteX:

⑤等待發(fā)送的消息量減1,將消息發(fā)到消息隊列:

⑥判斷消息隊列中的firSt、laSt,并釋放nОtemotp、muteX信號量:

⑦結(jié)束。

2.3.2mSg0Receive消息接收

功能:接收一條消息存儲到隊列。整體流程如圖5所示。

①初始化消息結(jié)構(gòu)體:

②判斷消息結(jié)構(gòu)體是否為空,為空則結(jié)束,反之繼續(xù):

③等待互斥信號量muteX:

④判斷mbОX一firSt與mbОX一laSt是否相等,相等則繼續(xù),不等則執(zhí)行步驟⑥:

⑤先釋放muteX,然后獲取nОtemotp,最后獲取muteX:

⑥當接收消息的指針不為空時,將消息添加到隊列:

⑦先釋放nОtfull信號量,再釋放muteX互斥信號量:

⑧結(jié)束。

3驗證機制

程序移植后,終端程序可以正常運行,公司內(nèi)部展開測試,并在江西、重慶等市場展開聯(lián)調(diào),均合格,在穩(wěn)定性和可靠性等方面取得良好的結(jié)果。

4結(jié)語

總之,基于LinuX系統(tǒng)的電力終端代碼移植方法,實現(xiàn)了程序的快速移植,保證了終端系統(tǒng)的穩(wěn)定性可靠性,并為未來新的需求開發(fā)提供了保障。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀
關(guān)閉