浓毛老太交欧美老妇热爱乱,蜜臀性色av免费,妺妺窝人体色www看美女,久久久久久久久久久大尺度免费视频,麻豆人妻无码性色av专区

位置:51電子網(wǎng) » 技術資料 » 接口電路

PCI總線數(shù)據(jù)輸出板驅(qū)動程序的開發(fā)

發(fā)布時間:2008/8/16 0:00:00 訪問次數(shù):407

pci(perip heral component interconnect )是一種先進的高性能32/64位局部總線,支持線性突發(fā)傳輸,數(shù)據(jù)最大傳輸率可達132mb/s。

同時,pci總線存取延誤小,采用總線主控和同步操作,不受處理器限制,具有自動配置功能,非常適合于高速外設。所以,它正迅速取代原先的isa總線成為微型計算機系統(tǒng)的主流總線。

隨著工業(yè)控制pci設備的增多,需要開發(fā)大量專用wdm驅(qū)動程序。鑒于直接用ddk開發(fā)驅(qū)動程序難度大,周期長,本文介紹了用driverstudio套件開發(fā)wdm驅(qū)動程序的方法以及基于9052總線控制器的d/a數(shù)據(jù)輸出板卡的硬件結構。

圖1 d/a數(shù)據(jù)輸出板卡硬件結構

d/a數(shù)據(jù)輸出板卡硬件結構如圖1所示。硬件電路由pci總線控制器9052,數(shù)據(jù)鎖存器ls373,d/a轉換芯片,eeprom組成。板卡上電時,讀取eeprom內(nèi)容初始化9052配置空間,據(jù)此為板卡分配合適的內(nèi)存空間和i/o空間,對空間進行讀寫操作。首先,上位機通過writefile()調(diào)用設備驅(qū)動程序,發(fā)送兩個12位數(shù)字量,驅(qū)動程序相應函數(shù)將兩個數(shù)字量分別寫入兩路鎖存器,送入d/a轉換芯片,最后輸出模擬量。

9052空間配置

pci9052芯片的配置寄存器分為pci配置寄存器和局部配置寄存器,二者都可以由pci總線和串行eeprom訪問。在pci配置寄存器中的設備id、制造商id、版本號、首區(qū)類代碼、類別代碼、指令寄存器和狀態(tài)寄存器等寄存器在所有的pci設備中都必須實現(xiàn),具體設置可參考相關資料。pci配置寄存器提供有6個基地址寄存器(base0~base5)這些基地址都是系統(tǒng)中的物理地址,其中base0和base1是用來訪問局部配置寄存器的基地址,base0是映射到內(nèi)存的基地址,base1是映射到i/o的基地址,可用于通過內(nèi)存和i/o來訪問局部配置寄存器。這兩個基地址可固定用于pci9052芯片的寄存器操作。通過base2~base5四個空間最多可以訪問局部端所接的4個芯片,實現(xiàn)4個局部地址空間(局部空間0~3)的pci總線訪問。

本設計選取las0(local address space 0)來訪問局部端的鎖存器,該尋址空間大小為4kb,與其有關的寄存器有四個:las0范圍寄存器、las0局部基址寄存器、las0局部總線區(qū)域描述符和片選0基址寄存器。las0范圍寄存器規(guī)定了地址空間的大小。

由于需要4kb的地址空間,所以las0范圍寄存器的值為0xfffff000;基地址必須是地址空間的整數(shù)倍,末尾為局部空間使能為,所以局部基址寄存器設為0x00000001;las0局部總線區(qū)域描述符設為0x00000102;片選0基址寄存器設為0x00000081。

驅(qū)動程序框架的建立

1 開發(fā)環(huán)境的選擇

驅(qū)動程序開發(fā)選用numega公司的driverstudio,它包含vtoolsd、softice和driverworks等開發(fā)工具,driverworks用于開發(fā)kmd和wdm驅(qū)動程序,它適用于windows 98/me/nt/2000/xp操作系統(tǒng)。driverworks,需要相應ddk的支持,把ddk用類的形式進行封裝,使用起來非常方便。

開發(fā)環(huán)境的建立

首先要安裝軟件。必須按照下面的順序安裝:

