《電子技術應用》
您所在的位置:首頁 > 其他 > 業界動態 > 用I/O命令訪問PCI總線設備配置空間

用I/O命令訪問PCI總線設備配置空間

2008-12-04
作者:李 剛 吳彥鴻

  摘? 要: 通過對PCI協議配置機制的分析,提出一種直接用I/O" title="I/O">I/O命令訪問PCI總線設備配置空間的方法,給出了相應的C語言程序,并在實際應用中得到驗證,從而在大多數情況下避免了復雜的驅動程序開發。

  關鍵詞: PCI總線? 配置空間? 操作系統

?

  PCI總線推出以來,以其獨有的特性受到眾多廠商的青睞,已經成為計算機擴展總線的主流。目前,國內的許多技術人員已經具備開發PCI總線接口設備的能力。但是PCI總線的編程技術,也就是對PCI總線設備的操作技術,一直是一件讓技術人員感到頭疼的事情。PCI總線編程的核心技術是對相應板卡配置空間的理解和訪問。一般軟件編程人員基于對硬件設備原理的生疏,很難理解并操作配置空間,希望硬件開發人員直接告訴他們怎樣操作;而PCI總線硬件開發人員雖深刻地理解了其意義,在沒有太多編程經驗地前提下,也難于輕易地操作PCI板卡。結果大多是硬件技術人員花費大量時間和精力去學習DDK、WINDRVER等驅動程序開發軟件。

  作者在開發PCI總線接口設備時,經過對PCI總線協議的深入研究,從協議本身的角度出發,找到一種方便而快捷的PCI配置空間操作方法,只使用簡單的I/O命令即可找到特定的PCI總線設備并對其所有的配置空間進行讀寫操作。一旦讀得其配置空間的內容,即可得到操作系統對該PCI總線設備的資源分配" title="資源分配">資源分配。

1 PCI總線配置空間及配置機制

  為避免各PCI設備在資源的占用上發生沖突,PCI總線采用即插即用協議。即在系統建立時由操作系統按照各設備的要求統一分配資源,資源分配的信息由系統寫入各PCI設備的配置空間寄存器,并在操作系統內部備份。各PCI設備有其獨自的配置空間,設計者通過對各設備(或插槽)的IDSEL引腳的驅動來區分不同設備的配置空間。配置空間的前64個字節稱為配置空間的預定首區,它對每個設備都具有相同的定義且必須被支持;其后的空間稱為設備關聯區,由設備制造商根據需要定義。與編程有關的配置空間信息主要有:

  (1)設備號" title="設備號">設備號(Device ID)及銷售商號(Vendor ID),配置空間偏移量為00h,用于對各PCI設備的區分和查找。為了保證其唯一性,Vendor ID應當向PCI特別興趣小組(PCI SIG)申請而得到。

  (2)PCI基地址(PCI Base Address),配置空間偏移量為10h~24h,設備通過設定可讀寫的高位數值來向操作系統指示所需資源空間的大小。比如,某設備需要64K字節的內存空間,可以將配置空間的某基地址寄存器的高16位設成可讀寫的,而將低16位置為0(只可讀)。操作系統在建立時,先向所有位寫1,實際上只有高16位被接收而被置成了1,低16位仍為0。這樣操作系統讀取該寄存器時,返回值為FFFF0000h,據此操作系統可以斷定其需要的空間大小是64K字節,然后分配一段空閑的內存空間并向該寄存器的高16位填寫基地址。

  其它可能與編程有關的配置空間的定義及地址請參閱參考文獻[1]。

  由于PC-AT兼容系統CPU只有內存和I/O兩種空間,沒有專門的配置空間,PCI 協議規定利用特定的I/O空間操作驅動PCI橋路" title="橋路">橋路轉換成配置空間的操作。目前存在兩種轉換機制,即配置機制1#和配置機制2#。配置機制2#在新的設計中將不再被采用,新的設計應使用配置機制1#來產生配置空間的物理操作。這種機制使用了兩個特定的32位I/O空間,即CF8h和CFCh。這兩個空間對應于PCI橋路的兩個寄存器,當橋路看到CPU在局部總線" title="局部總線">局部總線對這兩個I/O空間進行雙字操作時,就將該I/O操作轉變為PCI總線的配置操作。寄存器CF8h用于產生配置空間的地址(CONFIG-ADDRESS),寄存器CFCh用于保存配置空間的讀寫數據(CONFIG-DATA)。

  配置空間地址寄存器的格式如圖1。

