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

milkyway的窩

最初想法的誕生地

 

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


關(guān)鍵詞
:PCI總線 配置空間 操作系統(tǒng)
轉(zhuǎn)自:http://topdzh.byethost4.com/viewthread.php?tid=48&extra=page%3D1

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

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

1 PCI總線配置空間及配置機(jī)制

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

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

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

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

由于PC-AT兼容系統(tǒng)CPU只有內(nèi)存和I/O兩種空間,沒有專用的配置空間,PCI協(xié)議規(guī)定利用特定的I/O空間操作驅(qū)動PCI橋路轉(zhuǎn)換成配置空間的操 作。目前存在兩種轉(zhuǎn)換機(jī)制,即配置機(jī)制1#和配置機(jī)制2#。配置機(jī)制2#在新的設(shè)計中將不再被采用,新的設(shè)計應(yīng)使用配置機(jī)制1#來產(chǎn)生配置空間的物理操 作。這種機(jī)制使用了兩個特定的32位I/O空間,即CF8h和CFCh。這兩個空間對應(yīng)于PCI橋路的兩個寄存器,當(dāng)橋路看到CPU在局部總線對這兩個 I/O空間進(jìn)行雙字操作時,就將該I/O操作轉(zhuǎn)變?yōu)镻CI總線的配置操作。寄存器CF8h用于產(chǎn)生配置空間的地址(CONFIG-ADDRESS),寄存 器CFCh用于保存配置空間的讀寫數(shù)據(jù)(CONFIG-DATA)。

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


CF8H(局部總線):

當(dāng)CPU發(fā)出對I/O空間CFCh的操作時,PCI橋路將檢查配置空間地址寄存器CF8h的31位。如果為1,就在PCI總線上產(chǎn)生一個相應(yīng)的配置空間讀或?qū)懖僮鳎涞刂酚蒔CI橋路根據(jù)配置空間地址寄存器的內(nèi)容作如圖2所示的轉(zhuǎn)換。

CFCh (局部總線):

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

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

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



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

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

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

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

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,對地址本身無效,應(yīng)當(dāng)被屏蔽。對PC-AT兼容機(jī),I/O有效地址為16位,因此高位也應(yīng)被屏蔽。對于 內(nèi)存地址,最低位D0固定為0,而D1~D3用于指示該地址的一些物理特性[1],因此其低4位地址應(yīng)當(dāng)被屏蔽。需要指出的是該內(nèi)存地址是系統(tǒng)的物理地 址,在WINDOWS運行于保護(hù)模式時,需要經(jīng)過轉(zhuǎn)換得到相應(yīng)的線性地址才能對該內(nèi)存空間進(jìn)行直接讀寫。介紹該轉(zhuǎn)換方法的相關(guān)文章較為常見,此處不再贅 述。

上述程序給出了讀取配置空間里的基地址的方法。另有相當(dāng)多PCI設(shè)備通過配置空間的設(shè)備關(guān)聯(lián)區(qū)來設(shè)置該設(shè)備的工作狀態(tài),可輕易地用I/O命令進(jìn)行相應(yīng)的設(shè)置,無須編寫繁雜的驅(qū)動程序。在開發(fā)PCI視頻圖像采集卡的過程中,該方法得到了實際應(yīng)用。

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

評論

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

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

導(dǎo)航

統(tǒng)計

公告

隨筆皆原創(chuàng),文章乃轉(zhuǎn)載. 歡迎留言!

常用鏈接

