嵌入式报告打印_第1页
嵌入式报告打印_第2页
嵌入式报告打印_第3页
嵌入式报告打印_第4页
嵌入式报告打印_第5页
已阅读5页,还剩17页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、本科实验报告课程名称: 嵌入式操作系统 实验项目: 实验一:任务的基本管理 实验地点: 学科楼506实验室 专业班级: 计Z1101 学号: 2011001488 学生姓名: 郭晓云 指导教师: 张兴忠 2014年 04月15日太原理工大学学生实验报告学院名称计算机科学与技术专业班级计Z1101学号2011001488学生姓名郭晓云实验日期2014-04-15成绩课程名称嵌入式操作系统实验题目任务的基本管理一、 实验目的和要求(1)理解任务管理的基本原理,了解任务的各个基本状态及其变迁过程;(2)掌握µC/OS-II中任务管理的基本方法(创建、启动、挂起、解挂任务);(3)熟练使用&

2、#181;C/OS-II任务管理的基本系统调用。二、实验器材(设备、元器件):硬件环境:PC计算机;软件环境:WIN98/2000/XP、BC4.5(Borland C+ 4.5)、tasm.exe;三、实验内容可剥夺型内核,基于优先级调度。操作系统总是使处于就绪态的优先级最高的任务首先获得CPU的使用权。通过使用系统提供的函数控制任务实现各种功能。为了展现任务的各种基本状态及其变迁过程,本实验设计Task0、Task1两个任务:任务Task0不断地挂起自己,再被任务Task1解挂,两个任务不断地切换执行。通过本实验,可以清晰地了解到任务在各个时刻的状态以及状态变迁的原因。注意:图中的栅格并不

3、代表严格的时间刻度,而仅仅表现各任务启动和执行的相对先后关系。四、实验步骤整个应用的运行流程如图所示,其描述如下:(1)系统经历一系列的初始化过程后进入boot_card()函数,在其中调用ucBsp_init()进行板级初始化后,调用main()函数;(2)main()函数调用OSInit()函数对µC/OS-II内核进行初始化,调用OSTaskCreate创建起始任务TaskStart;(3)main()函数调用函数OSStart()启动µC/OS-II内核的运行,开始多任务的调度,执行当前优先级最高的就绪任务TaskStart;(4)TaskStart完成如下工作:a

4、、安装时钟中断并初始化时钟,创建2个应用任务;b、挂起自己(不再被其它任务唤醒),系统切换到当前优先级最高的就绪任务Task0。之后整个系统的运行流程如下:t1时刻,Task0开始执行,它运行到t2时刻挂起自己;t2时刻,系统调度处于就绪状态的优先级最高任务Task1执行,它在t3时刻唤醒Task0,后者由于优先级较高而抢占CPU;Task0执行到t4时刻又挂起自己,内核调度Task1执行;Task1运行至t5时刻再度唤醒Task0;系统启动后,经历一系列的初始化过程,进入main()函数,这是我们编写实现应用程序的起点。首先需要在main()函数里创建起始任务TaskStart:OSTask

5、Create(TaskStart, (void *)0, &TaskStartStkTASK_STK_SIZE - 1, 4); TaskStart任务TaskStart任务负责安装操作系统的时钟中断服务例程、初始化操作系统时钟,并创建所有的应用任务:ucos_x86_idt_set_handler(0x20,(void *)OSTickISR,0x8e00); /* Install uC/OS-II's clock tick ISR */ucos_timer_init(); /*Timer 初始化*/TaskStartCreateTasks(); /* Create all

6、the application tasks */OSTaskSuspend(OS_PRIO_SELF);具体负责应用任务创建的TaskStartCreateTasks函数代码如下,它创建了两个应用任务Task0和Task1:static void TaskStartCreateTasks (void) INT8U i;for (i = 0; i < N_TASKS; i+) /* Create N_TASKS identical tasks */ TaskDatai = i; /* Each task will display its own letter */ OSTaskCreate