?

?

  CF8H(局部總線):

  當CPU發出對I/O空間CFCh的操作時,PCI橋路將檢查配置空間地址寄存器CF8h的31位。如果為1,就在PCI總線上產生一個相應的配置空間讀或寫操作,其地址由PCI橋路根據配置空間地址寄存器的內容作如圖2所示的轉換。

?

?

  CFCh (局部總線):

  設備號被PCI橋路譯碼產生PCI總線地址的高位地址,它們被設計者用作IDSEL信號來區分相應的PCI設備。6位寄存器號用于尋址該PCI設備配置空間64個雙字的配置寄存器(256字節)。功能號用于區分多功能設備的某特定功能的配置空間,對常用的單功能設備為000。其中PCI插槽的總線號隨系統(主板)的不同稍有區別,大多數PC機為1,工控機可能為2或3。為了找到某設備,應在系統的各個總線號上查找,直到定位。如果在0~5號總線上不能發現該設備,即可認為該設備不存在。

  理解了上述PCI協議里的配置機制后,就可以直接對CF8h和CFCh兩個雙字的I/O空間進行操作,查找某個PCI設備并訪問其配置空間,從而得到操作系統對該PCI設備的資源分配。

2?用I/O命令訪問PCI總線配置空間

  要訪問PCI總線設備的配置空間,必須先查找該設備。查找的基本根據是各PCI設備的配置空間里都存有其特定的設備號(Device ID)及銷售商號(Vendor ID),它們占用配置空間的00h地址。而查找的目的是獲得該設備的總線號和設備號。查找的基本過程如下:用I/O命令寫配置空間的地址寄存器CF8h,使其最高位為1,總線號及設備號為0,功能號及寄存器號為0,即往I/O端口CF8h寫80000000h;然后用I/O命令讀取配置空間的數據寄存器CFCh。如果該寄存器值與該PCI設備的Device ID及Vendor ID不相符,則依次遞增設備號/總線號,重復上述操作,直至找到該設備為止。如果查完所有的設備號/總線號(1~5)仍不能找到該設備,則應當考慮硬件上的問題。對于多功能設備,只要設置配置寄存器相應的功能號值,其余步驟與單功能設備一樣。

  如查找設備號為9054h,銷售商號為10b5的單功能PCI設備,用VC++6.0編寫的程序如下:

char bus; char device;?

unsigned int ioa0, iod;

int scan( )

{

????????????? bus=0; device=0;

????????????? for(char i=0; i<5; i++) {

???????????????????? for(char j=0; j<32; j++) {

??????????????????????????? bus=i;? device=j;

??????????????????????????? ioa0=0x80000000+bus*0x10000

???????????????????? +(device*8)*0x100;

??????????????????????????? _outpd(0xcf8, ioa0);?

??????????????????????????? iod=_inpd(0xcfc);

??????????????????????????? if (iod0==0x905410b5) return 0;

???????????????????? }

?????? }

return -1;

}

  調用子程序scan( ),如果返回值為-1,則沒有找到該PCI設備。如果返回值為0,則找到了該PCI設備。該設備的總線號和設備號分別在全局變量bus和device中,利用這兩個變量即可輕易對該設備的配置空間進行訪問,從而得到分配的資源信息。假設該PCI設備占用了4個資源空間,分別對應于配置空間10h~1ch, 其中前兩個為I/O空間,后兩個為內存空間,若定義其基地址分別為ioaddr1,ioaddr2,memaddr1,memaddr2,相應的程序如下:

unsigned short? ioaddr1, ioaddr2;

unsigned int? memaddr1, memaddr2;

unsigned int? iobase, ioa;

void getbaseaddr(char bus, char device);

