新闻中心

EEPW首页 > 嵌入式系统 > 设计应用 > DSP/ARM双核系统的通信接口设计

DSP/ARM双核系统的通信接口设计

作者:时间:2009-12-21来源:网络收藏

  在Linux中,设备驱动程序是一组相关函数的集合。它包含设备服务子程序和中断处理程序,每个设备服务子程序只处理一种设备或者紧密相关的设备。其目的就是从与设备无关的软件中接受抽象的命令并执行。当执行一条请求时,具体操作是根据控制器驱动程序提供的,并利用中断机制去调用中断服务子程序配合设备来完成这个请求。设备程序利用结构file_operations与文件联系起来。在Linux下驱动程序装载如图4所示。

(2) HPI驱动程序

  HPI可用I/O端口方式,也可以用I/O存取方式。平台采用I/O存取方式,将HPI访问控制寄存器、数据寄存器、地址寄存器,映射到内存物理地址为0X0C000000开始的空间,通过访问存储器指令对HPI进行操作。HPI具体物理地址定义如下:
#defineHPI_BASE0X0C000000//HPI基地址
#define HPD_READ_LOWHPI_BASE+0X0012
//读数据寄存器第一字节

#define HPA_WRITE_HIGHHPI_BASE+0X000C
//写地址寄存器第二字节

  在Linux下,类似Windows,程序不能直接访问物理地址。设备驱动程序是内核的一部分,它像内核中其他代码一样运行在内核模式,驱动程序如果出错就会使受到严重破坏,因此需要将物理地址映射到内核空间。在Linux下通过virtul_address=(u32)ioremap (HPI_BASE,HPI_LENGTH)实现。驱动程序主要结构如下:
struct file_operations hpi_fops={
owner:THIS_MODULE,
read: hpi_read,
write: hpi_write,
poll : hpi_poll,
open: hpi_open,
release: hpi_release,
};

  HPI协议采用帧结构,由于增强型HPI允许访问DSP内部RAM所有空间,系统在DSP内部分配2 K字(16位)作为帧缓冲区,读写各1 K字,协议采用一位滑动窗口协议。帧格式如表1所列。

结语

  本文介绍了使用ARM和DSP双CPU构成的嵌入式系统的硬件平台,以及源代码开放的Linux作为嵌入式系统中操作系统的方法,给出了系统的总体框图,详细介绍了ARM和DSP接口的。这一方法可以适用于大多数现代嵌入式系统的设计,有一定的实用价值。


上一页 1 2 3 下一页

评论


相关推荐

技术专区

关闭