嵌入式计算机系统的设计 毕业论文.doc

上传人:小小飞 文档编号:3929676 上传时间:2019-10-10 格式:DOC 页数:31 大小:367.02KB
返回 下载 相关 举报
嵌入式计算机系统的设计 毕业论文.doc_第1页
第1页 / 共31页
嵌入式计算机系统的设计 毕业论文.doc_第2页
第2页 / 共31页
嵌入式计算机系统的设计 毕业论文.doc_第3页
第3页 / 共31页
嵌入式计算机系统的设计 毕业论文.doc_第4页
第4页 / 共31页
嵌入式计算机系统的设计 毕业论文.doc_第5页
第5页 / 共31页
点击查看更多>>
资源描述

《嵌入式计算机系统的设计 毕业论文.doc》由会员分享,可在线阅读,更多相关《嵌入式计算机系统的设计 毕业论文.doc(31页珍藏版)》请在三一文库上搜索。

1、29吉林大学远程教育2009届专科生毕业设计(论文) 吉林大学远程教育专科生毕业论文(设计)中文题目 嵌入式计算机系统的设计 学生姓名 专业 层次年级 学号 指导教师 职称 学习中心 成绩 年 月 日 摘 要 嵌入式系统是以应用为中心,以计算机技术为基础,软、硬件可裁剪,适应应用系统,对功能、可靠性、成本、体积、功耗等有严格要求的专用计算机系统。它具有以下特点:1、 与应用密切相关 嵌入式系统作为机器或设备的组成部分,与具体的应用密切相关。2、 实时性 嵌入式系统必须在实时方式下工作,若在规定的时间内某一请求得不到处理或者处理没有结束,可能会带来严重的后果。3、 复杂的算法 对不同的应用,嵌入

2、式系统有不同的算法。4、 制造成本 在某些情况下,制造成本决定了含有嵌入式系统的设备或产品能否在市场上被成功地销售。5、 功耗 许多嵌入式系统采用电池供电,因此对功耗有严格的要求。6、 开发和调试 必须有相应的开发环境、开发工具和调试工具,才能进行开发和调试。7、 可靠性 嵌入式系统应该能够可靠地运行,比如能在规定的温度、湿度环境下连续运行、有一定的抗干扰能力。8、 体积 嵌入式系统一般都要求体积尽可能地小。 随着计算机技术、信息技术和数据技术的发展,嵌入式系统的将向着更加小、更快速、功耗更低以及互联网的方向发展。关键词:可靠性 实时性 抗干扰29第一章绪论1.1嵌入式系统1.1.1嵌入式系统

3、简介随着计算机技术和微电子技术的迅速发展,嵌入式系统应用领域越来越广泛。当今,嵌入式系统已成为一个时髦的名词,就像当初的计算机热潮,似乎比当初的计算机热潮涉及的领域更广泛,应用技术人员更多,相关国民经济产值也更庞大。报纸、杂志、网络都把嵌入式系统当作讨论的热门话题。1.1.2 实时多任务操作系统RTOS(Real Time multi-tasking Operation System),即实时多任务操作系统是嵌入式应用软件的基础和开发平台。目前在中国大多数嵌入式软件开发还是基于处理器直接编写,没有采用商品化的RTOS,不能将系统软件和应用软件分开处理。RTOS是一段嵌入在目标代码中的软件,用户

4、的其它应用程序都建立在RTOS之上。不但如此,RTOS还是一个可靠性和可信性很高的实时内核,将CPU时间、中断、I/O、定时器等资源都包装起来,留给用户一个标准的API,并根据各个任务的优先级,合理地在不同任务之间分配CPU时间。 TOS是针对不同处理器优化设计的高效率实时多任务内核,优秀商品化的RTOS可以面对几十个系列的嵌入式处理器MPU、MCU、DSP、SOC等提供类同的API接口,这是RTOS基于设1.1.3嵌入式操作系统的发展状况国外嵌入式操作系统已经从简单走向成熟,主要有VMware、QNX、Palmas、Windows CE、嵌入式Linux等。国内的嵌入式操作系统研究开发有2种

