PCI设备初始化编程的过程.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
PCI设备初始化编程的过程

PCI设备初始化编程的过程这里以PowerPC上的PCI设备为例,介绍PCI设备初始化编程的过程,其他CPU的PCI基本框架是类似的. PowerPC的PCI控制器符合PCI2.2标准,以下使我解读的VxWorks系统PCI设备程序代码分析主要执行过程 1.初始化PCI设备 文件romInit.s中romInit()=======文件bootInit.c中romStart()========文件usrConfig.c中的usrInit()======文件syslib.c中的sysHwInit() syslib.c void sysHwInit (void){ //用于初始化系统硬件 //和网络,PCI有关的函数 #ifdef INCLUDE_EMAC_NETWORK //初始化媒介访问层MAL(控制EMAC和Buffer Descriptor BD间的数据传输) malReset(); #endif #ifdef INCLUDE_PCI pciInit(); //初始化PCI #endif #ifdef INCLUDE_NETWORK sysNetHwInit(); //初始化网络接口 #endif }   //该函数初始化PCI PCI的地址转换形式: CPU-PCI (master/initiator) 地址转换 PCI-CPU (slave/target) 地址转换 void pciInit() { unsigned short temp_short; /* * 初始化并 disable 所有的 PCI Master regions(三个), little endian,直接对寄存器R操作 */ sysPciOutLong(PMM0MA, PMM_UNUSED); sysPciOutLong(PMM1MA, PMM_UNUSED); sysPciOutLong(PMM2MA, PMM_UNUSED); /* 解释: PMM0MA:地址 0xEE400004, 控制PLB上的映射到PCI存储空间的range0大小和属性. 在PLB上共有三个ranges, PMM1MA代表区域rang1, PMM2MA代表区域range2. PMM_UNUSED: 0 range的定义 range: map PLB======PCI 64-bit PPBridge(PLB和PCI设备间的接口)responds as a target on the PLB bus in servral address ranges. These ranges allow a PLB Master to configure the PPBridge and to cause PPBridge to generate Mem I/O,interrupt acknowledge and special cycles to PCI bus. */ /* * Initially disable PCI Target region 2 to start. Region 1 is hardwired * to always be active. */ //PTM2MS:地址 0xEF400038,定义PCI存储空间的大小.这里清零 sysPciOutLong(PTM2MS, PTM_UNUSED); /* * Drive PCI 重新置位. 用于热启动,置位必须保持1ms */ //解释: 从PCI寄存器PCI_CFG_BRIDGE_OPT2中读出数值 其中 PPC405GP_PCI_BUSDEVFUNC = 0 PCI_CFG_BRIDGE_OPT2 = 0x60 temp_short = pciConfigIn(PPC405GP_PCI_BUSDEVFUNC, PCI_CFG_BRIDGE_OPT2, 2); //把读出的值放回寄存器PCI_CFG_BRIDGE_OPT2中 pciConfigOut(PPC405GP_PCI_BUSDEVFUNC, PCI_CFG_BRIDGE_OPT2, temp_short | 0x1000, 2); sysLocalDelay(1); /* 延时1ms kernel may not be up yet!! */ //再放一次 pciConfigOut(PPC405GP_PCI_BUSDEVFUNC, PCI_CFG_BRIDGE_OPT2, temp_short, 2); /* * 设置PCI Master(PMM),这是从本地存储地址Local memory address到PCI空间的映射 * CPU-PCI,参见文件 See config.h中的定义,参考 BS

文档评论(0)

almm118 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档