安裝microsoft visual studio c++ 6.0。在安裝過程中,必須選中“注冊環(huán)境變量”選項。

安裝操作系統(tǒng)對應的ddk(2000系統(tǒng)安裝2000ddk,xp系統(tǒng)安裝xpddk)。

安裝drivestudio3.1(若為xp系統(tǒng),必須安裝3.2以上的版本)。

接下來,編譯庫文件。用vc打開庫文件program files\compuware\ driverstudio\driverworks\source\ vdw libs.dsw,選擇build|batch build(編譯|批構件),從中選擇需要編譯的配置(32位機選“select all i386”)。若編譯無錯誤,就可以進行驅(qū)動程序的開發(fā)了。

3 生成驅(qū)動程序框架

從開始菜單啟動driver wizards,選擇driverworks project,開始創(chuàng)建一個驅(qū)動程序框架。

● 填寫驅(qū)動程序名稱,單擊next;
● 選擇驅(qū)動程序類型,這里選擇wdm driver驅(qū)動程序,單擊next;
● 選擇wdm function driver,單擊next;
● 選擇總線類型,這里選擇pci總線。填寫pci vendor id和pci device id,一般可以從硬件的使用說明書中看到,沒有的話可以用pciview軟件得到。后兩項pci subsystem id和pci revision id可以不填。單擊next;
● 選擇設備類的名稱和文件類名稱,默認即可,單擊next;
● 選擇需要的功能函數(shù),本設計需要i/o讀寫,必須添加i/o通信函數(shù)。添加讀函數(shù)pci_da_ioctl_read()和寫函數(shù)pci_da_ioctl_write(),單擊next;
● 選擇隊列方式,數(shù)據(jù)量大時選擇排隊,點擊next;
● 添加資源。資源分為i/o資源和內(nèi)存資源。添加資源時必須對應硬件相應得基地址寄存器。選擇direct存取方式,單擊next;
● 為i/o通信方式添加控制代碼,若不需要i/o通信,可不添加,單擊next;單擊finish,完成驅(qū)

pci(perip heral component interconnect )是一種先進的高性能32/64位局部總線,支持線性突發(fā)傳輸,數(shù)據(jù)最大傳輸率可達132mb/s。

同時,pci總線存取延誤小,采用總線主控和同步操作,不受處理器限制,具有自動配置功能,非常適合于高速外設。所以,它正迅速取代原先的isa總線成為微型計算機系統(tǒng)的主流總線。

隨著工業(yè)控制pci設備的增多,需要開發(fā)大量專用wdm驅(qū)動程序。鑒于直接用ddk開發(fā)驅(qū)動程序難度大,周期長,本文介紹了用driverstudio套件開發(fā)wdm驅(qū)動程序的方法以及基于9052總線控制器的d/a數(shù)據(jù)輸出板卡的硬件結構。

圖1 d/a數(shù)據(jù)輸出板卡硬件結構

d/a數(shù)據(jù)輸出板卡硬件結構如圖1所示。硬件電路由pci總線控制器9052,數(shù)據(jù)鎖存器ls373,d/a轉換芯片,eeprom組成。板卡上電時,讀取eeprom內(nèi)容初始化9052配置空間,據(jù)此為板卡分配合適的內(nèi)存空間和i/o空間,對空間進行讀寫操作。首先,上位機通過writefile()調(diào)用設備驅(qū)動程序,發(fā)送兩個12位數(shù)字量,驅(qū)動程序相應函數(shù)將兩個數(shù)字量分別寫入兩路鎖存器,送入d/a轉換芯片,最后輸出模擬量。

9052空間配置

pci9052芯片的配置寄存器分為pci配置寄存器和局部配置寄存器,二者都可以由pci總線和串行eeprom訪問。在pci配置寄存器中的設備id、制造商id、版本號、首區(qū)類代碼、類別代碼、指令寄存器和狀態(tài)寄存器等寄存器在所有的pci設備中都必須實現(xiàn),具體設置可參考相關資料。pci配置寄存器提供有6個基地址寄存器(base0~base5)這些基地址都是系統(tǒng)中的物理地址,其中base0和base1是用來訪問局部配置寄存器的基地址,base0是映射到內(nèi)存的基地址,base1是映射到i/o的基地址,可用于通過內(nèi)存和i/o來訪問局部配置寄存器。這兩個基地址可固定用于pci9052芯片的寄存器操作。通過base2~base5四個空間最多可以訪問局部端所接的4個芯片,實現(xiàn)4個局部地址空間(局部空間0~3)的pci總線訪問。