5、类型,一类是基于国外操作系统2次开发完成的,如海信的基于Windows CE的机顶盒系统;另一类是中国自主开发的嵌入式操作系统,如凯思集团公司自主研制开发的嵌入式操作系统Hope OS(“女娲计划”)等。 1.1.4嵌入式系统软件的特点嵌入式处理器的应用软件是实现嵌入式系统功能的关键,对嵌入式处理器系统软件和应用软件的要求也和通用计算机有所不同。 1.软件要求固态化存储。为了提高执行速度和系统可靠性,嵌入式系统中的软件一般都固化在存储器芯片或单片机本身中,而不是存贮于磁盘等载体中。 2.软件代码高质量、高可靠性。尽管半导体技术的发展使处理器速度不断提高、片上存储器容量不断增加,但在大多数应用中

6、,存储空间仍然是宝贵的,还存在实时性的要求。为此要求程序编写和编译工具的质量要高,以减少程序二进制代码长度、提高执行速度。 3.系统软件(OS)的高实时性是基本要求。在多任务嵌入式系统中,对重要性各不相同的任务进行统筹兼顾的合理调度是保证每个任务及时执行的关键,单纯通过提高处理器速度是无法完成和没有效率的,这种任务调度只能由优化编写的系统软件来完成,因此系统软件的高实时性是基本要求。 4.多任务操作系统是知识集成的平台和走向工业标准化道路的基础。1.2嵌入式开发概述1.2.1 嵌入式系统开发需要开发工具和环境 通用计算机具有完善的人机接口界面,在上面增加一些开发应用程序和环境即可进行对自身的开

7、发。而嵌入式系统本身不具备自举开发能力,即使设计完成以后用户通常也是不能对其中的程序功能进行修改的,必须有一套开发工具和环境才能进行开发,这些工具和环境一般是基于通用计算机上的软硬件设备以及各种逻辑分析仪、混合信号示波器等。 1.2.2 嵌入式系统软件需要RTOS开发平台 通用计算机具有完善的操作系统和应用程序接口(API),是计算机基本组成不可分离的一部分,应用程序的开发以及完成后的软件都在OS平台上面运行,但一般不是实时的。嵌入式系统则不同,应用程序可以没有操作系统直接在芯片上运行;但是为了合理地调度多任务、利用系统资源、系统函数以及和专家库函数接口,用户必须自行选配RTOS开发平台,这样

8、才能保证程序执行的实时性、可靠性,并减少开发时间,保障软件质量。 1.2.3 嵌入式系统开发人员以应用专家为主 通用计算机的开发人员一般是计算机科学或计算机工程方面的专业人士,而嵌入式系统则是要和各个不同行业的应用相结合的,要求更多的计算机以外的专业知识,其开发人员往往是各个应用领域的专家。因此开发工具的易学、易用、可靠、高效是基本要求。1.2.4嵌入式系统高级编程语言Ada语言是20世纪70年代美国国防部开发并投入使用的功能强大的通用系统开发语言,最初为Ada83。它支持模块化、独立编译、协处理等功能。其可靠性、可维护性、可读性都是相当好的。后来,为了更好地支持OOP(Object-Orie

9、nted Programming),对其进行了改进,形成了目前广泛使用的Ada95。使用Ada语言可以大大改善系统的清晰性、可靠性、可维护性等性能指标2,3。它是美国国防部指定的唯一一种可用于军用系统开发的语言。第二章ARM处理器结构和ARM指令集 2.1ARM处理器结构ARM(Advanced RISC Machines)是微处理器行业的一家知名企业,该企业设计了大量高性能、廉价、耗能低的RISC处理器、相关技术及软件。技术具有性能高、成本低和能耗省,适用于多种领域,比如嵌入控制、消费/教育类多媒体、DSP和移动式应用等。ARM处理器的框架如图2-1所示乘法器指令解码地址自增器nRESETn

10、MREQSEQABORTnIRQnFIQnRWMAS1:0LOCKnCPICPACPBnWAITMCLKnOPCBIGENDISYNCnTRANSnM4:0桶形移位器32 位 ALU写数据 寄存器读数据 寄存器地址寄存器寄存器A31:0ABE及控制 逻辑PC Update解码站指令 解码IncrementerPCABusBBus 图2-1ARM处理器架构2.1.1寄存器和处理器模式1.ARM 有7个基本工作模式:User:非特权模式,大部分任务执行在这种模式。限制你的内存访问并且你不能直接读取硬件设备正常程序执行的模式FIQ:当一个高优先级(fast)中断产生时将会进入这种模式高速数据传输和通

