找回密码
 加入计匠网
搜索
热搜: BIOS ACPI CPU Windows
查看: 14264|回复: 6

问一个弱弱的问题,PCI bus number的问题

[复制链接]
发表于 2009-7-7 18:18:41 | 显示全部楼层 |阅读模式
PCI bridge 在被分配bus number之前系统是如何访问 pci bridge的  ,(可能是自己没仔细看协议),
发表于 2009-7-7 21:06:35 | 显示全部楼层
未分配之前,就分配,BIOS分配的过程,叫PCI枚举。
回复

使用道具 举报

 楼主| 发表于 2009-7-8 08:35:46 | 显示全部楼层
这个回答。。。。。鸡生蛋,蛋生鸡?没有分配bus number在CF8里面填哪个bus number?
回复

使用道具 举报

发表于 2009-7-8 09:06:27 | 显示全部楼层
to dangdangtop:
0 z/ U  e  b4 B7 y" hPCI SCAN阶段通过组合BUS+DEV+FUN可以访问PCI bus上的所有device,然后根据这些device configuration space中的Header Type可以辨别该device是不是P2P bridge,然后就可以配置P2P bridge。
0 O0 o+ W: I; u. _如果你想在BIOS PCI SCAN之前访问该P2P bridge下面的device那么你就要先分配primary/secondary/subordinate bus number然后就可以访问P2P bridge下面的device了。
; `/ ]! c6 s# l$ [  ~* P! z7 U% {: }2 U7 A+ q6 e
bini的意思应该是在没有配置P2P bridge之前想访问就要先配置这些信息。
! d( J% {6 r9 E& n3 D1 M/ e* v2 [. u4 t+ A8 b4 e$ Y4 h
REFF:[我所知道的BIOS->PCISCAN]
: T7 w8 ^5 u  [[Practice]
, [* r/ M6 O6 S$ [" i4 y+ E假設有一個 P2P bridge ,下面有一PCI device;現在必須要去 accessPCI device's Device ID/Vendor ID(that is, PCI config read). % S& G) _2 |8 {' Q. T- K
* m7 B8 `/ R1 {) }% P
但是,問題是:做這事的"點"要在 PCI_SCAN之"前"....那要如何做到呢 ^_^ ?
# W3 B3 f0 O" @5 o9 W-----------------$ w0 q9 A5 k2 o; E
Ans:假如要在很早前(Ex. PCI SCAN之前)去 access P2P bridge後面的 device,照理是做不到的,因為: P2P bridge沒有被正確的 configed...% Z, C3 l+ c' l6 j# n
2 C' F( j9 r/ D# u9 O
在此例中,P2P bridge的 primary/secondary/subordinate bus要被 set,後面的device才能被 accessed到 !$ u5 w. D( b0 V; N8 {
3 F4 ~" ?- p* a) r* A% g* P
所以,假如要在 PCI SCAN前就 access,則BIOS必須手動去 set 此 3 bytes;然後,PCI config access才能被 forward to 其後的 PCI devices...
回复

使用道具 举报

发表于 2009-7-8 14:03:34 | 显示全部楼层
没有鸡生蛋蛋生鸡啊,Bus0 你不用去分吧, 发现时 P2P bridge 就给他下层分配一个 bus num, 这样你不就可以访问下层bus了吗....
回复

使用道具 举报

 楼主| 发表于 2009-7-8 16:28:59 | 显示全部楼层
原来bus 0不用分。。。。
回复

使用道具 举报

发表于 2009-7-17 22:15:50 | 显示全部楼层
不只你一个人认为BUS0要分的, 呵呵, 以前我公司一个硬件专家硬是说BUS0可以分的, 还跟俺争起来了, 哈哈
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 加入计匠网

本版积分规则

Archiver|手机版|小黑屋|计匠网

GMT+8, 2025-3-5 00:08 , Processed in 0.038155 second(s), 16 queries .

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表