采用PCI9052及GP2010实现GPS信号采集_通信网络论文
关键词:pci总线 gps dma
引言
全球定位系统gps(global position system),可以给用户提供实时的定位、速度和时间。现在的gps接收机大多采用硬件电路进行码相关运算,结构复杂,更新升级比较困难;而基于软件无线电的gps接收机受电路限制较少,更新换代只需调整相应软件,十分灵活。该数据采集卡就是基于以上考虑设计的。
1 pci9052的特点与功能
pci9052(以下简称9052)提供高性能的从目标pci接口板卡与pci总线的连接,支持宽范围速率的本地总线,最高可达132 mb/s的传输速率。对9052编程可实现复用/非复用的8位、16位、32位的本地总线接口。9052还有内部fifo可以加速本地总线的操作,此外它还有以下功能:
①支持pci r2.1版本,可以方便地将isa卡转换为pci卡;
②支持从目标传输模式,可以对存储器空间进行突发读/写,对i/o空间单次访问;
③2个本地中断总线配置;
④可编程的本地总线配置;
⑤串行e2prom配置;
⑥4个本地片选引脚,5个本地空间;
⑦多种本地读/写操作模式,方便地实现pci与本地的接口。
图1给出了9052内部结构。
2 gp2010射频前端器件
gp2010(以下简称2010)是为gps接收机设计的射频前端器件,它接收gps(l1)调制信号。l1是50位/hz的码速率经过1.023mhz的伪随机码扩频后以bpsk方式调制在1575.42mhz的载波上形成的扩频信号。信号电平在进入天线之前大约只有-130db,带宽为2.046mhz,所以l1基本上被噪声所掩盖。2010经过内部锁相环频率综合器产生1.4ghz、140mhz、与31.11mhz的三级时钟分别与射频输入的l1信号进行混频,其中还经过3级滤波抑制带外干扰,最后将其变换到4.309mhz的中频,然后进行5.714mhz的采样实现a/d变换(2位量化,符号位sign和数据位mag)。根据奈奎斯特定律对带通信号要以高于两倍的信号带宽进行采样才可无失真的恢复,用5.714mhz的速率采样也要考虑到信号传播过程中由于相对运动而产生的多普勒效应使信号带宽变宽的缘故。量化数据在每个时钟的上升沿输出。图2给出2010的内部结构图。
图2 gp2010内部结构图
3 数据采集卡系统结构
gps信号数据采集卡实现基本的一路gps卫星信号的采集工作。由于2010为2位、5.714mhz的采样速率,我们在fpga中首先将2位数据进行串并变换,使其每满32位后进行一次传输存储,这样存储速率就变为357.12khz。缓存选用4片18k×16位的fifo,这样就可以省略地址产生逻辑。在程序设计中,采样数据首先存入fifo(a),待满后会产生相应的中断,中断服务程序将读取其中的数据。在读过程中,采样数据会继续写入fifo(b),如此反复可将数据采入计算机内存。选用缓存时,建议在可行的情况下,容量越大越好。因为pci总线上,除了设计的采集卡在不断地申请占用总线外,还会有其余的设备占用,如果缓存不够大将会丢失采样数据。fpga的主要功能是实现数据串行变换、控制采样过程和与fifo的接口逻辑。图3是该数据采集卡的系统框图。
4 9052使用中应该注意的问题
9052内部的配置寄存器是通过外部串行e2prom上电加载的。9052会自动根据该e2prom的状态来决定其内部寄存器的值。如果e2prom不存在(此时e2prom和9052连接的数据引脚应加上拉电阻)或其内部无有效值,9052会将其内部寄存器配置为缺省值。值得一提的是,如果e2prom内部没有烧写为有效值时,应保证其开始48位为全“1”;否则,系统上电时可能会产生错误。
9052有5个本地空间,用户可根据实际需要进行相应的配置。当将本地空间配置成i/o时,对该空间的读/写操作只能单次进行。利用plxmon来开发驱动程序(调用其提供的api函数)进行i/o读/写,速度会十分慢(一般不会超过500khz);而如配置成存储器空间,用户会有多种接入模式,可大大提高接入速度。突发模式是为提高本地总线操作速度而设计的。在该模式期间,9052只提供一次传输开始和终止信号。开始信号有效后,地址将以本地时钟的频率(最高可达40mhz)递增,可以利用bterm#引脚是否有效来终止突发操作。由于fifo只需要一个口地址,在设计中为了利用其快速的存储器访问(突发访问)特性,我们还是为其分配了36kb的地址空间,以保证在该范围内fifo的片选始终有效。图4是一次突发读时序。其中lclk是本地时钟,ads有效表示一次传输的开始,blast有效表示本次传输的终止。
在此须澄清一个概念:pentium系列计算机(指cpu),不支持突发读操作,只可能产生单次读操作。用户若想在pci总线上实现突发操作(frame信号有效,多余一个pci时钟周期),应使用支持dma传输的芯片,如plx9054。但9052会将pci总线上的多次单次读操作转化为本地空间上的突发操作。
5 plxmon及plx器件驱动程序的开发
plxmon是plx公司专为其产品开发的测试软件。在用户的板卡插入pci槽,并安装了plxmon提供的驱动程序后,启动该软件就可以观察和修改芯片内部寄存器的值,并可以对存储器空间进行测试。
windows下的驱动程序包括硬件物理设备的驱动程序和文件系统等非物理设备的虚拟设备驱动程序,我们所编写的是硬件设备的驱动程序。windows类操作系统(windows 95、windows 98、windowsnt、windows 2000)为了保证其安全性、稳定性和可移植性,对应用程序访问硬件资源加以限制,用户需要对系统硬件及操作系统软件有详细的了解才可开发出高效的驱动程序,因此开发周期较长。利用第三方提供的开发软件,可以大大缩短开发时间,但效率不一定高,尤其对实时性要求严格的程序显得有些无力。
①device developer kit(ddk)。该软件中包括了有关设备驱动开发的文档、编译需要的头文件和库文件、调试工具和程序范例;但是由于ddk主要是使用汇编语言进行描述,开发起来比较困难。
②vtoolsd。该软件包是基于c/c++的,支持borlandc++和visualc++,使用和维护比较方便。
③windriver。允许用户使用visual c++、borland或者其它win32编程工具软件在用户模式(usermode)上编写设备驱动程序。
④plxmon。plx公司专为其芯片提供的驱动程序开发包和测试软件,同样可以在用户模式上编写。支持visual c++环境。
图4 突发读时序
在开发程序时,我们发现plxmon和windriver不兼容,而且除非有正式版本的windriver;否则试用期过后,利用它开发的驱动程序将无法使用。所以建立使用plxmon,只需包括相应的头文件,用户便可以方便地调用其提供的api函数,对板卡上的资源进行访问。以下的程序片段是在调试电路板时编写的基本查询中断是否有效来读取缓存的。所调用的函数均为plxmon提供的api函数。其中:plxpcibaseaddressesget()是得到板卡上存储空间的地址,而*(data+i)=*(u32*)(va.va3)是将该空间的值装入计算机内存。
图5是驱动程序流程图。
程序段如下:
example:
rc_w=plxpcibaseaddressesget(hdevice,&va);
while(true){
int_flag=*(u32*)(va.va0+0x4c);
if(int_flag[0]&4) {
for(i=0;i<fifo_size;i++)
*(sample_data+i)=*(u32*)(va.va3);
*(u32*)(va.va0+0x4c)=clear_flag;
break;
}
}
结语
由于pci总线的高速特性,使其被广泛应用于高速数据采集系统中,有效地解决了实时采集、实时传输和实时存储等问题。而pci总线控制器专用芯片的出现则缩短了pci总线硬件设备的开发周期,使得硬件设备的可靠性和稳定性都有了较大的提高。在开过程中,我们发现要想有高效率的操作特性,使用第三方提供的驱动程序开发包总是不太理想,尤其对于高速采样及实时严格的系统。用户还是要利用ddk开发符合自己要求的驱动程序。该数据采集卡实现了一路gps信号的采集工作,为今后利用通用pc机进行数字信号的捕获、跟踪及解调,初步实现软件无线电gps接收机打下基础。