11、道处理IRQ:当一个低优先级(normal)中断产生时将会进入这种模式通常的中断处理Supervisor:当复位或软中断指令执行时将会进入这种模式供操作系统使用的一种保护模式程序计数器构造如下图2-2: 2731N Z C V Q2867I F T mode1623 815 54024fsxc U n d e f i n e dJ图2-2 程序计数器构造n 条件位:n N = 1-结果为负,0-结果为正或0n Z = 1-结果为0,0-结果不为0n C =1-进位,0-借位n V =1-结果溢出,0结果没溢出n Q 位:n 仅ARM 5TE/J架构支持n 指示增强型DSP指令是否溢出n J 位

12、n 仅ARM 5TE/J架构支持n J = 1: 处理器处于Jazelle状态n 中断禁止位:n I = 1: 禁止 IRQ.n F = 1: 禁止 FIQ.n T Bitn 仅ARM xT架构支持n T = 0: 处理器处于 ARM 状态n T = 1: 处理器处于 Thumb 状态n Mode位(处理器模式位):n 0b10000Usern 0b10001FIQn 0b10010IRQn 0b10011Supervisorn 0b10111Abortn 0b11011Undefinedn 0b11111Systemn 当处理器执行在ARM状态:n 所有指令 32 bits 宽n 所有指令必

13、须 word 对齐n 所以 pc值由bits 31:2决定, bits 1:0 未定义 (所以指令不能halfword / byte对齐).n 当处理器执行在Thumb状态:n 所有指令 16 bits 宽n 所有指令必须 halfword 对齐n 所以 pc值由bits 31:1决定, bits 0 未定义 (所以指令不能 byte对齐).n 当处理器执行在Jazelle状态:n 所有指令 8 bits 宽n 处理器执行 word 存取一次取4条指令2.2ARM指令集2.2.1ARM存贮访问指令ARM存贮访问指令如下表2-1: 表2-1 ARM存贮访问指令助记符说明操作条件码位置MUL Rd

14、,Rm,Rs32位乘法指令RdRm*Rs (RdRm)MULcondSMLA Rd,Rm,Rs,Rn32位乘法指令RdRm*Rs+Rn (RdRm)MLAcondSUMULL RdLo,RdHi,Rm,Rs64位无符号乘法指令(RdLo,RdHi)Rm*RsUMULLcondSUMLAL RdLo,RdHi,Rm,Rs64位无符号乘法指令(RdLo,RdHi)Rm*Rs+(RdLo,RdHi)UMLALcondSSMULL RdLo,RdHi,Rm,Rs64位无符号乘法指令(RdLo,RdHi)Rm*RsSMULLcondSSMLAL RdLo,RdHi,Rm,Rs64位无符号乘法指令(RdL

15、o,RdHi)Rm*Rs+(RdLo,RdHi)SMLALcondS2.2.2数据处理指令数据处理指令如下表2-2 表2-2 数据处理指令助记符号说明操作条件码位置MOV Rd,operand2数据转送Rd-operand2MOV condSMVN Rd,operand2数据非转送Rd-(NOT)operand2MVN condSADD Rd,Rn,operand2加法运算指令Rd-Rn+operand2ADD condSSUB Rd,Rn,operand2减法运算指令Rd-Rn-operand2SUB condSRSB Rd,Rn,operand2逆向减法指令Rd-operand2-RnRS

16、B condSADC Rd,Rn,operand2带进位加法Rd-Rn+operand2+carryADC condSRSC Rd,Rn,operand2带进位减法Rd-Rn-perand2-(NOT)CarryRSC condSAND Rd,Rn,operand2带进位逆向减法Rd-Rn&operand2AND condSORR Rd,Rn,operand2逻辑或操作指令Rd-Rn|operand2ORR condSEOR Rd,Rn,operand2逻辑异或操作指令Rd-Rnoperand2EOR condSBIC Rd,Rn,operand2位清除指令Rd-Rn(operand2)BIC

