一種具有主從自適應(yīng)功能的CPCI通用處理模塊設(shè)計
掩碼具體含義如下,例如在0xF中寫入0x821F131F,0x13對應(yīng)為下行基地址寄存器1的掩碼,含義為基地址掩碼最高有效位(MSB)的位置。例如掩碼0x13表示掩碼的最高為在第19位?;刂?x93100000和掩碼0x13的關(guān)系見圖4,配置后地址范圍為0x9310 0000~0x931F FFFF。本文引用地址:http://2s4d.com/article/148131.htm
3 綜合嵌入式平臺中CPCI通用處理模塊工作方案
在CPCI底板總線上插有多個模塊時,這時需要同時考慮主模塊和從模塊的協(xié)同工作。針對提出的基于PCI6466的具有主從自適應(yīng)功能的CPCI通用處理模塊,考慮工作方案為:CPCI通用處理模塊作為主模塊時,主模塊的PCI6466工作在透明橋方式,這時由于從模塊的PCI6466工作在非透明模式,所以需要由主模塊在從模塊PCI6466的次端配置從模塊的上行基地址和下行翻譯地址,同時從模塊需要對自己的上行翻譯地址和下行基地址進行配置。
為了使系統(tǒng)中主從模塊對CPCI訪問空間的配置更加智能,在系統(tǒng)上電時,主模塊向從模塊的基地址寄存器寫入0xFFFF FFFF,然后讀出,根據(jù)讀出數(shù)據(jù)中0b1的個數(shù)確定從模塊需要多少存儲器空間。然后自行分配相應(yīng)大小空間并將基地址寫入基地址寄存器。
需要考慮的一點是,具有自適應(yīng)功能的CPCI通用處理模塊由于要在系統(tǒng)槽和外設(shè)槽2種插槽中使用,所以一般情況下都是直接將PCI6466配置成初端先啟動或次端先啟動,并不會通過考慮模塊具體的使用來設(shè)置到底是初端先啟動還是次端先啟動。這樣帶來的問題是,插入系統(tǒng)槽和外設(shè)槽的模塊被同時配置成初端先啟動時,若主模塊在上電復(fù)位結(jié)束后即訪問CPCI總線對各個從模塊的次端進行配置,但從模塊的PCI-PCI橋接器配置成初端先啟動,即從模塊操作系統(tǒng)啟動后,對橋的初端進行配置后,次端才能進行配置。
造成的結(jié)果是,主控模塊上電復(fù)位后訪問從模塊的次端,CPCI總線被拉死,程序停止執(zhí)行,看門狗復(fù)位有效,復(fù)位整個系統(tǒng)。主模塊再次訪問從模塊,CPCI再次被拉死,反復(fù)復(fù)位。這時就需要操作主控模塊待從模塊配置完成后再對從模塊進行配置,防止系統(tǒng)被拉死。
4 結(jié)語
本設(shè)計提出的基于PCI6466的具有主從自適應(yīng)功能的CPCI通用處理模塊在具體的應(yīng)用環(huán)境中具有很大的便利性,能夠方便地應(yīng)用在CPCI底板總線的系統(tǒng)槽和外設(shè)槽中,同時針對一些可能出現(xiàn)的問題做針對性的處理,為CPCI系統(tǒng)提供了一種通用的、具有主從自適應(yīng)功能的通用處理模塊的解決方案。
評論