描述:
最近做PCI方面的软件开发遇到个问题,PCI配置空间的读写是通过操作端口0xcf8与0xcfc来完成的,而系统中所有PCI设备对应的端口都是0xcf8和0xcfc二个端口,具体操作哪个设备是通过是看0xcf8中写入的是哪个地址。
现在问题来了,如果是个多线程的程序很有可能在配置地址和读数据这二条命令见参数同步问题,但是我在网上看到的代码都没有考虑同步问题的处理,不知道是不是我理解有误其实并没有同步问题,如下面红色字体代码部分。
char bus;char device;
unsigned int ioa0,iod;
int scan( )
{
bus=0;device=0;
for(char i=0;i<5;i++) {
for(char j=0;j<32;j++) {
bus=i; device=j;
ioa0=0x80000000+bus*0x10000+(device*8)*0x100; //这里是设备的地址配置信息
1 _outpd(0xcf8,ioa0); //这里是想配置地址寄存器写地址
2 如果代码执行到这来其他线程切入,执行一个_outpd(0xcf8,iob1)操作,那么下面的_inpd(0xcfc)操作不是就不能正确的读出ioa0对应的数据??
3 iod=_inpd(0xcfc); //这里是读配置地址对应的设备地址寄存器偏移处读出内容
...........................
...........................
...........................
}
解决方案1:
对于某个资源(叫设备也行),存在潜在的多个访问者(多个访问者可能会导致内容不完成/不一致)的时候,才需要考虑同步的问题。 如果不会存在多个访问者,就不需要考虑同步的问题。
解决方案2: 简单点,就使用windriver开发一个(如果使用的是plx芯片的话,plx提供驱动开发包);
如果愿意研究的话,使用微软的WDK,比DDK开发WDM驱动简单多了。
楼上说的对,如果你在windows下做驱动,需要用WDM去写,就是调用驱动底层去操作pci设备,在驱动底层层面考虑同步问题
解决方案4: 和操作系统有关;
如果是windows系统,PCI设备的枚举、资源分配是由操作系统完成的,自己的驱动程序只需要调用系统提供的API即可,不需要直接访问端口;
不过看你的代码,应该是在DOS系统下访问PCI设备代码;本身DOS是单任务操作系统,只要在中断服务程序(ISR)里面不去访问这些端口,就不存在程序重入问题。