免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: wchtalk
打印 上一主题 下一主题

开发PCI驱动碰到的问题 [复制链接]

论坛徽章:
0
11 [报告]
发表于 2006-10-18 14:05 |只看该作者
zu_xf,看PCI的DMA碰到的问题.

无论是pci_alloc_consistent()还是 pci_map_single()都是在内核随机地申请虚拟空间,同时,通过把虚拟空间virt_to_bus()生成总线地址。

(1)不明白的是:这个总线地址因为是随机生成的虚拟地址的转换,它如何和实际设备的I/O空间对应上?因为I/O空间毕竟分段,并且可选择的。

(2)void set_dma_addr(unsigned int channel, unsigned int addr); 函数中的地址和上面的地址有什么关联?

论坛徽章:
0
12 [报告]
发表于 2006-10-18 16:25 |只看该作者

回复 11楼 wchtalk 的帖子

1.PCI设备的IO空地址是逻辑地址,由PCI初始化模块分配.并不是通过pci_alloc_consistent和pci_map_single()分配的.这两个函数在PCI驱动中主要用来分配PCI设备和CPU之间的共享内存,建议参考\drivers\net\e100\e100.c.
2.此处的地址应当是物理地址;总线地址是重映射后的逻辑地址,映射方法跟体系有关.

论坛徽章:
0
13 [报告]
发表于 2006-10-19 11:31 |只看该作者

回复 12楼 zu_xf 的帖子

zu_xf,谢谢,不过我的意思是说:

pci_alloc_consistent分配了共享区间,这个区间上面对应的是内存虚拟地址,但是下面和设备的地址空间怎么对应?主要是设备一般都有6个I/O区间,这样,共享地址到底和那个区间对应呢?我没有看到类似的说明。

论坛徽章:
0
14 [报告]
发表于 2006-10-19 12:04 |只看该作者
原帖由 wchtalk 于 2006-10-19 11:31 发表
zu_xf,谢谢,不过我的意思是说:

pci_alloc_consistent分配了共享区间,这个区间上面对应的是内存虚拟地址,但是下面和设备的地址空间怎么对应?主要是设备一般都有6个I/O区间,这样,共享地址到底和那个区间 ...

6个 base addres.有可能是io或者memory
ioread 可以读io
ioremap把memory转换成virt地址,虽然对我们是透明的,但是这个关系是通过内核业表来表示的。

论坛徽章:
0
15 [报告]
发表于 2006-10-19 12:47 |只看该作者

回复 14楼 flw2 的帖子

谢谢兄弟,
不过,我说得针对DMA的情况。

论坛徽章:
0
16 [报告]
发表于 2006-10-19 16:37 |只看该作者
pci_alloc_consistent分配的共享区间是PCI设备和CPU之间共享数据的,位于系统内存中,例如PCI网卡的接收缓冲区等等。
而PCI设备的6个地址空间用来映射设备本身的内存或者IO空间,位于PCI设备上,例如PCI显卡的显存,PCI网卡的配置寄存器空间,PCI桥上挂的其他PCI设备的IO或者内存空间等等。

两者根本不是一回事,没办法对应。。。。。

原帖由 wchtalk 于 2006-10-19 11:31 发表
zu_xf,谢谢,不过我的意思是说:

pci_alloc_consistent分配了共享区间,这个区间上面对应的是内存虚拟地址,但是下面和设备的地址空间怎么对应?主要是设备一般都有6个I/O区间,这样,共享地址到底和那个区间 ...

论坛徽章:
0
17 [报告]
发表于 2006-10-26 15:14 |只看该作者

谢谢zu_xf,有个中断的问题讨教:)

zu_xf,对PCI设备明白不少,最近,要加上中断,虽然,读情景分析,还是又糊涂问题请教。

我的设备系统没有分配中断号,我检查了,设备可以响应中断,但是,我不知道我的设备应该在系统中分配怎样的中断号?!我看了说通过中断请求路径表和路径互连器,但是我还是看不明白原理?

论坛徽章:
0
18 [报告]
发表于 2006-10-28 15:25 |只看该作者

回复 17楼 wchtalk 的帖子

系统在扫描PCI总线是读取PCI设备配置空间的PCI设备的PCI_INTERRUPT_PIN寄存器,然后使用一个混和函数处理后分配的,通常是CPU的一个外设中断(例如,我的就是CPU的IRQ1)。你的PCI设备驱动只需要去用就行了。当然了,如果想修改分配方法,需要自己修改代码。2.4内核,就看看pcibios_init和pci_fixup_irqs函数吧。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP