通用網(wǎng)絡協(xié)議一致性測試平臺的設計與研究
CPU主要用于接收來自控制機的網(wǎng)絡、協(xié)議、算法參數(shù)并生成實現(xiàn)網(wǎng)絡協(xié)議的測試套集,它可以直接對被測設備發(fā)送或者接收測試流,或者通過自定義總線將測試套集存儲在SRAM中,以實現(xiàn)快速的測試;它還實現(xiàn)對外圍配套器件的控制,包括DDR、Flash、噪聲、日歷時鐘以及譯碼等。CPU的PCI總線轉(zhuǎn)換出一個網(wǎng)絡,作為測試機的控制口,與控制機進行通信。CPU的串口總線接出一個RS232串口。
CPLD主要用于CPU啟動、數(shù)據(jù)總線的譯碼、FPGA邏輯配置等處理。
FPGA主要用于網(wǎng)絡接口處理和測試流發(fā)送、接收。首先,它提供兩個軟MAC核與PHY芯片相連實現(xiàn)DUT的發(fā)送和接收網(wǎng)口;其次,它提供另外兩個軟MAC核可以允許CPU直接與DUT進行發(fā)送接收測試流;也可以調(diào)用外部SRAM實現(xiàn)測試流發(fā)送接收等操作。FPGA和CPU之間有兩種不同的通訊接口,一種是數(shù)據(jù)總線接口,用于傳輸基本配置信息、狀態(tài)信息和SRAM數(shù)據(jù);一種是RGMII網(wǎng)口接口,用于傳輸測試流數(shù)據(jù)。
2.2.2 軟件組成
CPU軟件使用裁剪的定制LINUX操作系統(tǒng),內(nèi)核版本2.6以上,配IPv4協(xié)議棧等。CPU要實現(xiàn)的軟件功能比較多,軟件模塊有以下幾個:
(1)與控制機的通信模塊:負責接收來自控制機的網(wǎng)絡、協(xié)議、算法參數(shù)以及其他命令,并回送測試結(jié)果。
(2)算法實現(xiàn)模塊:實現(xiàn)協(xié)議中需要的算法。
(3)套集生成模塊:這是實現(xiàn)一個協(xié)議所需要的IP包的集合,包括發(fā)送的IP包和接收的IP包。每個不同的協(xié)議將產(chǎn)生定制的套集。每個套集的主要流程就是生成指定的某個協(xié)議所需IP包的過程。但是在協(xié)議的實現(xiàn)上,會按照協(xié)議的要求對相應的字段進行邊界測試、正確性和錯誤測試。并體現(xiàn)在不同的測試流里。
(4)測試流發(fā)送模塊:將存儲在SRAM里的測試流發(fā)送至DUT。
(5)測試流接收模塊:接收DUT發(fā)出的響應流,存儲在SRAM里。
(6)結(jié)果的協(xié)議分析模塊:CPU接收到測試流后,將其按照協(xié)議要求拆分成各個字段,并與協(xié)議進行比對分析。并將結(jié)果發(fā)送到與控制機的通信模塊。
在發(fā)送IP包和接收IP包有關聯(lián)的情況下,比如IV向量由接收包傳遞過來后才能確定下一包發(fā)送的內(nèi)容,必須由CPU直接進行測試。
在協(xié)議比較簡單,發(fā)送IP包和接收IP包沒有關聯(lián)的情況下,可以將測試套集裝載在SRAM里,由FPGA進行測試。這種情況下,也可以測試DUT的性能。
3 工作流程與測試內(nèi)容
協(xié)議一致性測試的主要過程包括:標準測試套集生成、測試執(zhí)行、結(jié)果分析三個部分。標準測試套集是通過分析協(xié)議來確定要測試的各個方面,從而產(chǎn)生測試用例的集合;測試執(zhí)行為測試用例的運行過程;接收數(shù)據(jù)分析是對測試結(jié)果進行分析,從而得到協(xié)議實現(xiàn)與協(xié)議說明是否一致的判決。如圖3所示。
協(xié)議一致性測試的內(nèi)容包括三個方面:一是協(xié)議格式、完整性的一致性測試,能夠正確識別收到的協(xié)議,并且按照協(xié)議做出正確的響應,響應的格式要與協(xié)議一致。二是測試協(xié)議中包含的算法的正確性。要能夠正確地加密和解密相應的信息。三是要對協(xié)議的實現(xiàn)過程包括握手、協(xié)商等進行一致性測試。
4 測試套集的生成方法
測試套集的生成方法理論上有可達性分析與測試序列兩種??蛇_性分析是從一個初始狀態(tài)出發(fā),生成并檢查系統(tǒng)能夠到達的所有狀態(tài)。測試序列方法是針對FSM中的單個轉(zhuǎn)移生成的測試子序列,再將這些測試子序列連接起來作為完整的測試序列。
通用平臺對測試套集的生成方法不作限定。因為網(wǎng)絡協(xié)議千差萬別,套用某一個方法是不現(xiàn)實的。因此不論什么方法,即使是手工方法,只要能夠正確地詮釋協(xié)議,生成的測試套集符合套集接口要求都可以直接輸入到平臺上實施測試。套集可以是完整的協(xié)議測試,也可以是某個協(xié)議測試套集的一部分。這樣大大方便了協(xié)議測試套集的調(diào)試與測試。
通用平臺也提供了一種測試套集的生成方法。就是將協(xié)議的分析過程體現(xiàn)在控制機的界面上,在界面上對協(xié)議進行分割,確定轉(zhuǎn)移點和子序列,并給出子序列的數(shù)據(jù)范圍。然后CPU的套集生成軟件將這些轉(zhuǎn)移點和子序列通過組合連接起來,形成測試套集。
5 結(jié)束語
在協(xié)議一致性測試的需求越來越迫切的同時,協(xié)議的功能越來越強,復雜性也越來越高,使得測試難度越來越大。通用平臺的硬件設計為以后協(xié)議的發(fā)展做好了可持續(xù)發(fā)展的基礎,而軟件設計也將提供開源和穩(wěn)定的接口以供協(xié)議的發(fā)展,增加對協(xié)議的支持。
評論