《ep2[工学]第05章ARM嵌入式系统开发环境讲课教案.ppt》由会员分享,可在线阅读,更多相关《ep2[工学]第05章ARM嵌入式系统开发环境讲课教案.ppt(79页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、ep2工学第05章ARM嵌入式系统开发环境 Still waters run deep.流静水深流静水深,人静心深人静心深 Where there is life,there is hope。有生命必有希望。有生命必有希望5.1 基本原理基本原理v绝大多数的Linux软件开发都是以Native方式进行的,即本机(Host)开发、调试,本机运行的方式。这种方式通常不适合嵌入式系统的软件开发,因为嵌入式系统没有足够的资源在本机运行开发工具和调试工具。通常,嵌入式系统的软件开发采用一种交叉编译调试的方式,交叉编译调试环境建立在宿主机上,宿主机可以是一台PC或工作站,对应的目标板也称为开发板或实验板。
2、图5.1给出了这种交叉编译环境的示意图。开发时使用宿主机上的交叉编译、汇编及链接工具形成可执行的二进制代码,这种可执行代码不能在宿主机上执行而只能在目标板上执行,因此需要把可执行文件下载到目标板上运行。一般调试的方法包括串口调试和以太网口调试。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)25.1 基本原理基本原理v图5.1 交叉编译环境示意图嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)35.1 基本原理基本原理5.1.1 SemitARM9200实验箱实验箱v本书后面的实验和开发实例均依托SemitARM9200实验箱进行阐述,SemitARM9200实
3、验箱中的开发目标板及其配套软件由作者及其同事依托东南大学移动通信国家重点实验室和南京东大移动互联技术有限公司而开发。vSemitARM9200实验箱分为上、下两层,它们所包含的模块名称及其数量分别列于表5.1和表5.2中。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)45.1 基本原理基本原理表5.1 SemitARM9200实验箱上层表5.2 SemitARM9200实验箱下层模 块 名 称数 量模 块 名 称数 量Zigbee模块(主)1块SemitARM9200开发底板1块Zigbee模块(从)1块SemitARM9200 核心板1块GPS模块1块7.5V 1200mA
4、电源1块CDMA模块1块7.5V 800mA电源4块GPS天线1根GSM天线1根CDMA天线1根耳机1副802.11g无线网卡1块串口线(双公)1根串口线(公母)2根直连网线1根嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)55.1 基本原理基本原理v实验箱的实物图分别如图5.2和图5.3所示,开发板及接口、CDMA模块及电源、GPS模块及电源、Zigbee模块及电源、IEEE 802.11g无线网卡的实物图分别如图5.4图5.8所示。另外,GSM天线在实验箱的最低层,取出来后装在图5.3中GSM天线底座的位置上。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版
5、)65.1 基本原理基本原理图5.2 实验箱上层嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)75.1 基本原理基本原理图5.3 实验箱下层嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)85.1 基本原理基本原理图5.4 SemitARM9200 开发板及接口嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)95.1 基本原理基本原理图5.5 CDMA模块及电源嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)105.1 基本原理基本原理图5.6 GPS模块及电源嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)11
6、5.1 基本原理基本原理图5.7 Zigbee(主、从)模块及电源 图5.8 802.11g无线网卡嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)125.1 基本原理基本原理vSemitARM9200开发板由核心板和底板组成。核心板在实验箱的最低层,取出来后装在图5.3中的核心板插槽处。核心板上集成了Atmel的AT91RM9200处理器,64MB SDRAM及16MB的Flash,为应用研发提供了足够的空间。底板上则提供以下外设接口:两个RS-232 串口(COM),一个USB Host接口,两个USB Device接口,一个10/100Mbps自适应以太网接口。v核心板和
7、底板配合即构成一个最小的完整应用系统。系统具有体积小、耗电低、处理能力强等特点,能够装载和运行嵌入式Linux操作系统,用户可以在这个系统平台上进行自主软件开发。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)135.1 基本原理基本原理vAT91RM9200具有如下资源及接口:16KB数据Cache,16KB指令Cache,写缓冲区;虚拟内存管理单元NMU;带有Debug调试的在片Emulator;中级执行嵌入式Trace Macrocell;16KB的内部SRAM和128KB的内部ROM;外部总线接口(EBI);支持SDRAM、SRAM、Burst Flash和Compac
8、tFlash、SmartMedia and NAND Flash的无缝连接;增强型的时钟产生器和电源管理单元;带有两个PLL的两个在片振荡器;慢速的时钟操作模式和软件电源优化能力;嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)145.1 基本原理基本原理4个可编程的外部时钟信号;包括周期性中断、看门狗和第2计数器的系统定时器;带有报警中断的实时时钟;带有8个优先级、可单个屏蔽中断源、Spurious中断保护的先进中断控制器;7个外部中断源和一个快速中断源;4个32位的PIO控制器可以达到122个可编程I/O引脚(每个都有输入控制、可中断及开路的输出能力);20通道的外部数据控
9、制器(DMA);10/100Mbps的以太网接口;两个全速的USB2.0主接口和一个从口;4个USART;嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)155.1 基本原理基本原理三通道16位的定时/计数器(TC);两线接口(TWI);IEEE 1149.1 JTAG标准扫描接口。核心板各个部分的构成如图5.9所示。v内存部分:1片168Mb数据宽度的Flash,共16MB Flash(Intel 28F128J3C,如有不同型号,则是完全兼容的器件);两片16M16b数据宽度的SDRAM(HY 57V561620B T,如有不同型号,则是完全兼容的器件)构成64MB SDR
10、AM。v数据通信口和外部输入/输出口:底板实现了按键、UART、USB和百兆位以太网等功能。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)165.1 基本原理基本原理图5.9 SemitARM9200开发板中的核心板的构成嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)175.1 基本原理基本原理5.1.2 宿主机开发环境宿主机开发环境vSemitARM9200开发板可采用串口调试,操作系统经过修改可以实现以太网口调试。宿主机和目标板的处理器一般都不相同,宿主机为Intel或AMD处理器,而目标板(例如本开发板)的处理器为ATMEL AT91RM9200。GN
11、U编译器提供这样的功能,在编译时可以选择开发所需的宿主机和目标机,从而建立开发环境。所以在进行嵌入式开发前的第一步工作就是要安装一台装有指定操作系统的PC作为宿主开发机。宿主机上的操作系统一般要求安装Linux,但Linux有多个发行版本,本系统推荐使用Redhat 9.0作为本开发板的宿主机PC操作系统(http:/www.linuxiso.org可以下载)。然后要在宿主机上建立交叉编译调试的开发环境。环境的建立需要许多软件模块协同工作,这是一个比较繁杂的工作,为此SemitARM9200实验系统提供了一套光盘,含有开发软件包及GNU编译工具,装载后安装工作完全自动完成。嵌入式系统及其开发应
12、用(第二版)嵌入式系统及其开发应用(第二版)185.1 基本原理基本原理v当开发环境安装完毕后,会在根目录下生成两个目录:工作目录/home/arm和交叉编译环境目录/usr/local/arm。v嵌入式开发通常要求宿主机配置有网络,支持NFS(为交叉开发时mount所用),支持TFTP服务器(为下载映像文件所用)等,这些将在后面介绍。(1)安装步骤v建议完全安装Redhat9.0 Linux操作系统(http:www.linuxiso.org提供下载),可以使用系统所附光盘启动安装Redhat9.0 Linux。刚开始安装不久,安装向导会弹出对话框询问安装服务器或工作站等,请选择自定义(Cu
13、stom)。安装过程中可以指定PC上网卡的IP地址。因为本开发板在烧写时默认的IP为192.168.0.23,所以建议宿主机IP地址也配置在此网段(192.168.0.X)。IP地址可以在安装时指定,也可以在PC安装好以后指定IP。在配置防火墙(Firewall)时,选择不安装防火墙(No Firewall)。在选择软件Package时,选择最后一项:Everything,即完全安装。完全安装完以后,大概占用4.8GB的硬盘空间。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)195.1 基本原理基本原理v最后选择Linux启动以后进入X模式还是文本模式,这个可以根据自己的爱好
14、决定。进入文本模式时,启动花费的时间少一些。即使进入X Windows,也可以按Ctrl+Alt+Fx(x在默认情况下可以是1,2,6)组合键,输入安装RedHat时设置的用户名(root或已经建立的其他用户)和密码,即可进入操作系统的Shell提示符,如:rootlocalhost root#。v注意:安装完成以后也可以修改etcinittab文件来选择进入X Windows还是进入字符模式。v将系统附带的光盘插入光驱,然后执行以下命令若主机系统是Redhat9.0,一般会自动识别并mount(挂载)插入的光盘:嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)205.1 基本
15、原理基本原理cd/mnt :进入mnt目录mkdir cdrom :建立cdrom目录mount/dev/cdrom/mnt/cdrom:mount插入的光盘cd/mnt/cdrom :进入CDROM所在目录./arminst:执行安装程序回车 :开始安装嵌入式实验系统软件v注意:进入中文环境是为了能够看到安装启动时的一些中文提示信息,若没有中文环境也无所谓,只是会看到一些乱码而已,用户只需输入y并按回车键即可完成全部安装(建议在安装前启动时就将串口线连好)。安装时,当前用户必须是root。v执行完毕后,会在根目录下生成工作目录:/home/arm,该目录含有Linux内核、应用程序源代码及各
16、个工具软件。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)215.1 基本原理基本原理v安装完系统后,安装程序自动配置Minicom终端程序,通常在宿主机上用Minicom观察开发板输出到串口的调试信息,也可以通过串口向开发板发送命令。Minicom类似于Windows下的超级终端程序。v用串口线连接SemitARM9200开发板的ttys0和宿主机的COM1,在宿主机任意目录下执行minicom,然后给开发板上电,就可以看到开发板启动时显示出来的信息。开发板启动后运行一个简化的shell进程,可以接受用户的控制,使用者可以输入一些简单的命令,如cd、ls来查看片上文件系统。
17、运行程序直接输入程序名,/bin下面都是可执行程序,用ps命令可以查看系统正在运行的进程。vSemitARM9200开发板要求minicom设置COM1为所选串口,波特率为115 200bps,无硬件流控,8位数据位,1位停止位,无奇偶校验,即8N1。v注意:串口线、JTAG线严禁带电拔插!嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)225.1 基本原理基本原理(2)NFS服务器的配置v首先在Redhat Linux PC上shell提示符root#下输入setup命令,弹出如图5.10所示的菜单。v选择System services项,按回车键进入系统服务选项菜单,选中*
18、nfs项,然后退出setup界面返回命令提示符:vim/etc/exports v将这个默认的空文件修改为只有如下一行内容:/(rw)/即根目录可读写,/和(rw)之间要留空格 v然后保存退出(:wq),执行如下命令启动NFS服务:/etc/rc.d/init.d/nfs restart 或 service nfs restart Shutting down NFS mountd:OK Shutting down NFS daemon:OK Shutting down NFS quotas:OK 嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)235.1 基本原理基本原理Shu
19、tting down NFS services:OK Starting NFS services:OK Starting NFS quotas:OK Starting NFS daemon:OK Starting NFS mountd:OK v启动完成后,推荐采用在PC上mount本机看是否成功来判断NFS是否已经配好。例如,在PC的根目录下执行(假定PC的IP地址配置为192.168.0.22):mount 192.168.0.22:/mnt v然后到/mnt/目录下看是否可以列出所指定的IP的机器(可以是本机,当然也可以测试其他机器是否可以被mount)根目录(/)下的所有文件和目录,如果
20、可以,则说明mount成功,NFS配置成功。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)245.1 基本原理基本原理(3)TFTP服务器的配置v在PC上执行setup,选择System services项,将其中的tftp一项选中(出现*表示选中),并去掉ipchains和iptables两项服务(即去掉它们前面的*号),如图5.11所示。v最后,退出setup,执行如下命令以启动TFTP服务:service xinetd restart v配置完成后,建议简单测试一下TFTP服务器是否可用,即在本机上tftp自己,例如,在PC上执行:cd/cp/etc/inittab/t
21、ftpboot/复制一个文件到/tftpboot目录下以供下面使用tftp命令下载嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)255.1 基本原理基本原理v下面以etc/inittab文件为例进行说明:tftp 192.168.0.22 tftp get inittab v如果在/tftpboot目录里没有下载的文件,会提示没有找到相关文件。若出现如下信息:Received 741512 bytes in 0.7 seconds 就表示TFTP服务器配置成功了,在根目录下就会有刚才下载的inittab文件存在了。若弹出信息为:Timed out,则表明未成功,建议用如下命令
22、查看tftp服务是否开通:netstat-a|grep tftp 若TFTP服务器没有配置成功,需要按照上述步骤重新检查一遍。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)265.1 基本原理基本原理图5.10 NFS的配置图5.11 TFTP服务的配置嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)275.1 基本原理基本原理(4)关闭防火墙v输入setup,选择Firewall configuration项,选中No firewall项,关闭防火墙,如图5.12所示。说明:Redhat Linux PC自测mount成功也不能完全说明NFS就可以工作了,因
23、为还有一个防火墙的问题,为此建议读者在安装Redhat Linux时默认选择No firewall。但若读者没有这样选择的话,REDHAT启动时会加载防火墙规则,这样就能自测mount,但其他PC和开发板也无法mount这台PC。注意:setup里面的防火墙显示永远都是HIGH,这个一直是Redhat的一个小BUG,即使安装时默认选择了No firewall,setup里面也照样会显示防火墙设置为HIGH。这个可以不必理会,只要选择了一次No firewall就可以了。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)285.1 基本原理基本原理 有时根目录不让读/写,建议在PC
24、的命令提示符下执行chmod 777/试试。Redhat在加入网关设置后,网络建立TCP链接非常慢,如FTP/TELNET/NFS等都是。建立链接后,以太网通信还是很快的。若安装网络时加入了网关,就会出现在开发板操作NFS mount Redhat PC时,输入mount-o nolock XXX.XXX.XXX.XXX:/mnt后非常长的时间不返回Shell提示符,就一直停在那里,这是因为建立连接的时间非常长。遇到这种情况,建议在Redhat Linux PC上执行:route del default 即去掉网关,然后再进行NFS mount等操作就会非常快了。测试NFS,必须用以太网将开发
25、板和Redhat Linux PC连接起来才行,连接的方式有两种:一是开发板和PC都用普通的网线接到Hub或者交换机上;二是用交叉网线将开发板和PC嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)295.1 基本原理基本原理图5.12 防火墙的配置嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)305.1 基本原理基本原理 直接连起来,不过一定要注意这种网线是特制的,其内部收发是交换的(即一头按普通网线的做法,另一头把1和3、2和6交换一下)。测试开发板和PC网络是否连通的方式是:开发板正常启动Linux后,在minicom里面ping一下PC看是否连通。当然,
26、用PC来ping开发板看是否接通也是可以的。v注意:开发板必须启动Linux后才能ping通,开发板处在bootloader阶段一般是无法ping通的,即使这时开发板的bootloader初始化了以太网也不行。在一般情况下,如果不设置网关,使用ping命令时,需要开发板和PC在同一个网段。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)315.1 基本原理基本原理v若开发板跟PC的网络不通,则mount报错信息为:#mount-o nolock 192.168.0.22:/mnt mount:RPC:Unable to receive;eNrno=No route Fo hos
27、t mount:Sfsmount failed:Bad file descriptor mount program didnt pass remote address!mount:Mounting 192.168.0.22:/on/mnt failed:Invalid argument 关于TFTP服务安装的问题。有些读者在安装Redhat Linux 时,没有在CustomPackages中选择everything,导致没有安装TFTP服务。典型的情况是,安装完成后没有/tftpboot目录,setupsystem services里面也没有tftp选项。这时若要重新完全安装就太麻烦了,可采
28、用如下单独安装TFTP的方法:rpm-ivh foo-1.0-5.i386.rpmv其中,foo-1.0-5.i386.rpm在Redhat 9.0 Linux操作系统的安装光盘里面。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)325.1 基本原理基本原理说明:v按照上面方法把PC上的Linux安装和配置好,就可以把系统提供的开发板的源代码包安装到PC上了。v如果没有配置好上面的TFTP服务,则SemitARM9200开发板就没有办法使用TFTP通过以太网下载映像文件。v如果上面的NFS没有配置好,则下面开发的应用程序就没有办法使用NFS服务,这一项虽然不是必须的,但是有了
29、这一项服务,可以大大方便调试应用程序的开发。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)335.1 基本原理基本原理5.1.3 文件与目录结构文件与目录结构1.光盘目录介绍光盘目录介绍v系统光盘的主目录内容如下。SEMIT.tar.gz:整个软件源代码和编译器的压缩包。arminstall:安装脚本文件,可以在Shell提示符下输入vi来打开,进入光盘目录以后,输入./arminstall,就会提示安装上面提到的tgz扩展名的文件,并且安装相应的编译器和复制minicom的设置文件。doc:“ARM9嵌入式系统+无线通信开发平台实验指导书V1.2”及其他芯片资料。嵌入式系统
30、及其开发应用(第二版)嵌入式系统及其开发应用(第二版)345.1 基本原理基本原理2.安装开发环境软件包安装开发环境软件包v启动PC上的Redhat 9.0 Linux操作系统,并将产品附带的光盘插入光驱,然后执行以下命令:mount/dev/cdrom/mnt/挂载光盘 cd/mnt./arminstall/执行安装脚本 v在安装的过程中会显示一些提示信息。v注意:执行完毕后,会在根目录下生成工作目录:/home/arm,内含Linux内核、蓝牙协议栈和应用程序、IEEE 802.11g模块驱动源码及bootloader。v安装完光盘提供的源代码文件和交叉编译环境以后,执行:cd/回到其他目
31、录才能卸载光盘 umount/mnt/卸载光盘 v现在可以取出光盘了。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)355.1 基本原理基本原理3.安装光盘后的目录介绍安装光盘后的目录介绍v安装光盘以后,会在PC的/home目录下生成名称为arm的目录,并且把编译器安装到该目录下指定的路径中去,同时在根目录下生成“SEMIT_Project”的应用程序目录:/home/arm/linux-2.4.19-rmk7 Linux的内核;/home/arm/bluez 蓝牙协议栈和应用程序;/home/arm/driver IEEE 802.11g模块的驱动源码;/home/arm/
32、bootloader/SEMIT平台的引导代码,可以通过修改这些源码来修改bootloader;/tftpboot/其下是编译好的映像文件或者可执行文件,其中,zImage是编译好的Linux内核映像文件,u-boot.bin是编译好的引导程序二进制代码,ramdisk.image4ppp.gz是ramdisk文件系统压缩的映像文件,TECH-burn-cmd是烧写时要用到的一些命令,已经把相关命令写到此文本文件中了。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)365.1 基本原理基本原理 minirc.dfl 本开发板启动时默认的串口终端配置,使用第一个串口(ttyS0)
33、。如果在串口设置时出了问题,可以把此文件复制到PC的/etc目录中,然后退出minicom,再重新进入minicom即可。v注意:这里的bootloader for AT91RM9200分为如下3个。AT91RM9200-Loader:生成loader.bin,在CPU内部SRAM中运行。这个可从home/arm/bootloader/AT91RM9200-Loader目录下的ld文件(ld.script)中看出:MEMORY ram:ORIGIN=0 x200000,LENGTH=0 x3000#上面这个0 x200000就是INTERNAL SRAM的地址嵌入式系统及其开发应用(第二版)嵌
34、入式系统及其开发应用(第二版)375.1 基本原理基本原理SECTIONS .text:_stext=.;*(.text)*(.rodata).=ALIGN(4);_etext=.;ram.data:_sdata=.;*(.data)*(.glue_7*).=ALIGN(4);_edata=.;ram.bss:_sbss=.;*(.bss).=ALIGN(4);_ebss=.;ram 嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)385.1 基本原理基本原理 simple_boot:生成boot.bin,烧到Flash上运行。u-boot-0.4.8:生成u-boot.bin
35、,可在SDRAM中运行,实际应用是烧到Flash上,由上面的boot.bin加载到SDRAM中运行。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)395.1 基本原理基本原理5.1.4 Linux系统的配置编译和文件系统系统的配置编译和文件系统v嵌入式Linux内核及设备驱动全部源代码(光盘安装后建立完备的开发环境)、交叉编译的工具集被放置到/usr/local/arm/2.95.3目录下,其中GNU工具集列于表5.3中。v编译内核的命令如下:cd/home/arm/linux-2.4.19-rmk7make zImage v编译完成后,就会自动把zImage复制到/tftp
36、boot/目录下以供TFTP下载。v如果需要对内核进行配置和裁剪,可以在/home/arm/linux-2.4.19-rmk7目录下输入如下指令:make menuconfig v这时将出现如图5.13所示的内核和驱动模块的配置界面,在这里可以对内核和驱动模块进行选择和设置。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)405.1 基本原理基本原理表5.3 GNU工具集嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)GNU工具集arm-linux-gccarm-linux-cc1plusarm-linux-ranlibarm-linux-asarm-linux
37、-objcopyarm-linux-stringsarm-linux-ldarm-linux-objdumparm-linux-gdbarm-linux-g+arm-linux-striparm-linux-gasparm-linux-cc1arm-linux-nmarm-linux-sizearm-linux-cpparm-linux-ararm-linux-addr2line415.1 基本原理基本原理图5.13 内核和驱动模块的配置界面嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)425.1 基本原理基本原理v若对系统类型进行设置,则出现如下内容:System Type
38、-(AT91RM9200-based)ARM system type-AT91RM9200 Implementation*SMDK(MERI TECH BOARD)*change AIJI AT91RM9200 USB function support-Processor Type*ARM920T CPU idle*ARM920T I-Cache on*ARM920T D-Cache on Force write through caches on ARM920T Support Thumb instructions(experimental)嵌入式系统及其开发应用(第二版)嵌入式系统及其开发
39、应用(第二版)435.1 基本原理基本原理v完成设置后,退出,保存设置,然后执行make zImage命令,即可编译生成所定制的内核映像文件,并自动复制到/tftpboot/目录下以供烧写。v如果想了解编译的过程,可输入如下命令把编译过程重新定向到log文件进行观察:make zImage&log/把编译信息输出到文件log 中vim log v即可看到完整的编译过程。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)445.1 基本原理基本原理5.1.5 Linux系统在地址空间中的位置系统在地址空间中的位置v开发板地址空间的分布(Memory Map)如图5.14所示。vAT
40、91RM9200提供了8个外部片选引脚用于外部寻址,即nGCSn07,每个片选都指定了固定的地址,其固定间隔为256MB。图5.15给出了整个32位的4GB地址空间的分布情况,其中除了8个外部总线接口(EBI,External Bus Interface)外,还包括内部存储器(Internal Memory)、外设(Peripheral)及尚未定义(Undefined)的地址空间。内部存储器和尚未定义的地址分布如图5.16所示。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)455.1 基本原理基本原理图5.14 开发板地址空间分布嵌入式系统及其开发应用(第二版)嵌入式系统及其
41、开发应用(第二版)465.1 基本原理基本原理vAT91RM9200提供了8个外部片选引脚用于外部寻址,即nGCSn07,每个片选都指定了固定的地址,其固定间隔为256MB。图5.15给出了整个32位的4GB地址空间的分布情况,其中除了8个外部总线接口(EBI,External Bus Interface)外,还包括内部存储器(Internal Memory)、外设(Peripheral)及尚未定义(Undefined)的地址空间。内部存储器和尚未定义的地址分布如图5.16所示。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)475.1 基本原理基本原理图5.15 整个32位的
42、4GB地址空间的分布情况嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)485.1 基本原理基本原理图5.16 内部存储器和尚未定义的地址分布嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)495.1 基本原理基本原理v外设部分的空间被映射到0 xFFFFF0000 xFFFFFFFF之间的4KB地址空间上。每个外设拥有256或者512字节,其详细的分布情况请参见光盘中CPU Manual第32页的图6 System Peripherals Mapping。v本开发板内存由两片16M16b数据宽度的SDRAM构成,两片拼成32位模式,公用nGCS1,共64MB
43、RAM。起始地址为0 x20000000。vnGCS0接的是1片8M16b数据宽度的INTEL E28F128 Flash,起始地址为0 x10000000。其中内核zImage烧写在地址0 x10040000开始处,根文件系统RAMDISK烧在0 x10240000地址处。vINTEL E28F128J3A-150 Flash的单片16MB,共128个扇区,每个扇区都是128KB大小,均匀分布。嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)505.1 基本原理基本原理5.1.6 中断中断vAT91RM9200开发板上扩展的外设接口占用片选和中断情况见表5.4。v中断资源列于
44、表5.5,由该表可以看出,AT91RM9200提供了7路外部中断和1路FIQ。表5.4 外设接口占用片选和中断情况嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)接 口占 用 片 选占 用 中 断13506视频芯片NCS2IDE硬盘NCS3PD23(中断号为5)PS/2键盘NCS4PD8(中断号为5)515.1 基本原理基本原理表5.5 AT91RM9200的中断资源嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)外设ID外设助记符外 设 名 称外 部 中 断0AIC增强中断控制器FIQ1SYSIRO2PLOA并行I/O控制器A3PLOB并行I/O控制器B4PL
45、OC并行I/O控制器C5PLOD并行I/O控制器D6US0USART 07US1USART 18US2USART 29US3USART 310MCI多媒体卡接口11UDPUSB器件端口12TWI两线接口13SPI串行外设接口14SSC0同步串行控制器015SSC1同步串行控制器116SSC2同步串行控制器217TC0定时器/计数器018TC1定时器/计数器119TC2定时器/计数器220TC3定时器/计数器321TC4定时器/计数器422TC5定时器/计数器523UHPUSB主机端口24EMAC以太网MAC25AIC增强中断控制器IRQ026AIC增强中断控制器IRQ127AIC增强中断控制器
46、IRQ228AIC增强中断控制器IRQ329AIC增强中断控制器IRQ430AIC增强中断控制器IRQ531AIC增强中断控制器IRQ6525.1 基本原理基本原理v在Linux里面request_irq所需要的中断向量号,也就是表5.5中左边一行的数值,在ARMLinux内核中有如下的定义:vlinux-2.4.19-rmk7/include/asm/arch/irqs.hvARMlinux都是统一在这个地方定义的,但对于9200它放到下面这个文件里:linux-2.4.19-rmk7/include/asm/arch/AT91RM9200.h#define AT91C_ID_FIQ(0)/
47、Advanced Interrupt Controller(FIQ)#define AT91C_ID_SYS(1)/System Peripheral#define AT91C_ID_PIOA(2)/Parallel IO Controller A#define AT91C_ID_PIOB(3)/Parallel IO Controller B#define AT91C_ID_PIOC(4)/Parallel IO Controller C#define AT91C_ID_PIOD(5)/Parallel IO Controller D#define AT91C_ID_US0(6)/USART
48、 0#define AT91C_ID_US1(7)/USART 1 嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)535.1 基本原理基本原理#define AT91C_ID_US2(8)/USART 2#define AT91C_ID_US3(9)/USART 3#define AT91C_ID_MCI(10)/Multimedia Card Interface#define AT91C_ID_UDP(11)/USB Device Port#define AT91C_ID_TWI(12)/Two-Wire Interface#define AT91C_ID_SPI(13)/
49、Serial Peripheral Interface#define AT91C_ID_SSC0(14)/Serial Synchronous Controller 0#define AT91C_ID_SSC1(15)/Serial Synchronous Controller 1#define AT91C_ID_SSC2(16)/Serial Synchronous Controller 2#define AT91C_ID_TC0(17)/Timer Counter 0#define AT91C_ID_TC1(18)/Timer Counter 1#define AT91C_ID_TC2(1
50、9)/Timer Counter 2 嵌入式系统及其开发应用(第二版)嵌入式系统及其开发应用(第二版)545.1 基本原理基本原理#define AT91C_ID_TC3(20)/Timer Counter 3#define AT91C_ID_TC4(21)/Timer Counter 4#define AT91C_ID_TC5(22)/Timer Counter 5#define AT91C_ID_UHP(23)/USB Host port#define AT91C_ID_EMAC(24)/Ethernet MAC#define AT91C_ID_IRQ0(25)/Advanced Inte