17、 condCMP Rd,Rn,operand2比较指令标志N、Z、C、V-Rn-operand2CMP condCMN Rd,Rn,operand2负数比较指令标志N、Z、C、V-Rn+operand2CMN condTST Rd,Rn,operand2位测试指令标志N、Z、C、V-Rn&operand2TST condTEQ Rd,Rn,operand2相等测试指令标志N、Z、C、V-Rnoperand2TEQ cond2.2.3乘法指令乘法指令如下表2-3:表2-3 乘法指令助记符说明操作条件码位置MUL Rd,Rm,Rs32位乘法指令RdRm*Rs (RdRm)MULcondSMLA R

18、d,Rm,Rs,Rn32位乘法指令RdRm*Rs+Rn (RdRm)MLAcondSUMULL RdLo,RdHi,Rm,Rs64位无符号乘法指令(RdLo,RdHi)Rm*RsUMULLcondSUMLAL RdLo,RdHi,Rm,Rs64位无符号乘法指令(RdLo,RdHi)Rm*Rs+(RdLo,RdHi)UMLALcondSSMULL RdLo,RdHi,Rm,Rs64位无符号乘法指令(RdLo,RdHi)Rm*RsSMULLcondSSMLALcondSSMLALcondSSMLALcondSSMLALcondS2.2.4 跳转指令跳转指令如下表2-4: 表2-4 跳转指令助记符说

19、明操作条件码位置B label跳转指令PclabelBcondBL label带链接的跳转指令LRPC-4,PClabelBLcondRX Rm带状态切换的跳转指令PClable,切换处理状态BXcond2.2.5杂项指令杂项指令如下表2-5: 表2-5 杂项指令助记符说明操作条件码位置SWI immed_24软中断指令产生软中断,处理器进入管理模式SWIcondMRS Rd,psr读状态寄存器指令Rdpsr,psr为CPSR或SPSRMRScondMRS psr_fields,Rd/#immed_8r写状态寄存器指令Psr_fieldsRd/#immed_8r,psr为CPSR或SPSRMS

20、Rcond2.2.6Thumb指令集Thumb指令可以作是ARM指令压缩形式的子集,是针对代码密度的问题而提出的,它具有16位的代码密度。Thumb不是一个完整的体系结构,不能指望处理只执行Thumb指令而不支持ARM指令集。Thumb指令集没有协处理器指令。ARM和Thumb之间切换使用BX 指令。 Thumb指令与ARM指令在实现上差别不大,在此就不再对Thumb指令集进行详细的介绍了。第三章C/OS-的移植3.1移植的要求和准备这一章介绍如何将C/OS-移植到不同的处理器上。所谓移植,就是使一个实时内核能在某个微处理器或微控制器上运行。为了方便移植,大部分的C/OS-代码是用C语言写的;

21、但仍需要用C和汇编语言写一些与处理器相关的代码,这是因为C/OS-在读写处理器寄存器时只能通过汇编语言来实现。由于C/OS-在设计时就已经充分考虑了可移植性,所以C/OS-的移植相对来说是比较容易的。要使C/OS-正常运行,处理器必须满足以下要求:3.2移植具体过程3.2.1 C/OS-的软硬件结构体系Samsung S3C44B0X微处理器是三星公司专为手持设备和其它嵌入式应用提供的高性价比的微控制器解决方案。它使用ARM公司的16位/32位RISC结构,内核是ARM7TDMI,工作在66MHz,片上集成了以下部件:8K Cache、外部存储器控制器、LCD控制器、4个DMA通道、2个UAR

22、T、1个多主I2C总线控制器、1个I2C总线控制器,以及5通道PWM定时器和1个内部定时器、8通道12位ADC等,能够与常用的外围设备实现无缝连接,功能强大。目前,国内应用较为广泛。C/OS-应用程序C/OS-处理器无关代码OS-CORE.C OS-Q.COS-MBOX.C OS-MEN.COS-TASK.C C/OS-.COS-TIME.C C/OS-.HOS-SEM.CC/OS-设置(应用相关)OS-CFG.HINCLUDES.HC/OS-处理器相关代码OS_CPU.H OS_CPU_A.ASMOS_CPU_C.CC/OS-编译器相关定义存储器系统时钟外围设备处 理 器图3-1 C/OS-