{

  iobase=0x80000000+bus*0x10000+(device*8)*0x100;

  ioa=iobase+0x10;/*尋址基地址寄存器0*/

  _outpd(0xcf8, ioa);

  ioaddr1=(unsigned short)_inpd(0xcfc)&0xfffc;

  /*屏蔽低兩位和高16位*/

  ioa=iobase+0x14; /*尋址基地址寄存器1*/

  _outpd(0xcf8, ioa);

  ioaddr2=(unsigned short)_inpd(0xcfc)&0xfffc;

  ioa=iobase+0x18; /*尋址基地址寄存器2*/

  _outpd(0xcf8, ioa);

  memaddr1=_inpd(0xcfc) & 0xfffffff0;

  /*屏蔽低4位*/

  ioa=iobase+0x1c; /*尋址基地址寄存器3*/

  _outpd(0xcf8, ioa);

  memaddr2=_inpd(0xcfc) & 0xfffffff0;

}

  對于I/O基地址,最低兩位D0、D1固定為01,對地址本身無效,應當被屏蔽。對PC-AT兼容機,I/O有效地址為16位,因此高位也應被屏蔽。對于內存地址,最低位D0固定為0,而D1~D3用于指示該地址的一些物理特性[1],因此其低4位地址應當被屏蔽。需要指出的是該內存地址是系統的物理地址,在WINDOWS運行于保護模式時,需要經過轉換得到相應的線性地址才能對該內存空間進行直接讀寫。介紹該轉換方法的相關文章較為常見,此處不再贅述。

  上述程序給出了讀取配置空間里的基地址的方法。另有相當多PCI設備通過配置空間的設備關聯區來設置該設備的工作狀態,可輕易地用I/O命令進行相應的設置,無須編寫繁雜的驅動程序。在開發PCI視頻圖像采集卡的過程中,該方法得到了實際應用。

?

參考文獻

1劉顯慶,劉仁普. 微機總線規范. 北京:機械工業出版社,1995

2 Tom Shanley&Don Anderson.? PCI System Architecture.?MINDSHARE.INC, 1999

