引 言
本文在嵌入式Linux平台上实现了车载信息采集系统的一部分——汽车常规温度的数据采集,如采集车内温度、暧风或空调温度、车外温度、水箱温度等。DSl8820是一种可组网单总线数字温度传感器,为信息采集提供了经济有效的可行方案。嵌入式Linux以其源码开放、容易定制和扩展、多硬件平台支持和内置网络功能等优良性能,逐渐成为车载设备广泛使用的系统平台。本文涉及的系统使用三星公司的S3C2410AL一20处理器,操作系统采用2.6.8.1内核Linux,GUI采用Trolltech公司的Qtopia;功能上主要实现:各路温度的采集显示、音频报警、温度数据的存储、相关功能设置等。当需要语音提示或报警时,应用程序调用语音模块;当需要存储或显示历史数据时,应用程序调用SD存储模块。
1 Linux系统开发概述
驱动程序的开发是嵌入式Linux开发的主要任务之一。设备驱动为上层应用程序提供控制硬件的设备接口,同时直接与Linux内核打交道。图1描述了Linux系统开发框架。
应用程序开发是嵌入式Linux开发的另一个主要任务。Qt/Embedded是著名Qt库开发商Trolltech公司开发的面向嵌入式系统的Qt版本。Qtopia是在Qt/Em—bedded库的基础上,专门针对PDA、Smart—Phone这类运行嵌入式Linux的移动设备和手持设备所开发的开放源码的一套应用程序包和开发库。它包括全套的个人信息管理PIM(Personal Information Management),如地址本、日程安排、MPEG播放、图像显示、浏览器等。
2 车载信息系统及硬件平台概述
车载信息采集系统开发主要包括用户界面开发,内核开发,音频模块设计,串口模块设计,CAN总线模块设计,车辆状态(又包含开关量、模拟量、数字量等)检测模块设计等。
本设计着重实现一线制温度网络的数据采集。一线制温度网络的温度信号特点是:数值不高,多在0~100℃范围内;温度信号变化较慢;系统对采集到的温度信号的实时性要求不高;精度要求不高。
一线网络的优点在于能测量大量的物理量,所有的通信都通过一线协议,而与被测的具体量无关。一线网络是能够方便地搭建起由一线传感器芯片组成的一系列测量环境参数的网络。
DSl8B20是一种可组网的单总线数字温度传感器,具有以下功能特点:
①适应宽的电压范围(3.O~5.5 V),在寄生电源方式下可由数据线供电。
②独特的单线接口方式,DSl8820在与微处理器连接时仅需要1条口线即可实现微处理器与DSl8820的双向通信。
③温度范围为一55~+125℃,在一10~+85℃时精度为±0.5℃。
④可编程的分辨率为9~12位,对应的可分辨温度分别为0.5℃、O.25℃、O.125℃和0.062 5℃,可实现较高的精度测温。
单总线使得硬件开销极小,但需要相对复杂的软件进行补偿。由于DSl8B20采用单总线串行数据传送,保证严格的读写时序成为测温关键,因此没有采用I/0驱动,而是单独编写一线制温度网络驱动。
本设计采用寄生电源连接方式,12位分辨率。寄生电源的优点为:远程温度检测无需本地电源;缺少正常电源条件下也可以读ROM。为确保DSl8820在其有效变换期内得到足够的电源电流,在I/O线上通过MOSFET提供强的上拉(如图2所示)。当使用寄生电源方式时,VDD引脚必须连接到地。
系统核心控制器S3C2410X是三星公司基于ARM920T核的芯片。S3C2410X集成了1个LCD控制器(支持STN和TFT带有触摸屏的液晶显示屏)、SDRAM、触摸屏、USB、SPI、SD和MMC等控制器,4个具有PWM功能的计时器和1个内部时钟,8通道的10位ADC,117位通用I/O口和24位外部中断源,8通道10位AD控制器,处理器工作频率最高达到203 MHz。系统显示采用SHARP 3.5 in的TFT_LCD液晶显示屏。系统框图如图2所示。
3 驱动实现
本节将实现一线制温度传感器网络的驱动模块。驱动从总体上看分为两部分:驱动与内核接口层、硬件设备接口层。
3.1 驱动与内核接口层
驱动与内核接口层主要完成驱动模块在Linux内核的注册加载、卸载清除工作。这部分工作分别由初始化和退出函数完成。
①初始化函数完成驱动模块加载:
3.2 硬件设备接口层
硬件设备接口层用来描述驱动程序与设备的交互。这些工作通过虚拟文件系统与设备驱动程序的接口实现。这个接口由file_operation结构定义,其结构如下:
3.2.2 读接口函数
用户程序执行读操作的时候可能没有可以读取的数据,此时需要让read操作等待直到有数据可以读取。在此采用等待队列使进程在无数据读取时进入等待,数据到达时唤醒。等待队列设置成一个循环缓冲区,每放入一个新数据作为缓冲区的头,存放时间最久还未被取走的数据为缓冲区的尾。
3.2.3 fasync异步通知函数
异步通知函数向进程发送SIGIO信号,通知访问设备的进程,表示设备已经准备好I/O读写了,避免主动查询,提高程序效率。使用异步通知需增加一个struct
3.2.4 poll系统调用操作接口函数
当程序需要进行对多个文件读写时,如果某个文件没有准备好,则系统就会处于读写阻塞的状态,影响其他文件的读写。为了避免读写阻塞,使用poll函数。如果设备无阻塞地读,就返回POLLIN;通常的数据已经准备好,可以读了,就返回POLLRDNORM。
写接口函数用来通知驱动。例如通知驱动读取通道2的数据,在应用程序中执行写接口函数write(fileno,&SLOT2,1),驱动设置当前读通道号为2。
至此完成驱动接口函数。此驱动属于字符设备驱动,将源程序放在driver/ehar目录下。同时需要修改该目录下的Kconfig配置文件并添加Config 18820_S3C2410选项,修改driver/char/Makefile,添加obj一$(CC)NFIG_18B20 S3C2410)+=S3C2410_18820.O。最后重新配置内核,将驱动以模块形式添加到内核,这样就可以编译驱动了。
4 Qtopia应用程序设计
(1)创建工程
首先利用QT Designer设计器创建一个窗体应用程序ThermometerFigure.ui。窗体程序创建好后根据需要添加窗体控件、槽函数、信号等。图3为ThermometerFigure类的实现框图。
(2)ThermometerFigure类实现
利用uic工具产生相应的*.cpp和*.h文件(窗体类的实现文件和头文件)。编辑*.cpp和*.h文件实现各成员函数、信号槽的连接。具体实现如图3所示。
(3)创建main及初始化
首先创建main.cpp文件,并在main.cpp中创建QApplication对象。QApplication类负责图像用户界面应用程序的控制流和主设置,对所有来自系统和其他源文件的事件进行处理和调度;还包括应用程序的初始化和结束。
执行qmake命令生成Makefile文件,执行之前要设置相关的环境变量,编译器路径等。
qmake一o Makefile Thermometer.pro
(5)编译链接工程
执行make命令,将生成目标二进制文件Thermometer,此文件即可在设备上运行。
(6)将可执行文件发布到Linux系统
将可执行文件添加到Qtopia的根文件系统中,将生成的新的根文件系统烧写到设备的Flash根文件系统区,这样就可以在桌面运行程序了。图4为ThermometerFigure类实现界面。
结 语
本文介绍了车载信息系统开发的部分实现方法。通过实例讲述了Linux的开发过程,包括驱动开发和应用程序开发流程。创新点在于将一线制传感器网络引入车载信息采集系统,大大简化了线路结构,有很高的实用价值。