7、(Task0, (void *)&TaskDatai, &TaskStkiTASK_STK_SIZE - 1, 5); OSTaskCreate(Task1, (void *)&TaskDatai, &TaskStk1TASK_STK_SIZE - 1, 6); TaskStart任务完成上述操作后将自己挂起,操作系统将调度当前优先级最高的应用任务Task0运行。应用任务Task0运行后将自己挂起,之后操作系统就会调度处于就绪状态的优先级最高的任务,具体代码如下:void Task0 (void *pdata)INT8U i;INT8U err;i=*(int

8、*)pdata; for (;) /*此处为输出信息,显示任务运行的状态 */err=OSTaskSuspend(5); /* suspend itself */ 应用任务Task1运行后将Task0唤醒,使其进入到就绪队列中:void Task1 (void *pdata) INT8U i; INT8U err; i=*(int *)pdata;for (;) OSTimeDly(150); /*此处为输出信息,显示任务运行的状态 */OSTimeDly(150); err=OSTaskResume(5); /* resume task0 */ 5、 实验结果实验地点学科楼506实验室指导教

9、师张兴忠本科实验报告课程名称: 嵌入式操作系统 实验项目: 实验二:中断与系统时钟实验 实验地点: 博学馆506实验室 专业班级: 计Z1101 学号: 2011001488 学生姓名: 郭晓云 指导教师: 张兴忠 2014年04月15日太原理工大学学生实验报告学院名称计算机科学与技术专业班级计Z1101学号2011001488学生姓名郭晓云实验日期2014-04-15成绩课程名称嵌入式操作系统实验题目中断与系统时钟实验一、实验目的和要求掌握嵌入式实时操作系统µC/OS中中断的使用情况。二、实验器材(设备、元器件):硬件环境:PC计算机;软件环境:WIN98/2000/XP、BC4.

10、5(Borland C+ 4.5)、tasm.exe;三、实验内容和原理在本实验中,设计了三个任务Task1、Task2、Task3,创建了一个信号量InterruptSem。Task1和Task2获得信号量InterruptSem后延时,Task1延时200Tick,Task2延时500Tick,利用Task3输出的次数来对Task1和Task2的延时计数,Task3每100Tick产生一次输出。4、 操作方法与实验步骤整个系统的运行流程如下:1) 系统初始化,在TaskStart任务中,创建并启动任务Task1、Task2、Task3,优先级分别为12,13,14。2) 在TaskStar

11、t任务中创建一个信号量InterruptSem(初值为1)。3) 任务在TaskStart任务中挂起自己,操作系统实施调度,进入Task1运行;4) 任务Task1睡眠100ticks;5) 任务Task2开始执行, 任务Task2获得信号量InterruptSem;6) 任务Task2睡眠500tick,任务Task3投入运行,打印输出语句后延时,任务Task1睡眠时间到继续投入运行,它申请信号量InterruptSem失败被阻塞;7) 任务Task3投入运行,循环地打印输出语句。期间时钟中断不断产生,在中断处理程序中对任务Task2的睡眠时间进行计数;8) Task2睡眠时间到后恢复运行,

12、并释放信号量InterruptSem;9) Task1获得信号量InterruptSem后抢占Task2运行;10) Task1使用完信号量InterruptSem后释放该信号量;11) 系统从步骤4重复执行,一直运行下去五、实验代码及结果:void Task1 (void *pdata) INT8U err; pdata=pdata; for (;) OSTimeDly(100);printk("nTask1is try to get semaphore.nn"); /*task1 delay 100 clock ticks */OSSemPend(InterruptSe

13、m, 0, &err); /* Acquire semaphore to get into the room */printk("Task1 has Succeed to obtain semaphore.n");printk("Task1 is delayed.nn");OSTimeDly(200); printk("nThe delay of Task1 finished .n"); printk("Task1 release semaphore.n");OSSemPost(InterruptSem);