23、软硬件体系结构 图3.1说明了C/OS-II的软硬件体系结构。应用程序处于整个系统的顶层,每个任务都可以认为自已独占了CPU,因而可以设计成为一个无限循环。C/OS-II处理器无关的代码提供了C/OS-II的系统服务,应用程序可以使用这些API函数进行内存管理、任务间通信及创建、删除任务等。大部分的C/OS-II代码是使用ANSI C语言书写的,因此C/OS-II的可移植性好,然而仍需要使用C和汇编语言写一些处理器相关代码。C/OS-II的移植需要满足以下要求:1.处理器的C编译器可以产生可重入代码;2.可以使用C调用进入和退出临界区代码;3.处理器必须支持硬件中断,并且需要一个定时中断源;4

24、.处理器需要能够容纳一定数据的硬件堆栈;5.处理器需要有能够在CPU寄存器与内核和堆栈交换数据的指令。S3C44B0X处理器完全满足上述要求。3.2.2 实时内核C/OS-II在S3C44B0X上的移植我们使用ARM SDT编译器,移植C/OS-II主要包括以下几个步骤。1.设置OS_CPU.H中与处理器和编译器相关的代码*与编译器相关的数据类型*typedef unsigned char BOOLEAN;typedef unsigned char INT8U; /8位无符号整数typedef signed char INT8S; /8位有符号整数typedef unsigned short

25、INT16U; /16位有符号整数typedef signed short INT16S; /16位无符号整数typedef unsigned long INT32U; /32位无符号整数typedef signed long INT32S; /32位有符号整数typedef float FP32; /单精度浮点数typedef double FP64; /双精度浮点数typedef unsigned int OS_STK; /*堆栈入口宽度为16位与ARM处理器相关的代码:*/#define OS_ENTER_CRITICAL () ARMEnableInt() /开启中断#define O

26、S_STK_GROWTH 1 /堆栈由高地址向低地址增长2.用C语言编写6个操作系统相关的函数(OS_CPU_C.C)void OSTaskStkInit(void(task)(void *pd),void *pdata,void *ptos,INT16U opt) unsigned int *stk;*-stk=0; /*r9*/LDMFD sp!,r4MSR SPSR_cxsf,r4LDMFD sp!,r0-r12,lr pc完成上述工作后,C/OS-II就可以运行在ARM处理器上了。3.2.3 使用C/OS-II系统应注意的问题1.C/OS-II和Linux等分时操作系统不同,不支持时间

27、片轮转法。它是一个基于优先级的实时操作系统。每一个任务的优先级必须不同(分析它的源码会发现,C/OS-II把任务的优先级当作任务在标识来使用,如果优先级相同,任务将无法区分)。进入就绪态的优先级最高的任务首先得到CPU的使用权,只有等它交出CPU的使用权后,其它任务才可以被执行。所以,它只能就是多任务,不能就是多进程,至少不是我们所熟悉的那种多进程。2.C/OS-II对共享资源提供了保护的机制。C/OS-II是一个支持多任务的操作系统。我们可以把一个完整的程序划分成几个任务,不同的任务执行不同的功能。对于共享资源(比如串口),C/OS-II也提供了很好的解决办法,一般情况下使用的是信号量方法。

28、我们创也第四章网络转串口驱动的开发4.1Lwip在C/OS-上的移植4.1.1开源TCP/IP协议栈LwIP简介随着嵌入式系统与网络的日益结合,在嵌入式实时操作系统中引入TCP/IP协议栈,以支持嵌入式设备接入网络,成为嵌入式领域重要的研究方向。uC/0S II是近年来发展迅速的一TCP/IP实现的重点是在保持TCP协议主要功能的基础上减少对RAM的占用,一般它只需要几十K的RAM和40K左右的ROM就可以运行,这使LwIP协议栈适合在低端嵌入式系统中使用。4.1.2基于uC/0S II的网络平台概述 嵌入式操作系统uC/0S II是一个公开源代码的占先式多任务的微内核RTOS,其性能和安全性

