基于AutoSAR規(guī)范的驅(qū)動(dòng)代碼生成工具箱設(shè)計(jì)與實(shí)現(xiàn)
摘 要: 針對(duì)汽車控制器中驅(qū)動(dòng)代碼生成存在對(duì)硬件依賴性強(qiáng)、代碼格式不規(guī)范、可重用性不強(qiáng)等問(wèn)題,提出利用仿真建模工具Simulink/RTW、結(jié)合AutoSAR規(guī)范、基于代碼生成技術(shù)的汽車控制器驅(qū)動(dòng)工具箱的設(shè)計(jì)方法。通過(guò)對(duì)驅(qū)動(dòng)配置模塊的不同芯片配置及對(duì)相關(guān)參數(shù)的設(shè)置滿足多處理器需求,依據(jù)AutoSAR規(guī)范對(duì)驅(qū)動(dòng)函數(shù)接口的封裝實(shí)現(xiàn)代碼的可重用性。最后將設(shè)計(jì)的驅(qū)動(dòng)工具箱結(jié)合代碼生成模板應(yīng)用于BCM車窗控制系統(tǒng),實(shí)驗(yàn)證明了該方法的高效性和可行性。
關(guān)鍵詞: 代碼生成;驅(qū)動(dòng)工具箱;AutoOSAR規(guī)范;Simulink/RTW
隨著汽車電子的飛速發(fā)展和代碼自動(dòng)生成技術(shù)的出現(xiàn),汽車電子控制系統(tǒng)實(shí)現(xiàn)了從建模、仿真到代碼自動(dòng)生成的一體化開發(fā), 極大提高了生成代碼的效率、通用性及可移植性[1]。但是,汽車控制系統(tǒng)中驅(qū)動(dòng)代碼卻依賴于特定的硬件與運(yùn)行環(huán)境,主要還是以手工編寫代碼為主[2]。這種手工編寫代碼的方法存在大量的重復(fù)勞動(dòng),且代碼無(wú)法規(guī)范統(tǒng)一,可重用性不強(qiáng)、可讀性差。
所以,設(shè)計(jì)一款可以兼容多款處理器的驅(qū)動(dòng)代碼工具,生成統(tǒng)一性、規(guī)范性和開發(fā)性代碼成為行業(yè)發(fā)展的趨勢(shì)。當(dāng)前在汽車行業(yè)應(yīng)用最廣的是德國(guó)dSPACE公司的Targetlink代碼生成工具和Mathworks公司的RTW代碼生成工具[3]。本文采用Matlab/Simulnik/RTW工具設(shè)計(jì)并實(shí)現(xiàn)了基于代碼生成技術(shù)的驅(qū)動(dòng)工具箱,實(shí)現(xiàn)了汽車電控系統(tǒng)中驅(qū)動(dòng)代碼生成的可靠性、安全性、高效性及可移植性。
1 AutoSAR規(guī)范驅(qū)動(dòng)接口
汽車開放式系統(tǒng)架構(gòu)標(biāo)準(zhǔn)AutoSAR(AuTomotive Open System ARchitecture),主要可分為三層:應(yīng)用層、運(yùn)行時(shí)環(huán)境和基礎(chǔ)軟件。其中基礎(chǔ)軟件又包括系統(tǒng)服務(wù)、ECU抽象層和uC抽象層,所有驅(qū)動(dòng)程序都包含在uC抽象層和ECU抽象層中。
本文依據(jù)AutoSAR規(guī)范中ECU抽象層和uC抽象層中硬件接口標(biāo)準(zhǔn)編寫驅(qū)動(dòng)程序,組成驅(qū)動(dòng)資源庫(kù)[4]。驅(qū)動(dòng)程序按照硬件功能特點(diǎn)可分為四類:通用I/O硬件驅(qū)動(dòng)、通信硬件驅(qū)動(dòng)、存儲(chǔ)硬件驅(qū)動(dòng)和微控制器驅(qū)動(dòng)。其內(nèi)容與結(jié)構(gòu)如圖1所示。
AutoSAR規(guī)范定義了汽車電控單元硬件驅(qū)動(dòng)程序的接口規(guī)范,把驅(qū)動(dòng)函數(shù)進(jìn)行了標(biāo)準(zhǔn)化和模塊化,為驅(qū)動(dòng)工具箱開發(fā)應(yīng)用奠定了良好的基礎(chǔ)。
2 驅(qū)動(dòng)代碼生成工具箱的設(shè)計(jì)與實(shí)現(xiàn)
2.1 設(shè)計(jì)方法
在Simulink/RTW平臺(tái)上設(shè)計(jì)基于AutoSAR規(guī)范的驅(qū)動(dòng)代碼生成工具箱是通過(guò)建立S函數(shù)模塊配置參數(shù)并設(shè)計(jì)封裝入庫(kù)[5]來(lái)實(shí)現(xiàn)的。驅(qū)動(dòng)工具箱的設(shè)計(jì)流程如圖2所示,具體內(nèi)容如下:
(1)分析AutoSAR規(guī)范中驅(qū)動(dòng)函數(shù)接口標(biāo)準(zhǔn)的內(nèi)容,確定驅(qū)動(dòng)應(yīng)用代碼的內(nèi)容。
(2)分析汽車電控系統(tǒng)中驅(qū)動(dòng)代碼的需求,確定驅(qū)動(dòng)應(yīng)用代碼的格式。
(3)根據(jù)規(guī)范和需求確定驅(qū)動(dòng)工具箱的設(shè)計(jì)方案,設(shè)計(jì)驅(qū)動(dòng)工具箱為驅(qū)動(dòng)配置功能模塊和驅(qū)動(dòng)API功能模塊兩大類。
(4)編寫S函數(shù),實(shí)現(xiàn)驅(qū)動(dòng)配置功能模塊和驅(qū)動(dòng)API功能模塊的參數(shù)變量。
(5)在Simulink平臺(tái)上建立S函數(shù)模塊并添加各功能模塊的參數(shù)變量。
(6)設(shè)計(jì)和封裝S函數(shù)模塊內(nèi)容及格式,實(shí)現(xiàn)驅(qū)動(dòng)功能模塊的功能和創(chuàng)建驅(qū)動(dòng)工具箱并添加到Simulink庫(kù)中。
(7)依據(jù)驅(qū)動(dòng)工具箱的功能編寫代碼生成模板,實(shí)現(xiàn)驅(qū)動(dòng)應(yīng)用代碼自動(dòng)生成。
2.2 實(shí)現(xiàn)
下面以驅(qū)動(dòng)ADC模塊的實(shí)現(xiàn)為例詳細(xì)介紹驅(qū)動(dòng)工具箱模塊的實(shí)現(xiàn)方法。
依據(jù)驅(qū)動(dòng)工具箱的設(shè)計(jì)方案可知,驅(qū)動(dòng)ADC功能模塊分為配置模塊和API模塊。ADC配置模塊實(shí)現(xiàn)不同處理器初始化配置;API模塊(即ADC驅(qū)動(dòng)函數(shù)模塊)實(shí)現(xiàn)驅(qū)動(dòng)函數(shù)接口的配置及函數(shù)的調(diào)用。ADC功能模塊實(shí)現(xiàn)的主要步驟及內(nèi)容如表1所示。
ADC驅(qū)動(dòng)模塊庫(kù)中配置模塊通過(guò)初始化相關(guān)參數(shù)的配置,實(shí)現(xiàn)不同處理器下驅(qū)動(dòng)ADC使用時(shí)其相關(guān)的頭文件包含、配置文件生成、初始化結(jié)構(gòu)體參數(shù)配置及ADC的API開關(guān)定義。ADC驅(qū)動(dòng)API模塊由API函數(shù)接口變量的配置實(shí)現(xiàn)驅(qū)動(dòng)函數(shù)與控制算法的無(wú)縫連接,并配置函數(shù)體參數(shù)實(shí)現(xiàn)API函數(shù)的正確調(diào)用。
各驅(qū)動(dòng)模塊設(shè)計(jì)封裝好后添加到Simulink庫(kù)中就完成了驅(qū)動(dòng)工具箱的設(shè)計(jì)。圖3是驅(qū)動(dòng)代碼生成工具箱各功能模塊的結(jié)構(gòu)圖。
3 驅(qū)動(dòng)工具箱代碼生成模板的設(shè)計(jì)與實(shí)現(xiàn)
代碼生成模板基于模塊TLC設(shè)計(jì),其主要功能是驅(qū)動(dòng)函數(shù)初始化代碼的實(shí)現(xiàn)和API函數(shù)調(diào)用代碼的實(shí)現(xiàn)[5]。
3.1 設(shè)計(jì)
基于RTW的代碼生成工具設(shè)計(jì)驅(qū)動(dòng)工具箱代碼生成模板,主要包含系統(tǒng)目標(biāo)TLC和驅(qū)動(dòng)模塊TLC。系統(tǒng)目標(biāo)TLC在Matlab7.1版系統(tǒng)目標(biāo)osekworks.tlc基礎(chǔ)上修改,修改TLC組件的包含及相關(guān)文件名即可[6]。驅(qū)動(dòng)工具箱代碼生成模板結(jié)構(gòu)圖如圖4所示。