14、 /* Release semaphore */OSTimeDly(200); void Task2 (void *pdata) INT8U err;pdata=pdata;for (;) printk( "nTask2 is try to get semaphore.n");OSSemPend(InterruptSem, 0, &err); /* Acquire semaphore to get into the room */printk( "Task2 has Succeed to obtain semaphore.n");printk(&

15、quot;Task2 is delayed.nn");OSTimeDly(500); /*task2 delay 500 clock ticks */ printk("nThe delay of Task2 finished .n");printk("Task2 release semaphore.n");OSSemPost(InterruptSem); /* Release semaphore */OSTimeDly(200); void Task3 (void *pdata) pdata=pdata; for (;) printk(&quo

16、t;Task3 has got the CPU:|n"); OSTimeDly(100); 本科实验报告课程名称: 嵌入式操作系统 实验项目: 实验三:信号量测试 实验地点: 博学馆506实验室 专业班级: 计Z1101 学号: 2011001488 学生姓名: 郭晓云 指导教师: 张兴忠 2014年04月15日太原理工大学学生实验报告学院名称计算机科学与技术专业班级计Z1101学号2011001488学生姓名郭晓云实验日期2014-04-15成绩课程名称嵌入式操作系统实验题目信号量实验一、实验目的和要求掌握在基于嵌入式实时操作系统µC/OS-II的应用中,任务使用信号量的

17、一般原理。通过实验,了解如何利用信号量来对共享资源进行互斥访问。二、实验器材(设备、元器件):硬件环境:PC计算机;软件环境:WIN98/2000/XP、BC4.5(Borland C+ 4.5)、tasm.exe;三、实验内容假设有共享资源R,允许2个任务分时访问R,那么信号量的值应设置为2,系统中有3个用户任务访问资源R,分别为任务A、B、C,优先级分别为7、6、5。任务A运行后创建信号量,并访问R,访问完成后任务A将自己阻塞1000个时钟周期。任务B先阻塞300个时钟周期,然后操作步骤同任务A。任务C先阻塞400个时钟周期然后操作步骤同任务A。假设3个任务操作资源R需要的时间都是1000

18、个时钟周期,对资源R的操作用延时语句虚拟完成。4、 操作方法与实验步骤实验代码: void UserTaskSemA(void *pParam) /*任务SemA创建信号量,然后周期性访问资源R*/*创建信号量*/INT8U *perr;INT8U err;/INT8U i;OS_SEM_DATA mySemData;err=0;perr=&err;MyEventSem=OSSemCreate(2); if (MyEventSem=(OS_EVENT *)0)printf("任务A创建信号量失败!n");OSTaskDel(OS_PRIO_SELF); return

19、;OSSemQuery(MyEventSem,&mySemData); printf("时间:%d, 任务A创建信号量。当前信号量值=%dn",OSTimeGet(),mySemData.OSCnt);while(1) OSSemQuery(MyEventSem,&mySemData); printf("时间:%d,任务A开始请求信号量!当前信号量值=%dn",OSTimeGet(),mySemData.OSCnt);OSSemPend(MyEventSem,0,perr);if (err!=OS_ERR_NONE) printf(&qu

20、ot;任务A请求信号量失败n"); printf("错误号%dn",err); continue; OSSemQuery(MyEventSem,&mySemData); printf("时间:%d,任务A获得信号量。当前信号量值=%d,任务A开始对R操作n",OSTimeGet(),mySemData.OSCnt); OSTimeDly(1000); /*模拟操作资源,需要10秒,1000个时钟嘀嗒*/ printf("时间:%d,任务A结束资源操作,提交信号量!n",OSTimeGet(); OSSemPost(M

21、yEventSem); OSSemQuery(MyEventSem,&mySemData); printf("时间:%d,任务A提交信号量完成,当前信号量值=%d,任务A将延时阻塞1000嘀嗒n",OSTimeGet(),mySemData.OSCnt); OSTimeDly(1000);void UserTaskSemB(void *pParam) /*任务SemA创建信号量,然后周期性访问资源R*/INT8U *perr;INT8U err;OS_SEM_DATA mySemData;err=0;perr=&err;printf("时间:%d,

22、任务B开始延时300个时钟嘀嗒",OSTimeGet(); OSTimeDly(300);/*任务B先延时3秒*/if (MyEventSem=(OS_EVENT *)0)printf("任务A创建信号量失败!n");OSTaskDel(OS_PRIO_SELF); return;while(1) OSSemQuery(MyEventSem,&mySemData); printf("时间:%d,任务B开始请求信号量!当前信号量值=%dn",OSTimeGet(),mySemData.OSCnt);OSSemPend(MyEventSem

23、,0,perr);if (err!=OS_ERR_NONE) printf("任务B请求信号量失败n"); printf("错误号%dn",err); continue; OSSemQuery(MyEventSem,&mySemData); printf("时间:%d,任务B获得信号量。当前信号量值=%d,任务B开始对R操作,需1000个时钟嘀嗒n",OSTimeGet(),mySemData.OSCnt); OSTimeDly(1000); /*模拟操作资源,需要10秒,1000个时钟嘀嗒*/ printf("时间

24、:%d,任务B结束资源操作,提交信号量!n",OSTimeGet(); OSSemPost(MyEventSem); OSSemQuery(MyEventSem,&mySemData); printf("时间:%d,任务B提交信号量完成,当前信号量值=%d,任务B将延时阻塞1000嘀嗒n",OSTimeGet(),mySemData.OSCnt); OSTimeDly(1000);void UserTaskSemC(void *pParam) /*任务SemA创建信号量,然后周期性访问资源R*/INT8U *perr;INT8U err;INT8U i;O

25、S_SEM_DATA mySemData;err=0;perr=&err; printf("时间:%d,任务C开始延时400个时钟嘀嗒",OSTimeGet(); OSTimeDly(400);/*任务C先延时4秒*/if (MyEventSem=(OS_EVENT *)0)printf("任务A创建信号量失败!n");OSTaskDel(OS_PRIO_SELF); return;while(1) OSSemQuery(MyEventSem,&mySemData); printf("时间:%d,任务C开始请求信号量!当前信号量

26、值=%dn",OSTimeGet(),mySemData.OSCnt);OSSemPend(MyEventSem,0,perr);if (err!=OS_ERR_NONE) printf("任务C请求信号量失败n"); printf("错误号%dn",err); continue; OSSemQuery(MyEventSem,&mySemData); printf("时间:%d,任务C获得信号量。当前信号量值=%d,任务C开始对R操作,需1000个时钟嘀嗒n",OSTimeGet(),mySemData.OSCnt)

27、; OSTimeDly(1000); /*模拟操作资源,需要10秒,1000个时钟嘀嗒*/ printf("时间:%d,任务C结束资源操作,提交信号量!n",OSTimeGet(); OSSemPost(MyEventSem); printf("时间:%d,任务C提交信号量完成,当前信号量值=%d,任务C将延时阻塞1000嘀嗒n",OSTimeGet(),mySemData.OSCnt); OSTimeDly(1000);5、 实验数据记录和处理本科实验报告课程名称: 嵌入式操作系统 实验项目: 实验四:内存管理 实验地点: 博学馆506实验室 专业班级

28、: 计Z1101 学号: 2011001488 学生姓名: 郭晓云 指导教师: 张兴忠 2014年 4月 15日 太原理工大学学生实验报告学院名称计算机科学与技术专业班级计Z1101学号2011001488学生姓名郭晓云实验日期2014-04-15成绩课程名称嵌入式操作系统实验题目内存管理实验二、 实验目的和要求掌握嵌入式实时操作系统µC/OS-II内存管理中内存分配和回收的功能。2、 实验器材(设备、元器件):硬件环境:PC计算机;软件环境:WIN98/2000/XP、BC4.5(Borland C+ 4.5)、tasm.exe;三、实验内容和原理内存管理的核心是内存的动态分配和释

29、放。在该实验中,首先创建一个内存分区,该分区包含3个块,申请3次后,第4次申请失败;释放过程也是这样,当内存已经满了,就不可能再释放内存块给内存了。四、操作方法与实验步骤实验代码:void TaskM(void *pParam) INT8U *perr; INT8U err,i; OS_MEM *pmyMem; /MCB块地址 INT8U myMem320; /用来做内存分区 void *pblk10; /内存块地址数组 BOOLEAN require; OS_MEM_DATA mem_data;/用于查询内存块信息 err=OS_ERR_NONE; perr=&err; requir

30、e=1; pmyMem=OSMemCreate(myMem,3,20,perr);/*创建内存分区,10个块, 每个块20个字节*/ if (pmyMem=(OS_EVENT *)0) /*检查是否创建成功*/ printf("时间:%d, TaskM创建内存分区失败n",OSTimeGet(); OSTaskDel(OS_PRIO_SELF); /*不成功则删除本任务*/return; printf("时间:%d, TaskM创建内存分区成功,包含10个块, 每个块20个字节n",OSTimeGet(); i=0; while(1) if (i>5) i=0; require=!require; /printf("时间:%d,i=%dn",OSTimeGet(),i); OSTimeDly(100);/*延时1秒*/ if (require) printf("时

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论