29、可以与商业产品竞争。uC/0S II的特点可以概括为以下几个方面:公开源代码,代码化的,用户需要付费才能获得,很少给出源代码,这影响了uC/0S II的研究和推广。通过把开放源代码的TCP/IP协议栈LwIP移植到uC/0S II上来,就获得了一套可免费研究、学习的嵌入式网络软件平台。系统示意图如下图4-1: 图4-1 uC/0S IILwIP系统示意图4.1.3 LwIP在uC/0S II下的实现 LwIP协议栈在设计时就考虑到了将来的移植问题,因此把所有与硬件、OS、编译器相关的部份独立出来,放在/src/arch目录下。因此LwIP在uC/0S II上的实现就是修改这个目录下的文件,其它

30、的文件一般不应该修改。下面分几部份分别说明相应文件的实现原理和过程。现在网上最新的版本是V0.6.41.lwip的进程模型(process model)tcp/ip协议栈的process model一般有几种方式.(1)tcp/ip协议的每一层是一个单独进程.链路层是一个进程,ip层是一个进程,tcp层是一个进程。这样的好处是网络协议的每一层都非常清晰,代码的调试和理解都非常容易.但是最大的坏处数据跨层传递时会引起上下文切换(context switch).对于接收一个TCP segment要引起3次context switch(从网卡驱动程序到链路层进程,从链路层进程到ip层进程,从ip层进

31、程到TCP进程).通常对于操作系统来说,任务切换是要浪费时间的.过频的context swich是不可取的.(2)另外一种方式是TCP/IP协议栈在操作系统内核当中.应用程序通过操作系统的系统调用(system call)和协议栈来进行通讯。这样TCP/IP的协议栈就限定于特定的操作系统内核了.如windows就是这种方式.。2.Port Lwip to uCos (其实在ucos的实现中我们使用的是Message Queue来实现lwip中的”mbox”,下面大家可以看到这一点) Operating system emulation layer的原代码在/lwip/src/core/sys.

32、c中.而和具体的操作系统相关的代码在./lwip/src/arch/sys_arch.c中.操作系统封装层的主要函数如下:void sys_init(void) /系统初始化sys_thread_t sys_thread_new(void (* function)(void *arg), void *arg,int prio)/创建一个新进程sys_mbox_t sys_mbox_new(void) /创建一个邮箱rch.txt.文件. (2) Lwip在ucos上的移植. 系统初始化sys_int必须在tcpip协议栈任务tcpip_thread创建前被调用.#define MAX_QUEU

33、ES20#define MAX_QUEUE_ENTRIES20 &LWIP_TASK_STKcurr_prio_offsetLWIP_STK_SIZE-1,LWIP_START_PRIO+curr_prio_offset );curr_prio_offset+; return 1; else / PRINT( lwip task prio out of range ! error! );从代码中可以看出tcpip_thread应该是最先创建的.Lwip中的定时事件。在tcp/ip协议中很多时候都要用到定时,定时的实现也是tcp/ip协议栈中一个重要的部分.lwip中定时事件的数据结构如下. s

34、truct sys_timeout struct sys_timeout *next; /指向下一个定时结构u32_t time;/定时时间sys_timeout_handler h; /定时时间到后执行的函数void *arg; /定时时间到后执行函数的参数.;struct sys_timeouts struct sys_timeout *next;struct sys_timeouts lwip_timeoutsLWIP_TASK_MAX;Lwip中的定时事件表的结构如下图,每个和tcp/ip相关的任务的一系列定时事件组成一个单向链表.每个链表的起始指针存在lwip_timeouts的对应