本站內容除特別聲明的原創文章之外,轉載內容只為傳遞更多信息,并不代表本網站贊同其觀點。轉載的所有的文章、圖片、音/視頻文件等資料的版權歸版權所有權人所有。本站采用的非本站原創文章及圖片等內容無法一一聯系確認版權者。如涉及作品內容、版權和其它問題,請及時通過電子郵件或電話通知我們,以便迅速采取適當措施,避免給雙方造成不必要的經濟損失。聯系電話:010-82306118;郵箱:aet@chinaaet.com。
热re99久久精品国产66热_欧美小视频在线观看_日韩成人激情影院_庆余年2免费日韩剧观看大牛_91久久久久久国产精品_国产原创欧美精品_美女999久久久精品视频_欧美大成色www永久网站婷_国产色婷婷国产综合在线理论片a_国产精品电影在线观看_日韩精品视频在线观看网址_97在线观看免费_性欧美亚洲xxxx乳在线观看_久久精品美女视频网站_777国产偷窥盗摄精品视频_在线日韩第一页
  • <strike id="ygamy"></strike>
  • 
    
      • <del id="ygamy"></del>
        <tfoot id="ygamy"></tfoot>
          <strike id="ygamy"></strike>
          欧美成人午夜| 久久深夜福利免费观看| 日韩午夜在线| 欧美精品日韩www.p站| 在线成人免费观看| 国产精品九九| 亚洲国产欧美不卡在线观看| 免费亚洲网站| 久久精品国产一区二区三| 欧美日韩国产综合在线| 猛男gaygay欧美视频| 亚洲国产人成综合网站| 欧美va亚洲va日韩∨a综合色| 亚洲永久免费观看| 久久久99精品免费观看不卡| 99人久久精品视频最新地址| 在线成人激情| 欧美日韩精品免费看| 欧美无砖砖区免费| 99人久久精品视频最新地址| 亚洲一区观看| 久久久国产午夜精品| 国产欧美一二三区| 黑人巨大精品欧美一区二区| 日韩性生活视频| 国产精品九九久久久久久久| 很黄很黄激情成人| 麻豆精品一区二区av白丝在线| 亚洲在线网站| 亚洲第一页在线| 日韩视频免费在线| 亚洲一区欧美二区| 亚洲女女做受ⅹxx高潮| 在线观看av不卡| 最新国产拍偷乱拍精品| 99视频精品在线| 亚洲欧美制服另类日韩| 亚洲欧美日韩一区| 国产人妖伪娘一区91| 国产视频一区二区在线观看| 亚洲二区在线观看| 国产精品欧美激情| 亚洲欧美日韩高清| 国产视频一区在线| 欧美亚州在线观看| 国产精品一卡二| 亚洲视频专区在线| 欧美午夜精品一区| 午夜一区在线| 久久激情五月婷婷| 欧美日韩成人在线播放| 亚洲福利视频三区| 亚洲欧美日韩在线| 午夜亚洲性色福利视频| 欧美日韩国产一区二区三区| 亚洲一区二区三区精品在线| 欧美一区二区视频在线观看2020| 制服丝袜亚洲播放| 国模私拍一区二区三区| 狠狠色丁香婷婷综合影院| 国产精品天天看| 在线观看av不卡| 久久伊人免费视频| 亚洲视频你懂的| 久热成人在线视频| av72成人在线| 欧美日韩不卡一区| 欧美v国产在线一区二区三区| 一本久久a久久免费精品不卡| 国产精品红桃| 99视频一区二区三区| 国产精品高潮呻吟久久av黑人| 亚洲国产日韩一区二区| 伊人影院久久| 欧美va亚洲va国产综合| 亚洲国产精品电影| 99精品欧美一区二区三区| 亚洲精品在线观| 国产精品视频福利| 91久久国产精品91久久性色| 欧美国产在线电影| 美日韩精品免费观看视频| 亚洲精品国产精品久久清纯直播| 欧美三级中文字幕在线观看| 嫩草国产精品入口| 亚洲欧洲日本在线| 国产一区二区三区四区在线观看| 国产精品久久久久婷婷| 国产一区二区毛片| 亚洲欧洲日韩在线| 久久久久久久网| 国产日韩欧美精品一区| 亚洲欧美国产精品va在线观看| 亚洲桃色在线一区| 亚洲视频网在线直播| 国产精品一二一区| 欧美精品手机在线| 99亚洲视频| 久久久精品国产免费观看同学| 蜜臀99久久精品久久久久久软件| 久久亚洲综合色| 宅男噜噜噜66国产日韩在线观看| 国产精品99久久久久久久vr| 亚洲欧洲日本在线| 国产一区二区| 久久久国产精品一区二区三区| 欧美一区亚洲一区| 日韩一级在线观看| 在线欧美不卡| 久久成人免费电影| 欧美三级视频在线观看| 亚洲第一网站免费视频| 欧美日韩国产成人高清视频| 亚洲人成网站精品片在线观看| 国产精品一区二区久激情瑜伽| 亚洲欧美一区二区精品久久久| 精品成人一区二区| 欧美连裤袜在线视频| 亚洲国产va精品久久久不卡综合| 国产日本欧美一区二区三区在线| 亚洲主播在线| 欧美在线网址| 男人天堂欧美日韩| 国产三级欧美三级日产三级99| 黄色成人av网站| 一区二区三区在线免费视频| 欧美性jizz18性欧美| 亚洲欧美一区二区精品久久久| 亚洲裸体俱乐部裸体舞表演av| 国产一区香蕉久久| 欧美激情一区二区三区四区| 性欧美1819性猛交| 亚洲国产欧美一区二区三区同亚洲| 韩国欧美一区| 欧美午夜精品久久久久久久| 黑人巨大精品欧美一区二区小视频| 欧美成人精品h版在线观看| 黄色资源网久久资源365| 久久久久88色偷偷免费| 欧美国产日韩二区| 日韩视频在线一区二区| 欧美区亚洲区| 麻豆久久婷婷| 亚洲欧美激情一区二区| 国产精品视频专区| 国内精品视频在线观看| 亚洲精品日韩精品| 激情综合在线| 狠狠色丁香婷综合久久| 久久成人一区二区| 久久精品毛片| 国产精品对白刺激久久久| 免费一级欧美在线大片| 亚洲——在线| 亚洲欧洲日本一区二区三区| 日韩视频精品在线| 欧美吻胸吃奶大尺度电影| 日韩写真在线| 久久综合九九| 国产日韩欧美亚洲一区| 欧美另类一区| 久久久中精品2020中文| 国产精品久久久久高潮| 久久精品国产96久久久香蕉| 亚洲国产小视频| 久久久久国产一区二区| 亚洲一区三区电影在线观看| 亚洲福利专区| 一区二区日韩欧美| 欧美大片在线观看一区| 亚洲在线一区二区三区| 免费欧美电影| 欧美精品福利在线| 99国产成+人+综合+亚洲欧美| 欧美综合国产精品久久丁香| 国产精品99免费看| 亚洲专区一区二区三区| 国内揄拍国内精品少妇国语| 欧美体内she精视频在线观看| 香港久久久电影| 亚洲第一狼人社区| 一区二区三区日韩欧美精品| 久久久国产午夜精品| 亚洲男人的天堂在线观看| …久久精品99久久香蕉国产| 欧美国产精品v| 99视频精品在线| 亚洲精品视频在线播放| 伊人久久亚洲影院| 国产深夜精品| 国产精品免费网站| 欧美日韩免费精品| 亚洲破处大片| 欧美国产亚洲另类动漫| 久久精品123| 久久天天躁夜夜躁狠狠躁2022| 亚洲国产精品久久| 一区二区三区四区国产精品| 欧美日韩国产在线一区| 欧美永久精品| 国内成人精品一区| 另类亚洲自拍| 最近中文字幕日韩精品| 久久精品欧美日韩精品| 久久成人精品视频| 国产揄拍国内精品对白| 国产精品视频免费在线观看| 久久免费的精品国产v∧| 影音先锋久久| 亚洲精品免费在线观看| 亚洲欧洲一区二区在线观看| 亚洲二区免费| 欧美性猛交xxxx乱大交蜜桃| 欧美视频在线免费| 亚洲色诱最新| 久久成人精品电影| 欧美一级片在线播放| 一区二区毛片| 亚洲激情av| 欧美人成免费网站| 亚洲美女电影在线| 久久日韩精品| 国产亚洲精品7777| 亚洲国产精品一区| 欧美福利专区| 久久爱www| 久久亚洲影音av资源网| 亚洲欧美日韩国产一区二区| 国内精品久久久久影院 日本资源| 老司机精品久久| 欧美日韩免费一区二区三区视频| 欧美日韩在线影院| 亚洲福利av| 欧美日韩高清在线一区| 在线观看成人一级片| 国产精品一区二区三区四区五区| 在线看日韩av| 欧美激情性爽国产精品17p| 亚洲一区二区三区四区五区午夜| 亚洲国产日韩在线一区模特| 欧美视频一二三区| 欧美日韩午夜视频在线观看| 好吊色欧美一区二区三区视频| 欧美成人免费在线| 另类天堂视频在线观看| 国产精品色网| 在线免费观看一区二区三区| 欧美视频专区一二在线观看| 亚洲国产日韩在线一区模特| 久久精品1区| 一区二区电影免费观看| 久久久久99| 欧美精品18| 欧美国产国产综合| 亚洲精品久久久久久一区二区| 国产综合久久久久久鬼色| 亚洲午夜一区二区三区| 欧美性理论片在线观看片免费| 久久免费黄色| 国产午夜精品一区二区三区欧美| 亚洲美女在线看| 欧美在线1区| 久久精品亚洲| 国产视频在线观看一区二区| 久久精品亚洲精品| 亚洲日本中文字幕免费在线不卡| 久久天堂av综合合色| 国产一区二区日韩精品| 老司机午夜精品| 欧美精品麻豆| 国产精品久久久久久久久久妞妞| 亚洲高清不卡在线| 久久野战av| 性久久久久久| 激情综合网址| 免费在线视频一区| 性高湖久久久久久久久| 国产精品扒开腿做爽爽爽视频| 国产精品久久午夜| 国产日韩一区二区三区在线播放| 亚洲福利视频在线| aa日韩免费精品视频一| 国产日韩欧美综合在线| 国产精品综合视频| 一区二区三区四区国产精品| 午夜精品在线| 亚洲伦理久久| 亚洲视频在线二区| 91久久夜色精品国产九色| 亚洲毛片在线观看| 亚洲尤物在线| 国产一区二区三区观看| 欧美日韩美女在线| 伊人久久婷婷色综合98网| 国产亚洲欧美一区在线观看| 久久久久久有精品国产| 欧美剧在线免费观看网站| 一区二区三区在线观看欧美| 久久久91精品国产一区二区三区| 农村妇女精品| 亚洲国产第一| 国产精品免费看久久久香蕉| 久久久国产精品一区二区三区| 欧美成人免费在线| 亚洲人成精品久久久久| 黄色另类av| 亚洲欧美中日韩| 国产精品亚洲综合久久| 国产精品高潮呻吟视频| 久久黄色小说| 国产色综合久久| 香蕉久久久久久久av网站| 国产欧美在线播放| 亚洲精品影院在线观看| 久久精品国产免费看久久精品| 久久精品国产一区二区三区| 狠狠色狠狠色综合日日五| 亚洲视频中文字幕| 欧美激情乱人伦| aa级大片欧美三级| 噜噜爱69成人精品| 久久国产精品久久久久久久久久| 国产精品欧美一区喷水| 久久精品中文字幕一区二区三区| 欧美午夜电影完整版| 99人久久精品视频最新地址| 亚洲精品免费网站| 欧美v国产在线一区二区三区|