1、嵌入式系统及应用实验指导书嵌入式系统及应用实验指导书李 剑 编中国矿业大学信息与电气工程学院2012年12月实 验 要 求 实验前应充分预习阅读实验指导书,查看相关技术文档,复习教材中有关内容。明确实验目的、实验原理及内容,以减少实验中的盲目性,提高主动性。自行拟定实验步骤,掌握注意事项。 实验报告在实验完成后一周内交到实验室,采用统一报告纸,手写完成,并装订成册。 嵌入式系统与应用实验硬软件介绍 实验一 ADI IDE嵌入式集成开发环境基础实验 实验二 嵌入式Linux应用程序开发基础实验 嵌入式系统与应用实验硬软件介绍一、JXARM9-2410实验箱硬件简介:图1 JXARM9-2410实
2、验箱结构示意图JXARM9-2410教学实验系统的硬件部分包括:基本模块、调试模块、通讯模块、人机交互模块、A/D模块、步进电机驱动模块、IDE/CF接口模块、GPRS模块、GPS模块。1. 基本模块:SDRAM存储器:主板包含64MB SDRAM。由一片16位数据宽度的SDRAM存储器组成,地址从0x300000000x33fffffff。FLASH 存储器:主板包含32MB NOR FLASH存储器和8MB NAND FLASH,NOR FLASH内部存放启动代码Bootloader、Linux 内核映象、IIS测试声音文件等。其数据宽度为32位,地址从:0x000000000x01fff
3、fff;NAND FLASH中包含一个cramfs文件系统,在Linux中使用。 串行通讯口:主板包含3 个UART接口:UART0和UART1 用作RS232 串行接口,UART2 用作RS485 接口。UART0在Bootloader、演示程序、Linux 和多个实验中用于人机交互(通过超级终端)以及文件传输; IIS 录放音接口:主板有一个可以基于DMA 操作的IIS 总线接口,可进行立体声录放音; I2C 总线接口:与24C08 芯片接口,可以存放一些固定的配置数据; 4 个LED 跑马灯:可独立软件编程; 6 个七段数码管:6个共阳七段数码管; 外部中断测试:一个按键用于外部中断0
4、的测试; 复位按键:按键用于CPU 复位; 两通道通用DMA,两通道具有外部请求引脚的外设 DMA; 五个PWM 定时器和一个内部定时器; 看门狗定时器; 8 通道10-bit ADC。 2. 调试模块:标准JTAG接口:14针标准JTAG接口,该接口用于高速仿真调试;简易调试接口并口:直连标准计算机并口,调试接口,该接口用于简易仿真调试。3. 通讯模块:以太网通讯接口:10M以太网卡;USB接口:遵循USB1.1标准;标准计算机打印口(并口)。4. 人机交互模块:显示器/触摸屏:8英寸,TFT LCD显示器,640X480;按键:4X4按键。5. A/D模块:10bit A/D模块。6. 步
5、进电机驱动模块:两相步进电机驱动。7. IDE/CF接口模块:标准IDE硬盘接口;标准CF卡接口。8. GPRS模块:GPRS无线通讯模块。9. GPS模块:GPS全球定位系统模块。二、JXARM9-2410实验箱硬件资源分配在使用实验箱中的各个模块硬件资源时,需了解模块对应的地址空间及空间组织,以便编程调用。1. 地址空间分配以及片选信号定义表1 ARM9-2410 地址空间分配表2. RAM空间组织 存储空间的定制是嵌入式系统开发的一个特色,我们可以根据自己的需要自行规定内存的使用。在本教学实验系统中,SDRAM地址范围从0x300000000x33ffffff共64Mbytes。在不同的
6、程序中,SDRAM空间范围被分配成不同的区域用于不同的用途,下表是实验测试程序所用的一个默认分配方式,它的代码空间和数据空间分配如下:表2 SDRAM空间组织分布3. FLASH空间组织 FLASH 地址范围从0x000000000x01ffffff共32Mbytes。其空间组织如下表,各地址空间对应了不同的用途:表3 FLASH 空间组织分布三、超级终端的使用普通PC软件开发是使用键盘和显示器作为标准输入输出设备,而嵌入式系统开发一般使用串口作为标准输入输出设备。嵌入式系统上电后执行u-boot代码进行系统引导,在u-boot中指定了串口0作为输入输出设备。这对于我们进行嵌入式应用非常重要。
7、超级终端是windows XP系统自带的终端连接软件,当连接设备选择为串口时,即可作为实验箱的输入输出界面使用。Widows 7等版本不自带超级终端,但网上有大量的类似软件可以使用。下面介绍超级终端的使用方法。下图给出了xp系统中超级终端打开的路径:图2 超级终端打开路径打开超级终端后弹出的画面如图3所示,随意给新建连接起个名称,如ARM、ARM2410:图3 超级终端界面1点击确定后,弹出的界面如图4所示:图4再点击取消,界面如图5所示,此时还为设置连接。图5点击图5中红圈所圈的工具图标,弹出的设置对话框如图6所示图6 超级终端设置对话框点击“连接时使用”的下拉条,选中相应的串口设备,普通P
8、C机上一般是com1。如果是笔记本或其他电脑没有自带串口的,一般使用USB转串口设备,此时需先打开系统的设备管理器,找到端口一项,查看USB serial的端口号。然后点击超级终端设置对话框中的设置按钮,打开串口属性设置对话框,设置如图7所示:图7 串口属性设置对话框按照图7所示进行设置后,点击确定后返回到图6对话框,再点击确定,回到主界面,点击呼叫图标(有时候设置好后返回主界面会自动连接呼叫)如图8所示红圈内的电话标志,就可以连接外部串口设备了。如果要断开连接就点击旁边的断开图标。图8 用串口线连接到JXARM9-2410实验箱的串口0上,打开超级终端的呼叫图标,然后打开实验箱的电源,正常情
9、况下超级终端会显示如下信息,如图9所示:四、嵌入式Linux开发环境的建立(JXARM9-2410实验箱)嵌入式Linux开发环境主要包括四个方面:选择并安装一个合适的主机Linux操作系统;在主机Linux系统中安装tftp服务器;在主机中安装Linux系统;在主机Linux系统安装交叉编译器。1.安装主机Linux操作系统要进行嵌入式linux的开发首先要按照好一个主机开发环境,因为嵌入式linux下的大部分开发工作都是在pc中开发的。如果你的机器足够好(内存至少大于1GB),那么建议首先在Windows下安装一个虚拟机软件vmware,毕竟Windows下可用的工具比较多,再在vmwar
10、e基础上安装一个桌面版本的Linux系统。实验室使用的是vmware-8.0和Ubuntu-11.10,这2个软件都可以在网上下载到。由于在linux系统的开发过程中需要经常使用管理员权限,因此建议使用root登录linux系统。通常新建系统是不允许root登录的,如何获得root登录则需根据不同的linux系统版本在网络上查找方法,本文不详细介绍。2.建立tftp服务器在嵌入式linux开发过程中需要使用tftp方式从Linux主机下载文件到板子中,因此需要在主机linux系统中安装tftp服务器。(1)安装tftp软件在Ubuntu的终端中输入“apt-get install tftpd
11、tftp xinetd”,默认执行到结束。(2)建立配置文件在终端中输入“gedit /etc/xinetd.d/tftp”新建一个tftp配置文件,并在文件中输入:service tftpsocket_type = dgramprotocol = udpwait = yesuser = rootserver = /usr/sbin/in.tftpdserver_args = -s /tftpbootdisable = noper_source = 11cps = 100 2flags = IPv4服务器的根目录地址即为tftpboot。(3)重启服务在终端中输入“/etc/init.d/xi
12、netd restart”。3.建立nfs服务器在嵌入式linux开发的时候,常常需要使用nfs以方便程序的调试。使用nfs,用户可以将板子要用到的根文件系统放在主机目录下,开发板则通过以太网挂载到这个目录并将这个目录下的文件作为根文件系统的内容,这样用户的程序更新后不比重新烧写板子的根文件系统便能被重新使用,这点能够大大加快程序的调试。Ubuntu下安装nfs服务器的步骤如下:(1)进行NFS服务器端与客户端的安装:apt-get install nfs-kernel-server nfs-common portmap安装客户端的作用是可以在本机进行NFS服务的测试。(2)配置portmap
13、两种方法任选一种就可以:gedit /etc/default/portmap去掉-i 127.0.0.1或:dpkg-reconfigure portmap运行后选择“否”另外很重要的一点,要用sysv-rc-conf(而不是chkconfig)工具查看一下当前nfs和portmap的状态,若是off,则用sysv-rc-confportmapon或sysv-rc-confnfs-kernel-serveron打开(3)配置挂载目录和权限gedit /etc/exports在最后一行添加配置如下:/nfsboot *(rw,sync)其中/nfsboot指的是是NFS的共享目录,*表示任何IP
14、都可以共享这个目录,你可以改为受限的IP,rw表示的是权限,sync是默认的。(4)重启NFS服务/etc/init.d/nfs-kernel-server restart 重启nfs服务4.安装交叉编译链arm处理器不断发展,已经有很多种架构,针对不同的arm架构和linux内核版本,需使用不同的编译器。JXARM9-2410的嵌入式linux系统使用的是版本为2.95.3。(1)安装编译器将附件文件cross-2.95.3.tar复制到Ubuntu主文件夹下,然后打开终端执行:mkdir /usr/local/armcp cross-2.95.3.tar /usr/local/armcd
15、/usr/local/armtar xvf cross-2.95.3.tar rm /usr/local/arm/cross-2.95.3.tar(2)将编译器添加到环境变量中为了使用方便,还可以编辑/etc/bash.bashrc文件添加把编译器路径到环境变量PATH中,只要在这个文件中添加下面这个语句即可:export PATH=$PATH:/usr/local/arm/2.95.3/bin:编辑完毕后使用source /etc/bash.bashrc命令执行以下这个文件,让设置生效。实验一 ADI IDE嵌入式集成开发基础实验一、实验目的1.了解ADT IDE的 ARM开发环境;2.掌握
16、ADT IDE开发环境中基本的工程设置以及程序编译方法;3.掌握ADT IDE开发环境中基本的程序调试方法。二、实验内容在ADT集成开发环境中编写数码管显示程序,利用6位数码管构成一个简易秒表。三、实验设备1.硬件:JXARM9-2410教学实验箱、PC机;2.软件:PC机操作系统 Windows 98(2000、XP) ADT 1000开发环境。四、实验预备知识更详细的内容见ARM9 嵌入式技术及嵌入式 Linux 高级实践教程第4章。1.C语言的基础知识;2.ADI IDE集成开发环境的程序调试基础知识和方法;3.LED数码管基本原理;发光二极管数码显示器简称LED显示器。LED显示器具有
17、耗电省、成本低廉、配置简单灵活、安装方便、耐振动、寿命长等优点,目前广泛应用于嵌入式系统中。7段LED由7个发光二极管按“日”字形排列,所有发光二极管的阳极连在一起称共阳极接法,阴极连在一起称为共阴极接法。一般共阴极可以不需外接电阻,但共阳极接法中发光二极管必须外接电阻。LED的结构及连接图见下图。当选用共阴极的LED显示器时,所有发光二极管的阴极连在一起接地,当某个发光二极管的阳极加入高电平时,对应的二极管点亮。因此要显示某字形就应使此字形的相应段的二极管点亮,也就是送一个用不同电平组合代表的数据字来控制LED的显示,此数据称为字符的段码。字符0、1、2F与LED码段A、B、CF以及DP(小
18、数点)的关系如表4:字符DPGFEDCBA段码(共阴)段码(共阳)0001111113FHC0H10000011006HF9H2010110115BHA4H3010011114FHB0H40110011066H99H5011011016DH92H6011111017DH82H70000011107HF8H8011111117FH80H9011011116FH90HA0111011177H88HB011111007CH83HC0011100139HC5HD010111105EHA1HE0111100179H86HF0111000171H8EH-0100000040HBFH.1000000080H
19、7FH熄灭0000000000HFFH说明:共阴的LED,被选中时的段为高电平有效,熄灭的段码为00H;共阳的LED,被选中时的段为低电平有效熄灭的段码为FFH。LED显示器的接口一般有静态显示与动态显示接口两种方式,下面分别加以介绍。1) 静态显示LED数码管采用静态接口时,共阴极或共阳极点连接在一起接地或接高电平。每个显示位的段选线与一个8位并行口线对应相连,只要在显示位上的段选线上保持段码电平不变,则该位就能保持相应的显示字符。这里的8位并行口可以直接采用并行I/O口,也可以采用串入并出的移位寄存器或是其它具有三态功能的锁存器等。2) 动态显示在多位LED显示时,为了简化电路,降低成本,
20、将所有位的段选线并联在一起,由一个8位I/O口控制。而共阴(或共阳)极公共端分别由相应的I/O线控制,实现各位的分时选通。由于各个数码管是共用同一个段码输出口,分时轮流通电的,从而大大简化了硬件线路,降低了成本。不过这种方式的数码管接口电路中数码管不宜太多,一般在8个以内,否则每个数码管所分配的实际导通时间会太少,显得亮度不足。若LED位数较多时应采用增加驱动能力以提高显示亮度。本实验中采用的是动态显示接口,其中数码管扫描控制地址为0x0:1000006,位0位5每位分别对应一个数码管,将其中某位清0来选择相应的数码管,地址0x01000004为数码管的数据寄存器。数码管采用共阳方式,向该地址
21、写一个数据就可以控制LED的显示,其原理图如下图所示:五、实验步骤1.硬件连接将实验箱的电源线接到电源插座上,使用串口连接线连接PC串口端和实验箱串口0,使用并口线连接PC机并口端和实验箱的简易JTAG并口调试端。2.超级终端按照前面的内容建立好一个超级终端后,打开实验箱电源,检查U-boot启动是否正常3.建立工程1)(以英文版为例,汉化版请同学们自己对照)打开ADT IDE,点击“File-New菜单”,弹出New对话框,如上图所示,选择Project页,在Project页中选择调试设备,对于简易调试器的用户,请选择“ARM9SIMPLE”,在“Project name”和“Locatio
22、n”中输入工程名称和路径,请注意路径和工程名中不能包含空格。在工程类型中选择“EXEC”。2) 新建一个文件并保存为d:leddemoleddemo.c,编辑该文件,添加如下代码:/*/*文件名称: LEDSEG7.C */*实验现象: 数码管依次显示出0、1,2、9、a、b、C、d、E、F */*/#define U8 unsigned charstatic int delayLoopCount=1000;unsigned char seg7table16 = /* 0 1 2 3 4 5 6 7*/ 0xc0, 0xf9, 0xa4, 0xb0, 0x99, 0x92, 0x82, 0xf
23、8, /* 8 9 A B C D E F*/ 0x80, 0x90, 0x88, 0x83, 0xc6, 0xa1, 0x86, 0x8e,;void Delay(int time);/*/* 函数说明: JXARM9-2410 7段构共阳数码管测试 */* 功能描述: 依次在7段数码管上显示0123456789ABCDEF */* 返回代码: 无 */* 参数说明: 无 */*/void Test_Seg7(void) int i; *(U8*) 0x010000006) = 0x00;/*为什么是0x01000006?它是做什么用的?*/ for( ; ; ) /* 数码管从0到F依次将
24、字符显示出来 */ for(i=0;i=0x0;i-) /* 查表并输出数据 */ *(U8*) 0x010000004) = seg7tablei; Delay (1000); /*/* Function name : 循环延时子程序 */* Description : 循环 time 次 */* Return type :void */* Argument : 循环延时计数器 */*/void Delay(int time) int i; for(;time0;time-) for(i=0;idelayLoopCount;i+);3) 将leddemo.c文件加入到工程leddemo中,如
25、下图所示,点击右键菜单:将弹出文件选择对话框,选择d:leddemoleddemo.c文件,并点击“打开”按钮。4) 新建一个文件并保存为d:leddemoldscript,编辑该文件,添加如下内容:SECTIONS . = 0x30000000; .text : *(.text) Image_RO_Limit = .; Image_RW_Base = .; Image_RO_Base = .; Image_RW_Limit = .; .data : *(.data) .rodata : *(.rodata) Image_ZI_Base = .; .bss : *(.bss) Image_ZI
26、_Limit = .; _bss_start_ = .; _bss_end_ = .; _EH_FRAME_BEGIN_ = .; _EH_FRAME_END_ = .;PROVIDE (_stack = .); end = .; _end = .; .debug_info 0 : *(.debug_info) .debug_line 0 : *(.debug_line) .debug_abbrev 0 : *(.debug_abbrev) .debug_frame 0 : *(.debug_frame) 该文件为链接脚本文件,链接脚本文件中全部使用半角符号,文件编写格式必须从SECTIONS
27、关键字开始,紧接着是开大括号,后面是所有需要输出的描述部分,最后用闭大括号收尾。具体意义参考附录A。该文件必须通过第5步中的工程设置对话框设置到链接参数中才有效。鼠标右键点击工程中的MISC目录,选择添加文件,将该文件添加到工程中。5) 如下图所示,在工作区窗口中的leddemo工程名上右键点击并选择“Setting”菜单项。弹出设置对话框,选择“Link”页,在“Link script”链接脚本中输入“.ldscript”,点击“OK”按钮。6) 如下图所示,在工作区窗口中的leddemo工程名上右键点击并选择“Build”菜单项。编译成功后结果如下图所示。7) 如并口线已经连接到JXARM9-2410 的简易JTAG并口上,且实验箱已经上电,就直接点击“Debug”菜单的“Remote Connect”进行连接,如下图所示。正常连接结果如下图所示,有target connected的提示。如果连接正确“Debug”菜单项将如下图所示
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1