35、表项中,如下图4-2 图4-2Lwip中的定时事件表的结构函数sys_arch_timeouts返回对应于当前任务的指向定时事件链表的起始指针.该指针存在lwip_timeoutsMAX_LWIP_TASKS中.struct sys_timeouts null_timeouts;struct sys_timeouts * sys_arch_timeouts(void)u8_t curr_prio;s16_t err,offset;OS_TCB curr_task_pcb;null_timeouts.next = NULL;/获取当前任务的优先级err = OSTaskQuery(OS_PRIO

36、_SELF,&curr_task_pcb);curr_prio = curr_task_pcb.OSTCBPrio;offset = curr_prio - LWIP_START_PRIO;/判断当前任务优先级是不是tcp/ip相关任务,优先级5-9if(offset = LWIP_TASK_MAX)return &null_timeouts;return &lwip_timeoutsoffset;ping 192.168.1.95 l 2000 t,不间断用长度为2000的数据报进行ping测试,同时使用tftp客户端软件给192.168.1.95下载一个十几兆程序,同时再使用telnet连

37、接192.168.1.95端口7(echo端口),往该端口写数测试echo功能.在运行一段时间以后,开发板进入不再响应.我当时也是经过长时间的分析才发现是因为在低优先级任务运行ys_arch_timeouts()时被高优先级任务打断改写了curr_task_tcb的值,从而使sys_arch_timeouts返回的指针错误,进而导致系统死锁.函数sys_timeout给当前任务增加一个定时事件:void sys_timeout(u32_t msecs, sys_timeout_handler h, void *arg)struct sys_timeouts *timeouts;struct s

38、ys_timeout *timeout, *t;timeout = memp_malloc(MEMP_SYS_TIMEOUT); /为定时事件分配内存if (timeout = NULL) return;timeout-next = NULL;timeout-h = h;timeout-arg = arg;timeout-time = msecs;timeouts = sys_arch_timeouts(); /返回当前任务定时事件链表起始指针if (timeouts-next = NULL) /如果链表为空直接增加该定时事件timeouts-next = timeout;return;/如果

39、链表不为空,对定时事件进行排序.注意定时事件中的time存储的是本事件/时间相对于前一事件的时间的差值if (timeouts-next-time msecs) *data = NULL;/单位转换,从ucos tick-mstimeout = (ucos_timeout -ucErr)*(1000/ OS_TICKS_PER_SEC);return timeout;semaphone的实现和mbox类似,这里就不再重复了.4.2MAC和IP地址设置4.2.1嵌入式网络设备中MAC及IP地址的特点 MAC地址在这里特指以太网定义的一个48位(6字节)地址。每台连到以太网网络的计算机分配一个唯一

40、的48位(6字节)数字,即它的以太网地址。为分配地址,以太网硬件制造商购买以太网地址块,在生产以太网接口硬件时顺序给它们分配。MAC地址属于物理层的地址,对于不同类型的网络,其物理址分配方式不同,但本论文中介绍的设置方法都适用。IP地址(IP address)也叫互连网地址(Internet address)。它是TCP/IP的设计人员选择的一个类似于物理网络的编址地址。互连网上的每个主机都分配了一个唯一的32位(4字节)整数地址。IP地址属于软件协议层的地址。只要主机上运行TCP/IP协议,其IP地址的编址方式就符合这个统一标准。在嵌入式系统中,操作系统和所有的应用软件都被固化到Flash等

41、存储设备中。在嵌入式系统中很少使用外存。嵌入式系统的启动往往也是“自动”的,即从上电到处于工作状态,不用人的介入。这是嵌入式设备应用的要求和特点嵌入式网络设备中的MAC及IP地址的设置有它的特点:1.关心和接触嵌入式网络设备MAC地址的人比关心和接触通用计算机MAC地址的人多得多。 件。4.2.2MAC及IP地址的设置 本嵌入式网络设备系统的MAC及IP地址设置的基本思想是:把MAC及IP地址存放在Flash的未用扇区(一般在高扇区),嵌入式操作系统启动后,自动运行一个程序去读取MAC及IP地址并设置它。用户如何把MAC及IP地址放到Flash中?通过计算机串口与网络设备的RS232接口(即串口)相连,使用超级终端的方式,运行网络设备中的程序把数据写入Flash中。先运行提供的TFTPD32文件出现界面如下图4-3所示: 下图4-4是下载并运行 test.bin 的一个例子(提供源码) 图4-3 TFTPD32文件出现界面 图4-4 利用tftp下载并运行 test.bin 的一个例子3:参数设置和程序自动装载运行:到

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 其他


经营许可证编号:宁ICP备18001539号-1