在线咨询
eetop公众号 创芯大讲堂 创芯人才网
切换到宽版

EETOP 创芯网论坛 (原名:电子顶级开发网)

手机号码,快捷登录

手机号码,快捷登录

找回密码

  登录   注册  

快捷导航
搜帖子
芯片精品文章合集(500篇!) 创芯人才网--重磅上线啦!
查看: 6953|回复: 0

[原创] WDM驱动中访问pci9054本地空间0的问题

[复制链接]
发表于 2011-11-22 23:18:01 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?注册

x

各位大哥,小弟最近遇到一个头疼的问题。我最近在弄windows下的WDM驱动,是一块基于pci9054的数据采集卡的驱动。

问题一:
系统发出IRP_MN_START_DEVICE后,在相应的IRP处理函数中获取到访问pci9054芯片内部寄存器的基地址pcibar1(I/O映射),及访问本地地址空间0的基地址pcibar2(内存映射),还有中断资源。但是读取pcibar1+LAS0RRpcibar1+LAS0BA等,并非从EEPROM加载的值,而需要我手动配置CNTRL[29]CNTRL[30]重新加载EEPROM的值。为什么系统上电的时候没有配置好???
部分代码如下:
         //CNTRL
寄存器的偏移地址为0x6C
         ULONG cntrl_value =READ_PORT_ULONG((PULONG)(pdx->pcibar1+0x6C));
         //
软件复位
        WRITE_PORT_ULONG((PULONG)(pdx->pcibar1+0x6C), cntrl_value|0x40000000);

         //
触发pci9054EEPROM重新加载本地配置寄存器
        WRITE_PORT_ULONG((PULONG)(pdx->pcibar1+0x6C), cntrl_value&0xDFFFFFFF);
        WRITE_PORT_ULONG((PULONG)(pdx->pcibar1+0x6C), cntrl_value|0x20000000);

         //
软件复位
         WRITE_PORT_ULONG((PULONG)(pdx->pcibar1+0x6C), cntrl_value&0xBFFFFFFF);

问题二:
按问题一的方法重新加载EEPROM的值之后,通过WRITE_REGISTER_ULONG((PULONG)(pdx->pcibar2+偏移地址), 数值),但是发现有些寄存器无法读写???如偏移地址0x20, 0x30, 0x34, 0x40。为什么???
注:没有重新加载EEPROM之前,本地空间0所有的偏移地址都无法读写,读出的都是0xFFFFFFFF
您需要登录后才可以回帖 登录 | 注册

本版积分规则

关闭

站长推荐 上一条 /2 下一条


小黑屋| 手机版| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-11-22 17:04 , Processed in 0.014413 second(s), 9 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
快速回复 返回顶部 返回列表