青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

milkyway的窩

最初想法的誕生地

 

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


關鍵詞
:PCI總線 配置空間 操作系統
轉自:http://topdzh.byethost4.com/viewthread.php?tid=48&extra=page%3D1

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

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

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

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

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

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

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

由于PC-AT兼容系統CPU只有內存和I/O兩種空間,沒有專用的配置空間,PCI協議規定利用特定的I/O空間操作驅動PCI橋路轉換成配置空間的操 作。目前存在兩種轉換機制,即配置機制1#和配置機制2#。配置機制2#在新的設計中將不再被采用,新的設計應使用配置機制1#來產生配置空間的物理操 作。這種機制使用了兩個特定的32位I/O空間,即CF8h和CFCh。這兩個空間對應于PCI橋路的兩個寄存器,當橋路看到CPU在局部總線對這兩個 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設備配置空 間62個雙字的配置寄存器(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端口CF8h80000000h;然后用I/O命令讀取配置空間的數據寄存器 CFCh。如果該寄存器值與該PCI設備的Device ID及Vendor ID不相符,則依次遞增設備號/總線號,重復上述操作直到找到該設備為止。如果查完所有的設備號/總線號(1~5)仍不能找到該設備,則應當考慮硬件上的 問題。對于多功能設備,只要設備配置寄存器相應的功能號值,其余步驟與單功能設備一樣。

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

CODE:
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;

}

}

retrn -1

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

CODE:
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視頻圖像采集卡的過程中,該方法得到了實際應用。

posted on 2007-01-02 14:46 milkyway 閱讀(6210) 評論(1)  編輯 收藏 引用 所屬分類: linux

評論

# re: 用I/O命令訪問PCI總線設備配置空間 2009-05-19 21:46 學生

樓主能不能留一下聯系方式?我的Email:washulei@yahoo.com.cn,想跟您詳細請教一下I/O-mapped 和 Memory-mapped兩種方式的區別。謝謝。  回復  更多評論   

導航

統計

公告

隨筆皆原創,文章乃轉載. 歡迎留言!

常用鏈接

留言簿(37)

隨筆分類(104)

隨筆檔案(101)

文章分類(51)

文章檔案(53)

wince牛人

搜索