本設計選取las0(local address space 0)來訪問局部端的鎖存器,該尋址空間大小為4kb,與其有關的寄存器有四個:las0范圍寄存器、las0局部基址寄存器、las0局部總線區(qū)域描述符和片選0基址寄存器。las0范圍寄存器規(guī)定了地址空間的大小。

由于需要4kb的地址空間,所以las0范圍寄存器的值為0xfffff000;基地址必須是地址空間的整數(shù)倍,末尾為局部空間使能為,所以局部基址寄存器設為0x00000001;las0局部總線區(qū)域描述符設為0x00000102;片選0基址寄存器設為0x00000081。

驅(qū)動程序框架的建立

1 開發(fā)環(huán)境的選擇

驅(qū)動程序開發(fā)選用numega公司的driverstudio,它包含vtoolsd、softice和driverworks等開發(fā)工具,driverworks用于開發(fā)kmd和wdm驅(qū)動程序,它適用于windows 98/me/nt/2000/xp操作系統(tǒng)。driverworks,需要相應ddk的支持,把ddk用類的形式進行封裝,使用起來非常方便。

開發(fā)環(huán)境的建立

首先要安裝軟件。必須按照下面的順序安裝:

安裝microsoft visual studio c++ 6.0。在安裝過程中,必須選中“注冊環(huán)境變量”選項。

安裝操作系統(tǒng)對應的ddk(2000系統(tǒng)安裝2000ddk,xp系統(tǒng)安裝xpddk)。

安裝drivestudio3.1(若為xp系統(tǒng),必須安裝3.2以上的版本)。

接下來,編譯庫文件。用vc打開庫文件program files\compuware\ driverstudio\driverworks\source\ vdw libs.dsw,選擇build|batch build(編譯|批構件),從中選擇需要編譯的配置(32位機選“select all i386”)。若編譯無錯誤,就可以進行驅(qū)動程序的開發(fā)了。

3 生成驅(qū)動程序框架

從開始菜單啟動driver wizards,選擇driverworks project,開始創(chuàng)建一個驅(qū)動程序框架。

● 填寫驅(qū)動程序名稱,單擊next;
● 選擇驅(qū)動程序類型,這里選擇wdm driver驅(qū)動程序,單擊next;
● 選擇wdm function driver,單擊next;
● 選擇總線類型,這里選擇pci總線。填寫pci vendor id和pci device id,一般可以從硬件的使用說明書中看到,沒有的話可以用pciview軟件得到。后兩項pci subsystem id和pci revision id可以不填。單擊next;
● 選擇設備類的名稱和文件類名稱,默認即可,單擊next;
● 選擇需要的功能函數(shù),本設計需要i/o讀寫,必須添加i/o通信函數(shù)。添加讀函數(shù)pci_da_ioctl_read()和寫函數(shù)pci_da_ioctl_write(),單擊next;
● 選擇隊列方式,數(shù)據(jù)量大時選擇排隊,點擊next;
● 添加資源。資源分為i/o資源和內(nèi)存資源。添加資源時必須對應硬件相應得基地址寄存器。選擇direct存取方式,單擊next;
● 為i/o通信方式添加控制代碼,若不需要i/o通信,可不添加,單擊next;單擊finish,完成驅(qū)

相關IC型號

熱門點擊

 

推薦技術資料

耳機放大器
    為了在聽音樂時不影響家人,我萌生了做一臺耳機放大器的想... [詳細]
版權所有:51dzw.COM
深圳服務熱線:13692101218  13751165337
粵ICP備09112631號-6(miitbeian.gov.cn)
公網(wǎng)安備44030402000607
深圳市碧威特網(wǎng)絡技術有限公司
付款方式


 復制成功!