微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > MCU和DSP > 基于Windows CE的SPI驱动程序设计

基于Windows CE的SPI驱动程序设计

时间:01-14 来源: 点击:

引 言

Windows CE为支持多线程、多任务、抢占式的嵌入式操作系统。随着Windows CE 6.0的发布,其内核性能的明显提升和源代码开放,将促使其在消费电子、工业控制、移动通信等领域得到广泛的应用。通常Platform Builder中给出了支持多种CPU常用设备驱动程序,如LCD驱动、鼠标驱动、USB驱动、串口驱动等;但有时由于平台采用了其他特定的硬件设备,其驱动程序在Platform Builder并没有给出,这时就需要用户针对实际的硬件自行开发,以满足个性化的需求。本文所涉及的SPI接口驱动就属于此类。

1 SPI总线及S3C2440芯片介绍

串行外围设备接口SPI(Serial Peripheral Interface)总线是Freescale公司推出的一种三线同步接口。接口采用同步串行3~4线方式进行通信,即1条时钟线SCK、1条数据输入线MOSI、1条数据输出线MISO,另外还有1条从选线NSS(可选),用于CPU与各种外围器件进行全双工、同步串行通信。SPI接口在众多的移动存储和高速通信芯片上得到广泛应用。

根据时钟极性和时钟相位的不同,MOSI和MISO上的数据支持4种数据传输格式。SPI的主要特点为:可以同时发出和接收串行数据,可以当作主机或从机工作,提供频率可编程时钟,发送结束中断标志,写冲突保护和总线竞争保护等。

S3C2440是一款基于ARM920T的16/32位RISC微处理器,主频可达400 MHz。该芯片性价比高,功耗低,含有丰富的片内外设,主要用于手持设备和移动终端。S3C2440中与SPI相关的寄存器有:

2 Windows CE的驱动程序

2.1 Windows CE下驱动程序的基本概念和分类

驱动程序是一个抽象物理设备或者虚拟设备的功能软件,驱动程序管理这些设备的操作并将设备的功能导出给操作系统和应用程序。根据驱动程序导出接口的不同,windows CE中驱动可以分为本机设备驱动程序(native device driver)和流式驱动程序(streams device driver)。本机设备驱动适于集成到基于Windows CE平台的设备。这些设备驱动程序是一些硬件所必需的,是由原始设备制造商创建的,用来驱动如键盘、LED、触摸屏等。本机驱动在编译时被静态链接到GWES,系统运行时由GWES加载。流式驱动程序也称"可安装驱动程序",是由设备管理器(device.exe)动态加载用户模式的DLL。对流式驱动程序来说,不管需要控制的设备是什么类型,所有流式驱动都使用相同的接口并导出一组相同的函数--流接口函数。流式驱动适用任何在逻辑上可以被认为是一个数据源或者数据存储的I/O设备。

2.2流式驱动程序工作原理

在Window CES中,流式驱动程序负责将设备抽象成一个文件,应用程序便能够使用系统提供的API(ReadFile、writeFile、IOControl等)对其进行读写。应用程序使用文件API访问设备时,请求经过文件系统(Filesys.exe)过滤被送到device.exe;device.exe根据请求调相关的流式驱动程序接口,从而完成与硬件的交互。

2.3 设备驱动的中断处理

在windows CE系统中,当中断发生时,OEM抽象层(OEM Abstraction Layer,OAL)把物理中断信号映射成OEM定义的逻辑中断供操作系统和驱动程序调用。为了满足实时性要求,系统将中断处理过程分为2个阶段,即处于内核模式的中断服务例程(Interrupt Service Rout

ine,ISR)和处于用户模式的中断服务线程(Interrupt Service Thread,IST)。ISR主要负责将物理中断映射为逻辑中断,然后由操作系统根据逻辑中断激发所关联时间对象的内核,使等待该事件内核对象的线程IST开始执行中断处理程序。

具体中断处理过程如图1所示。中断发生后,信号发往异常处理器,并且中断支持处理器调用OAL函数OEMInterruptDisable关闭来自该硬件的中断。ISR被内核调用并返回结果,且通过内核设置Event事件来触发IST。IST被唤醒后调用各种I/O函数完成中断处理并返回InterruptDone通知内核。内核调用OEMInterruptDone通知硬件重新开启中断。

3 SPI总线驱动设计

综上所述,SPI总线驱动分为2部分,即处于内核模式OAL层将物理中断映射成逻辑中断的ISR,以及处于用户模式流式驱动。其中包括执行中断处理线程IST。

3.1 初始化中断以及ISR实现

SPI通信是通过读写SPI寄存器来完成的,通过读写上述6个SPI寄存器中的状态字可以检测和控制SPI总线的行为。在OAL层中需要完成的工作如下:

①在中断头文件oalintr.h中添加SPI的中断宏定义,供ISR返回调用。
#(define SYSINTR_SPIO (SYSINTR_FIRMWARE+22)

注意:定义时要使中断号满足该文件中MapIrq2SysIntr中所要求的范围。WinCE4.2版本支持最大中断数为32,WinCE5.0版支持最大中断数为64。

②在OAL实现文件cfw.c中,添加中断初始化和禁

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top