積分與排名

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久久青草婷婷精品综合日韩| 亚洲精品在线看| 在线欧美一区| 久久久亚洲一区| 亚洲网站视频福利| 久久精品视频导航| 国产日韩三区| 久久久久久久一区二区| 久久中文字幕一区二区三区| 亚洲第一页在线| 久久久蜜桃一区二区人| 夜夜爽av福利精品导航| 欧美激情视频在线播放| 欧美高清在线视频| 一区二区三区 在线观看视频| 国产乱肥老妇国产一区二| 久久精品国产99精品国产亚洲性色| 欧美激情女人20p| 午夜精品久久久99热福利| 怡红院精品视频| 国产精品乱码妇女bbbb| 久久久.com| 性久久久久久久久久久久| 欧美第一黄色网| a91a精品视频在线观看| 欧美顶级少妇做爰| 一区二区三区色| 夜夜嗨av一区二区三区中文字幕| 午夜精品一区二区三区电影天堂 | 久久精品一区| 亚洲午夜未删减在线观看| 黑人一区二区三区四区五区| 欧美日韩国产免费观看| 麻豆精品视频在线观看| 欧美一区视频| 最新国产成人av网站网址麻豆 | 久久精品五月婷婷| 欧美日韩国产综合久久| 悠悠资源网久久精品| 亚洲欧美日韩高清| 西瓜成人精品人成网站| 一区二区三区导航| 久久先锋影音av| 久久精品免费| 99成人精品| 欧美成年人网站| 欧美激情一区二区三区四区| 国内精品久久久久久久影视麻豆| 国产欧美va欧美va香蕉在| 国产精品久久久久9999高清| 欧美日韩中文在线| 欧美性jizz18性欧美| 欧美三区美女| 亚洲人成在线播放网站岛国| 亚洲精品日日夜夜| 中文在线资源观看视频网站免费不卡| 99精品久久免费看蜜臀剧情介绍| 亚洲精品一区二区三区四区高清| 久久网站热最新地址| 亚洲综合二区| 久久精品日产第一区二区| 亚洲精品久久久久中文字幕欢迎你| 久久精品一二三区| 国产精品成人一区二区艾草| 日韩系列在线| 亚洲人成人77777线观看| 欧美成人午夜激情视频| 亚洲黄色精品| 亚洲欧美日韩综合aⅴ视频| 欧美激情国产日韩| 国产一区二区三区日韩欧美| 欧美日韩1区2区| 久久综合狠狠综合久久综合88| 亚洲视频专区在线| 亚洲精品久久久久久久久久久久久 | 激情综合亚洲| 伊人成综合网伊人222| 欧美中文字幕在线| 欧美国产精品专区| 免费在线成人| 国产美女扒开尿口久久久| 小嫩嫩精品导航| 欧美一级午夜免费电影| 在线看片成人| 亚洲精品一二| 欧美好吊妞视频| 中文国产成人精品| 亚洲欧美日韩国产综合精品二区| 亚洲精品少妇网址| 久久人人97超碰精品888| 亚洲视频一区在线观看| 亚洲精品乱码久久久久久按摩观| 欧美成人高清视频| 亚洲免费影院| 老司机精品导航| 亚洲在线1234| 亚洲欧洲在线看| 国产精品久久久久9999吃药| 美女脱光内衣内裤视频久久影院 | 欧美**字幕| 亚洲自拍16p| 久久成人18免费观看| 亚洲日本精品国产第一区| 99综合电影在线视频| 国内一区二区三区| 欧美激情在线播放| 国产精品资源| 91久久久亚洲精品| 黄色av成人| 亚洲综合日韩中文字幕v在线| 亚洲欧美在线x视频| 久久久另类综合| 亚洲欧美精品suv| 欧美不卡激情三级在线观看| 久久精品国产999大香线蕉| 伊大人香蕉综合8在线视| 亚洲一区二区高清| 欧美成人在线网站| 麻豆成人综合网| 欧美伊人久久久久久午夜久久久久| 亚洲高清不卡一区| 国产精品专区h在线观看| 日韩一区二区高清| 国产精品久久久久国产精品日日| 免费亚洲电影在线| 国产视频精品网| 亚洲在线免费观看| 亚洲一区二区三区四区在线观看| 免费一级欧美片在线观看| 久久嫩草精品久久久精品| 久久国产精品72免费观看| 性欧美xxxx大乳国产app| 欧美三级电影大全| 亚洲精品三级| 亚洲私人黄色宅男| 欧美日韩福利| 日韩视频一区二区三区| 一本色道久久综合亚洲精品高清| 免费看亚洲片| 亚洲国产欧美一区二区三区丁香婷| 欧美日韩国产丝袜另类| 最新中文字幕一区二区三区| 亚洲国产成人精品女人久久久| 亚洲国产mv| 亚洲精品免费观看| 欧美国产日韩二区| 亚洲免费观看在线观看| 日韩视频―中文字幕| 欧美人与性动交a欧美精品| 久久精品欧洲| 黄色综合网站| 欧美v国产在线一区二区三区| 欧美激情va永久在线播放| 亚洲乱码国产乱码精品精98午夜 | 欧美韩国日本综合| 99视频国产精品免费观看| 亚洲欧美日韩高清| 国产综合视频在线观看| 欧美va亚洲va国产综合| 在线亚洲自拍| 亚洲精品视频一区| 欧美视频二区| 欧美在线地址| 亚洲国产免费| 久久成人18免费网站| 亚洲大胆女人| 欧美日韩一区二区在线| 欧美激情视频一区二区三区在线播放| 亚洲激情视频在线| 国产精品观看| 久久精品亚洲一区二区三区浴池| 亚洲国产成人porn| 性亚洲最疯狂xxxx高清| 亚洲第一偷拍| 国产精品中文在线| 久久人人97超碰精品888| 国产视频一区二区在线观看| 欧美午夜精品电影| 亚洲区在线播放| 亚洲综合色婷婷| 亚洲精品网址在线观看| 一区二区三区日韩在线观看| 伊伊综合在线| 欧美在线亚洲一区| 亚洲视频网在线直播| 久久影音先锋| 性一交一乱一区二区洋洋av| 久久激情综合网| 欧美在线视频不卡| 欧美日韩国产页| 欧美韩日一区| 亚洲黄色高清| 欧美韩日一区二区| 亚洲伦理久久| 亚洲午夜久久久久久久久电影院| 久热综合在线亚洲精品| 欧美大片一区二区| 亚洲第一天堂av| 欧美jizzhd精品欧美巨大免费| 免费高清在线视频一区·|