留言簿(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>
            久久久久99| 国产精品欧美久久| 国产综合色精品一区二区三区| 久久久一区二区| 欧美在线播放一区| 欧美亚洲日本国产| 欧美主播一区二区三区美女 久久精品人 | 免费91麻豆精品国产自产在线观看| 午夜亚洲福利| 久久精品国产精品亚洲| 美女网站在线免费欧美精品| 欧美激情一区二区三区在线视频| 亚洲娇小video精品| 亚洲高清在线播放| 一区二区精品国产| 久久久久久久一区二区三区| 欧美成人免费va影院高清| 欧美日韩另类国产亚洲欧美一级| 国产精品久久一卡二卡| 一区二区视频在线观看| 亚洲一区二区三区免费观看| 久久狠狠亚洲综合| 亚洲日本va午夜在线影院| 午夜在线观看欧美| 欧美精品久久久久久| 国产午夜精品福利| 中国亚洲黄色| 欧美激情中文不卡| 久久av最新网址| 国产精品国产一区二区| 亚洲国产精品成人va在线观看| 午夜久久黄色| 亚洲精选久久| 母乳一区在线观看| 国产亚洲一区在线播放| 亚洲一二三区精品| 亚洲国产99| 久久一二三四| 国产麻豆精品theporn| 999在线观看精品免费不卡网站| 欧美综合国产| 亚洲视频二区| 欧美成年人视频网站| 国产亚洲福利社区一区| 一区二区日韩欧美| 欧美高清视频在线播放| 欧美一二三视频| 国产精品毛片va一区二区三区| 亚洲精品免费一二三区| 免费不卡中文字幕视频| 欧美伊人久久久久久午夜久久久久 | 欧美成人在线免费观看| 久久精品成人欧美大片古装| 欧美性猛交xxxx免费看久久久| 亚洲乱码国产乱码精品精天堂| 免费国产自线拍一欧美视频| 久久精品视频免费播放| 国产有码一区二区| 久久久久国内| 久久www成人_看片免费不卡| 国产精品视频专区| 午夜精品网站| 午夜久久一区| 激情久久久久| 男男成人高潮片免费网站| 久久精品国产精品亚洲综合| 国产亚洲综合性久久久影院| 久久精品综合网| 久久久精品日韩| 亚洲欧洲日本国产| 亚洲精品久久久一区二区三区| 欧美精品在线播放| 亚洲一区精彩视频| 欧美在线观看网址综合| 又紧又大又爽精品一区二区| 欧美高清在线视频观看不卡| 欧美高清视频一区| 一区二区三区视频观看| 亚洲影视九九影院在线观看| 国产乱码精品一区二区三区忘忧草 | 最新高清无码专区| 欧美日韩亚洲系列| 欧美一区二区日韩一区二区| 久久国产精品免费一区| 亚洲黄色天堂| 亚洲网友自拍| 一区二区视频欧美| 99re66热这里只有精品4| 国产精品无码永久免费888| 久久婷婷综合激情| 欧美伦理在线观看| 久久激情视频| 欧美极品影院| 欧美一区二区三区免费在线看| 久久久久国产成人精品亚洲午夜| 亚洲久色影视| 欧美一区在线视频| 亚洲视频在线观看一区| 欧美专区在线观看| 国产一区二区在线免费观看 | 久久婷婷影院| 亚洲在线免费观看| 久久综合久久88| 亚洲一区制服诱惑| 美女性感视频久久久| 亚洲一区二区三区免费视频| 久久日韩粉嫩一区二区三区| 亚洲影音先锋| 欧美mv日韩mv国产网站| 欧美中文字幕在线视频| 欧美日韩成人一区| 久久尤物视频| 欧美日韩精品免费观看视频| 国产精一区二区三区| 亚洲精品小视频在线观看| 亚洲一二三区精品| 亚洲日韩欧美视频| 午夜国产精品视频| 99精品视频免费在线观看| 久久国产66| 欧美一区二视频在线免费观看| 欧美日本韩国| 亚洲国产精品va在线看黑人| 国色天香一区二区| 亚洲欧美日韩网| 亚洲欧美综合网| 国产精品成人一区二区三区吃奶| 欧美激情亚洲国产| 亚洲二区免费| 亚洲精品久久久久中文字幕欢迎你 | 亚洲欧美一级二级三级| 一区二区三区 在线观看视| 久久综合中文色婷婷| 久久躁狠狠躁夜夜爽| 狠狠色综合色综合网络| 亚洲欧美视频| 久久精品视频在线| 国模精品一区二区三区| 性高湖久久久久久久久| 久久av一区二区三区| 国产精品久久久久久亚洲调教| 99re热这里只有精品视频| 日韩亚洲视频| 欧美午夜电影在线观看| 亚洲天天影视| 久久精品视频va| 亚洲国产高清视频| 欧美精品一线| 亚洲视频一二区| 性久久久久久久久| 狠狠色狠狠色综合日日91app| 久久综合色88| 日韩一级在线| 久久久亚洲一区| 91久久线看在观草草青青| 欧美国产成人在线| 艳妇臀荡乳欲伦亚洲一区| 欧美一区二区免费视频| 在线看无码的免费网站| 91久久久在线| 国产精品进线69影院| 亚洲一区自拍| 欧美成人免费播放| 正在播放日韩| 国产视频观看一区| 免费亚洲电影在线观看| 亚洲精品综合| 久久精品国产亚洲aⅴ| 在线日韩中文| 欧美色大人视频| 销魂美女一区二区三区视频在线| 欧美激情bt| 欧美亚洲日本一区| 在线观看欧美视频| 欧美色综合天天久久综合精品| 欧美中文字幕久久| 一区二区欧美精品| 欧美 亚欧 日韩视频在线| 中国av一区| 尤物99国产成人精品视频| 国产精品久久久久91| 久久人人97超碰精品888| 亚洲精品专区| 欧美高清在线精品一区| 欧美一区二区三区啪啪| 99国产精品99久久久久久| 狠狠入ady亚洲精品经典电影| 欧美午夜精品久久久久久人妖| 榴莲视频成人在线观看| 欧美一区观看| 国产精品99久久久久久www| 欧美成年人在线观看| 欧美伊人精品成人久久综合97| 亚洲精品一区二区三区av| 国产一区二区丝袜高跟鞋图片| 国产精品高潮在线| 欧美日韩123| 欧美黄免费看| 欧美成人黑人xx视频免费观看| 欧美在线综合|