免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2515 | 回复: 4
打印 上一主题 下一主题

pci读取问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-03-29 08:39 |只看该作者 |倒序浏览
在内核中对pci的读写是利用0xCF8地址寄存器和0xCFC数据寄存器实现的
那位大侠帮忙解释一下在read byte的时候为什么要用
*value = inb(0xCFC + (reg & 3));
为什么不是直接从数据寄存器读取数据,而是要用
0xCFC + (reg & 3)
reg & 3表示什么意思?

论坛徽章:
0
2 [报告]
发表于 2007-03-29 09:47 |只看该作者
这是io port的访问方式,每个体系结构有自己的指令集,如x86的in、out系列就是

论坛徽章:
0
3 [报告]
发表于 2007-03-29 10:46 |只看该作者
inb只取一个字节0xCFC数据寄存器好象是4个连续的io地址吧,0xCFC到0xCFf

所以这里 inb(0xCFC + (reg & 3)); 的 (reg & 3)是个偏移量

论坛徽章:
0
4 [报告]
发表于 2007-03-29 15:02 |只看该作者
(reg & 3)的用意是这样的,
0&3=0
1&3=1
2&3=2
3&3=3
4&3=0
5&3=1
.....
楼主明白了吧?

论坛徽章:
0
5 [报告]
发表于 2007-03-30 19:02 |只看该作者

回复 #4 epegasus 的帖子

OK,thank you!
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP