嵌入式系统开发总结(uCCOS+uCGUI+uCFS)

时间:2019-05-12 06:35:35下载本文作者:会员上传
简介:写写帮文库小编为你整理了多篇相关的《嵌入式系统开发总结(uCCOS+uCGUI+uCFS)》,但愿对你工作学习有帮助,当然你在写写帮文库还可以找到更多《嵌入式系统开发总结(uCCOS+uCGUI+uCFS)》。

第一篇:嵌入式系统开发总结(uCCOS+uCGUI+uCFS)

嵌入式系统开发总结(uC/COS+uC/GUI+uC/FS)

今天终于把做了一个多月的嵌入式系统软件交了上去。终于可以轻松一下了,但是期末临近,看来没得闲了。现在总结一下整个开发过程,希望对想要入门嵌入式系统开发的朋友有所帮助。

首先要说的是,整个开发过程很艰苦,主要是因为第一次接触嵌入式开发,入门很难,同时由于大三有很多专业课,还有六级、实习面试等,在此对我的队友陈、马表示感谢,谢谢他们和我一直坚持到最后。

该系统实现基于uC/COS、uC/GUI、uC/FS的整合。首先要根据硬件配置三者。根据uC/GUI、uC/FS的文档资料很容易移植到操作系统uC/COS。其文档资料的下载地址请参见文章最后。

uC/COS是基于嵌入式的实时操作系统,它管理任务、内存、文件、电源等,为嵌入式系统提供多任务的开发环境。uC/GUI是一种用于嵌入式应用的图形支持软件,本系统借用uC/GUI实现系统所需要的各种界面。uC/FS是一种文件系统,本系统借用其来管理存储器中的文件,在book、message中都用到文件的读写,可以说uC/FS是本系统实现的不可或缺的部分。

该系统所有界面由uC/GUI 实现。主界面一窗口(Frame)为容器,添加菜单栏(Menu)来控制整个系统。其他界面以Dialog为容器,在Dialog中添加按钮(Button)、列表(ListView)、多行编辑框(MultiEdit)等。系统采用了“回调函数”机制,回调函数在用户程序中定义,当一个指定的事件发生时,通知图形系统调用指定的函数。通常应用于一个窗口内容改变时自动重绘的场合。该系统利用回调函数初始化窗口,当窗口内容改变时重绘窗口,同时处理事件响应,例如当鼠标点击“Read”按钮是,通过回调函数调用txtTask()函数弹出电子书显示对话框(Txt)。

总的来说,该设计结构合理,逻辑严密,各个模块相互协调实现了复杂的功能。系统界面小组力求简单大方,各个模块的功能实现都用到了不少精妙的算法。但是,由于小组能力有限,前期对嵌入式的了解浅薄,以及时间等各方面的限制,系统并没有完全实现所预期的功能,也可以说仅实现了一些辅助功能。首先说message模块,设计预期是用到红外发送,实现与红外手机的数据传输和操纵手机的短信发送,但是在实际操作中小组发现需要扩展外围电路(红外发送),由于资金问题,小组讨论放弃该功能,仅实现了信息编辑和信息保存功能。其实该功能的实现小组也是有很清晰的思路的,如果有足够的资金和时间,小组完全可以实现该功能,这里很有些遗憾。

然后是文件系统,最后的几天里,我们发现了一个严重的问题,也就是我们所用文件系统所管理的RAM是可挥发性的(一时没有意识到),我们保存到其中的文件在系统下一次启动的时候都会消失。小组发现norflash是不可挥发的存储器,于是我们考虑将文件存储到norflash中,但是在将norflash添加到uC/FS中的过程中,我们发现必须为其编写驱动程序。经过数天的努力,我们编辑出了norflash的uC/FS驱动,但是很遗憾,没有成功,竞赛举办方给出的norflash模块的实验太过简单,无法编辑驱动程序的底层控制存储器算法。(本小组编写的norflash驱动将在附件中给出)

Music模块,其实music仅仅实现了简单的mp3播放功能,同时提供暂停、下一首等功能,但是经过小组的不懈努力仍然没有声音。于是我们怀疑是硬件模块(UCB1400、AC97CODEC)的问题。

系统整体功能也有待改进,比如开机,进行一段时间的操作后,系统就会不正常的死掉。虽然我们做了大量的性能改良功能,但这个问题依然存在。

小组在近期做了此次竞赛的总结,一直表示此次竞赛给我们提供了一个很好的学习机会,大家都有了很大的提高,至少是对嵌入式有了切身的认识。大家对嵌入式系统设计也有了很大的兴趣,同时表示将在以后对嵌入式进行更深层次的研究。

在此,我们对同类设计提供一些建议。前期应该对资金、时间等做准确的估计,同时选择最主要的功能模块,这样可以集中有限精力将单个模块的功能实现的更加强大。在功能设计的阶段应尽量考虑到所有细节,这样可以避免在最后时刻发现关键因素致使系统功能大打折扣。系统的创新点:

1、使用uC/FS管理文件

电子书模块和短信编辑模块的Save功能都需要大量操作文件的代码。由于实时操作系统uC/GUI没有实现文件系统,在参考了各种版本的文件系统后,小组决定选用uC/FS。uC/FS是一种FAT格式的文件系统,它可以用于所有的存储媒体,但你必须提供存储媒体的底层接口函数。

引进uC/FS后,小组很方便地实现了系统的各种主要功能。

2、借用软键盘代替手写字体识别功能

当考虑到手写字体识别功能的难度和时间的有限,小组讨论果断决定使用软件盘实现字符的输入功能。

首先,小键盘界面小巧简洁。我们以woindow系统中的软键盘为模板,删除掉不需要的复杂按键,形成了独具风格的嵌入式版软键盘。

其次,由于界面大小限制,软键盘进入了”shift”键,实现键盘按键的切换,实现了所有字符(包括数字、大小写字母和各种操作符)的输入功能。

3、系统内容丰富多彩

这一点可以说是系统的坏处也可以说是系统的好处,坏处就是由于本次竞赛时间有限,有些功能实现的也比较简单,但是可惜的是该系统脉络清晰,很合理地将各个模块有机地结合到了一起。而且各个模块并不是相互独立的,而是相互约束、相互协作的。例如:message模块的Save功能,将文本信息保存到存储器中,保存的文件有可以在book中查阅;通讯录协助message模块中Send功能的手机号码查询。

这些都可以说是本系统的一大特色。

主界面:

(各个模块的界面以及具体实现请参看后续文章)程序流程框图:

uC/GUI中文手册下载:http://download.csdn.net/source/466900

uC/FS正式版(内含使用手册)下载:http://download.csdn.net/source/466918 uC/COS中文手册下载:http://download.csdn.net/source/466905 uC/GUI完整实例(超有用):http://download.csdn.net/source/467738

第二篇:学习嵌入式系统开发心得

你好,我是一名嵌入式开发爱好者.近来总是看到很多初学者(多数是在校大学生)由于没有条件,想学习却不知道如何下手。

本人绝对能体会到学习的艰辛,而且视任何对知识技术有强烈追求的人(不管目前水平高低)为同路人,所以整理短文一篇写出一些学习感受,替所有渴望知识的人企盼高手指点学习之路,分享经验。

爱因斯坦说过,”我是站在巨人的肩膀上“

实践当然是最锻炼人的方式,但是我想在校生很少有这样的机会,别说本科生,硕士生也未必有条件。所以我想学习嵌入式要从个人的知识背景和现实条件出发。订立合适的阶段目标,在允许的条件下多动手多思考。

一般情况下对于硬件设备是比较短缺的。但是可以从软件方面和嵌入式系统开发模式上下功夫,提醒大家一点,嵌入式系统开发设计的内容知识很多,所以大家不要乱,在了解嵌入式系统开发的体系结构后,一步一步的下手,最容易上手的是linux下的C,比如ucos(有开放源代码),虽然可能无法在硬件上仿真,但也不必着急。wince,palmos上手都很容易。无论对于初学者还是自以为是高手的人来说,编程水平(这可不受硬件条件限制)绝对是没有止境的,有了较高的编程水平(嵌入式主要是C,当然OO的几种语言c++,java是发展趋势),等到有机会的时候及时的补充硬件知识,会很快的成为高手。

还有,一定记住,学习嵌入式,”要想办法,不要找理由“。当年在dos下用tc编程时的条件,现在回想起来建筑就是奇迹。

我推荐一条学习之路吧,仅供参考,1、C开发经验

条件:linux(这都有吧)

方法:随便,主要是掌握ansiC编程(不包括gtk,qt等图形可视化开发)

2、网络、操作系统、体系结构

条件:linux,各种书,算法、例程。

方法:通过C编程实现简单的网络等知识的算法和过程。

3、嵌入式系统概念

条件:各个嵌入式网站,讨论组,书籍

方法:少提问(尤其是等着天上掉馅饼,这主要是防止增长惰性,也解决不了实际问题),多思考。

4、嵌入式开发实践

条件:各种嵌入式系统开发工具的demo版(或者D版,如果有的话),包括编译器,仿真器。可以找高手们要,也可以下载。

方法:这里有两个分支,一个是基于mcu/dsp的嵌入式系统开发,一个是象palmos,wince,ucos等rtos下的应用软件开发。对硬件感兴趣,想成为真正高手的由第一个分支入手,以后进入第二个分支;如果十分厌烦硬件,只想停留在软件开发上的,可以只由第二个分支入手,以后就和pc上的开发没有什么本质上的区别了,找份不错的工作应该没问题,可以不用进行下面的步骤了,感兴趣可以参考第6条。

5、硬件开发

条件:各种嵌入式芯片、存储器等电路器件,protel99等电路设计软件,电路板制作。

方法:这时候该有开发条件了,最起码是51系列,这个比较方便。电路的设计内容较多,不过看起来吓人,实际上比软件要简单的多。只要下功夫,实践会告诉你一切。

6、硬件工程/软件工程/项目管理

条件: 各个芯片详细资料和使用经验,软件工程知识,项目管理知识,培训,大型项目参与经验

方法:已经是高手了,但是学无止境,沾沾自喜于已有的知识是致命的。那个下一步。。,你该是管理者了。

抛砖引玉,以上出自我的经验,欢迎各路高手们补一下 再告诉你一些我的收藏夹的网站

国内有关嵌入式开发的论坛

电子产品世界的论坛

http://bbs.edw.com.cn/index.asp

恒颐高科论坛

http://www.xiexiebang.com/

中国单片机公共实验室

http://www.xiexiebang.com/

北京科银京成技术公司

http://www.xiexiebang.com/

微芯力科技

http://www.xiexiebang.com

驱动开发网之嵌入式版块,挺综合的一个网站

http://www.xiexiebang.com/index.php

电子爱好者家园[2004年09月30日] http://home.ee521.com/main.asp

广州友善之臂电子有限公司

http://www.arm9.net/index.asp

好了 兄弟 开始努力 我们一起加油哈...

第三篇:嵌入式Linux系统开发教程实验报告

嵌入式Linux系统开发教程实验报告

组员:武易 金鹏飞 周长升

实验一 熟悉嵌入式系统开发环境

一实验目的

1.熟悉嵌入式系统硬件实验平台 2.掌握超级终端配置方法。

3.掌握嵌入式系统开发环境配置,ARM-Linux下NFS服务器的配置方法 4.掌握常用的 Linux下shell命令

二实验设备及工具

硬件:UP-NETARM2410-S嵌入式实验仪、PC机pentumn500以上、硬盘40G以上、内存大于256M。

软件:PC机操作系统REDHAT LINUX 9.0、MINICOM、AMRLINUX开发环境

三实验内容

(1)掌握嵌入式系统实验平台上的各类借接口的位置;

(2)配置windows的超级终端,熟悉vivi的命令行,bootload、kernel、root和用户程序的介绍;

(3)配置linux的终端,配置网络服、Ip地址,开发目录共享,挂载等。

四实验结果

实验二嵌入式Linux程序设计

一实验目的

1.掌握嵌入式Linux软件设计方法原理 2.掌握Makefile文件设计方法。

3.熟悉Linux下静态库和共享库的设计

二实验设备及工具

硬件:UP-NETARM2410-S嵌入式实验仪、PC机pentumn500以上、硬盘40G以上、内存大于256M。

软件:PC机操作系统REDHAT LINUX 9.0、MINICOM、AMRLINUX开发环境

三实验内容

(1)编写一个带输入、输出的由5个文件组成的嵌入式软件;(2)写好makefile文件,并上机调试;(3)用变量指明两种编译器。

四实验结果

实验三

kernel与root的设计和烧写

一实验目的

1.掌握Linux内核配置与裁剪的方法 2.理解根文件系统配置。

3.掌握嵌入式系统内核和根文件系统的烧写的过程

二实验设备及工具

硬件:UP-NETARM2410-S嵌入式实验仪、PC机pentumn500以上、硬盘40G以上、内存大于256M。

软件:PC机操作系统REDHAT LINUX 9.0、MINICOM、AMRLINUX开发环境

三实验内容

对嵌入式Linux系统进行裁剪、配置和编译,生成自己需要的操作系统映像文件,并将其烧写到flash中。

四实验结果

实验四搭建嵌入式系统开发环境

一实验目的

1.掌握嵌入式开发环境的配置 2.掌握开发工具链的安装与配置。

3.掌握嵌入式系统内核和根文件系统的烧写的过程

二实验设备及工具

硬件:UP-NETARM2410-S嵌入式实验仪、PC机pentumn500以上、硬盘40G以上、内存大于256M。

软件:PC机操作系统REDHAT LINUX 9.0、MINICOM、AMRLINUX开发环境

三实验内容

(1)安装配置嵌入式开发环境;(2)安装与配置工具链;(3)内核和根文件系统的烧写

四实验结果

实验五嵌入式驱动程序设计

一实验目的

1.学习在LINUX 下进行驱动设计的原理

2.掌握使用模块方式进行驱动开发调试的过程

二实验设备及工具

硬件:UP-NETARM2410-S嵌入式实验仪、PC机pentumn500以上、硬盘40G以上、内存大于256M。

软件:PC机操作系统REDHAT LINUX 9.0、MINICOM、AMRLINUX开发环境

三实验内容

在PC 机上编写简单的虚拟硬件驱动程序并进调试,实验驱动的各个接口函数的实现,分析并理解驱动与应用程序的交互过程。

四实验结果

实验六

S3C2410处理器硬件电路设计

一实验目的

1.熟悉硬件电路设计

2.掌握简单的S3c2410处理器的电路设计。3.掌握protel软件的使用

二实验设备及工具

硬件:UP-NETARM2410-S嵌入式实验仪、PC机pentumn500以上、硬盘40G以上、内存大于256M。

软件:PC机操作系统REDHAT LINUX 9.0、MINICOM、AMRLINUX开发环境

三实验内容

使用protel 99se 做s3c2410处理器最小系统电路设计,A/D数据采集模块电路设计。

四实验结果

第四篇:嵌入式Linux系统开发教程实验报告

嵌入式实验报告

姓名: 学号: 学院: 日期:

实验一 熟悉嵌入式系统开发环境

一、实验目的

熟悉 Linux 开发环境,学会基于S3C2410 的Linux 开发环境的配置和使用。使用Linux的armv4l-unknown-linux-gcc 编译,使用基于NFS 方式的下载调试,了解嵌入式开发的基本过程。

二、实验内容

本次实验使用 Redhat Linux 9.0 操作系统环境,安装ARM-Linux 的开发库及编译器。创建一个新目录,并在其中编写hello.c 和Makefile 文件。学习在Linux 下的编程和编译过程,以及ARM 开发板的使用和开发环境的设置。下载已经编译好的文件到目标开发板上运行。

三、实验设备及工具

硬件::UP-TECH S2410/P270 DVP 嵌入式实验平台、PC 机Pentium 500 以上, 硬盘10G 以上。

软件:PC 机操作系统REDHAT LINUX 9.0+超级终端(或X-shell)+AMR-LINUX 开发环境。

四、实验步骤

1、建立工作目录

[root@localhost root]# mkdir hello [root@localhost root]# cd hello

2、编写程序源代码

我们可以是用下面的命令来编写hello.c的源代码,进入hello目录使用vi命令来编辑代码:

[root@localhost hello]# vi hello.c 按“i”或者“a”进入编辑模式,将上面的代码录入进去,完成后按Esc 键进入命令状态,再用命令“:wq!”保存并退出。这样我们便在当前目录下建立了一个名为hello.c的文件。hello.c源程序: #include int main(){ char name[20];scanf(“%s”,name);printf(“hello %s”,name);return 0;}

3、编写Makefile

要使上面的hello.c程序能够运行,我们必须要编写一个Makefile文件,Makefile文件定义了一系列的规则,它指明了哪些文件需要编译,哪些文件需要先编译,哪些文件需要重新编译等等更为复杂的命令。使用它带来的好处就是自动编译,你只需要敲一个“make”命令整个工程就可以实现自动编译。Makefile源程序:

CC= armv4l-unknown-linux-gcc EXEC = hello OBJS = hello.o CFLAGS += LDFLAGS+= –static all: $(EXEC)$(EXEC): $(OBJS)$(CC)$(LDFLAGS)-o $@ $(OBJS)clean:-rm-f $(EXEC)*.elf *.gdb *.o 下面我们来简单介绍这个Makefile 文件的几个主要部分: CC 指明编译器

EXEC 表示编译后生成的执行文件名称 OBJS 目标文件列表 CFLAGS 编译参数 LDFLAGS 连接参数 all: 编译主入口

clean: 清除编译结果

注意:“$(CC)$(LDFLAGS)-o $@ $(OBJS)”和“-rm-f $(EXEC)*.elf *.gdb *.o”前空白由一个Tab 制表符生成,不能单纯由空格来代替。

与上面编写 hello.c的过程类似,用vi来创建一个Makefile文件并将代码录入其中。

[root@localhost hello]# vi Makefile

4、编译应用程序

在上面的步骤完成后,我们就可以在hello 目录下运行“make”来编译我们的程序了。如果进行了修改,重新编译则运行: [root@localhost hello]# make clean//编译应用程序 [root@localhost hello]# make//下载调试

注意:编译、修改程序都是在宿主机(本地PC 机)上进行,不能在超级终端下进行。

5、下载调试

在宿主PC计算机上启动NFS服务,并设置好共享的目录,(这里将刚生成的根目录/arm2410cl作为共享目录,以下实验同理)具体配置请参照前面第一章第四节中关于嵌入式Linux 环境开发环境的建立。在建立好NFS共享目录以后,我们就可以进入超级终端中建立开发板与宿主PC机之间的通讯了。

[/mnt/yaffs] mount-t nfs-o nolock 192.168.0.56:/arm2410cl /host //超级终端中执行

如果不想使用我们提供的源码的话,可以再建立一个NFS 共享文件夹。如/root/share,我们把我们自己编译生成的可执行文件复制到该文件夹下,并通过超级终端挂载到开发板上。

[root@localhost hello]# cp hello /root/share //虚拟机中

[/mnt/yaffs] mount-t nfs-o nolock 192.168.0.56:/root/share /host //超级终端中 再进入/host目录运行刚刚编译好的hello程序,查看运行结果。[/mnt/yaffs] cd /host //超级终端中 [/host]./hello hello world(1)在PC计算机上启动NFS 服务,并设置好共享的目录。

启动 Red Hat Linux –>点击“主菜单”->选择“系统设置”->“服务器设置”->“NFS服务器”->“增加”->“基本”下:点击“浏览”选择“/”下的“arm2410cl/”;“确定”;“主机:192.168.0.* ”;“基本权限”选择“读/写”;“确定”。->“常规选项”下:选择:“允许来自高于1024的端口的连接”,其他不选;确定。(2)在建立好NFS共享目录以后,进入minicom 中建立开发板与宿主PC机之间的通讯

新建终端

[root@localhost root]# minicom//服务器 新建终端

[root@localhost root]#ifconfig eth0 192.168.0.10 //设置主机地址 [root@localhost root]#ifconfig //查看地址 在服务器下:

[/mnt/yaffs] mount-t nfs –o nolock 192.168.0.56:/arm2410cl /var 注意:开发板挂接宿主计算机目录只需要挂接一次便可,只要开发板没有重起,就可以一直保持连接。这样可以反复修改、编译、调试,不需要下载到开发板。

6、实验截图

7、测试结果

测试挂载成功,用mplayer xyz.avi命令播放视频 [root@localhost /]#cd /mnt/yaffs/mm [root@localhost /]#mplayer xyz.avi

五、实验心得

本次实验比较简单,旨在让我们熟悉Linux开发环境,学会基于S3C2410的Linux开发环境的配置和使用。实验中我们创建了一个新目录,并在其中编写hello.c和Makefile文件。我们学习在Linux下的编程和编译过程,以及ARM开发板的使用和开发环境的设置,下载已经编译好的文件到目标开发板上运行。学会使用Linux的armv4l-unknown-linux-gcc编译和基于NFS方式的下载调试,了解嵌入式开发的基本过程。实验二 S3C2410处理器A/D模块硬件设计

一、实验目的

1.熟悉硬件电路设计

2.掌握简单的S3c2410处理器的电路设计。3.掌握protel软件的使用。

二、实验内容

使用protel 99se 做s3c2410处理器最小系统电路设计,A/D数据采集模块电路设计。

三、实验设备及工具

硬件:UP-TECH S2410/P270 DVP 嵌入式实验平台、PC 机Pentium 500 以上, 硬盘10G以上。

软件:PC 机操作系统REDHAT LINUX 9.0、超级终端(或X-shell)、ARM-LINUX 开发环境

五、实验原理

1、A/D 转换器

A/D 转换器是模拟信号源和CPU 之间联系的接口,它的任务是将连续变化的模拟信号转换为数字信号,以便计算机和数字系统进行处理、存储、控制和显示。在工业控制和数据采集及许多其他领域中,A/D 转换是不可缺少的。

A/D 转换器有以下类型:逐位比较型、积分型、计数型、并行比较型、电压-频率型,主要应根据使用场合的具体要求,按照转换速度、精度、价格、功能以及接口条件等因素来决定选择何种类型。常用的有以下两种:(1)双积分型的 A/D 转换器;(2)逐次逼近型的 A/D 转换器。

2、A/D 转换的重要指标(1)分辨率(Resolution)

(2)精度(Accuracy)

(3)ARM 自带的十位A/D 转换器(4)A/D 转换器在扩展板的连接(A/D 转换器在扩展板的接法如图2.4.2 所示,前三路通过电位器接到3.3v 电源上。)

图 2.4.2 A/D 转换器在扩展板上的接法

六、实验步骤

1、阅读理解源码

进入/arm2410cl/exp/basic/04_ad 目录,使用vi 编辑器或其他编辑器阅读理解源代码。

2、编译应用程序

运行make产生ad可执行文件

[root@localhost /]# cd /arm2410cl/exp/basic/04_ad/ [root@localhost 04_ad]# make armv4l-unknown-linux-gcc-c-o main.o main.c armv4l-unknown-linux-gcc-o../bin/ad main.o-lpthread armv4l-unknown-linux-gcc-o ad main.o-lpthread [root@localhost 04_ad]# ls ad hardware.h main.o Makefile.bak s3c2410-adc.h bin main.c Makefile readme.txt src

3、下载调试

到超级终端窗口,使用 NFS mount 开发主机的/arm2410cl 到/host 目录。[/mnt/yaffs] mount-t nfs-o nolock 192.168.0.56:/arm2410cl /host [/mnt/yaffs]insmod ad/s3c2410-adc.o [/mnt/yaffs]cd /host/exp/basic/04_ad [/host/exp/basic/04_ad]./ad Press Enter key exit!a0= 0.0032 a1= 3.2968 a2= 3.2968 我们可以通过调节开发板上的三个黄色的电位器,来查看a0、a1、a2 的变化。

4、原理图

5、实验截图

七、实验心得

通过本次试验,我学会了A/D接口原理,了解实现A/D系统对于硬件要求。阅读ARM芯片文档,掌握ARM的A/D相关寄存器的功能,熟悉ARM系统硬件的A/D相关接口,还了解在Linux环境下对S3C2410芯片的8通道10位A/D模块的硬件设计。实验三

Kernel与root的设计和烧写

一、实验目的

1.掌握Linux内核配置与裁剪的方法 2.理解根文件系统配置。

3.掌握嵌入式系统内核和根文件系统的烧写的过程。

二、实验内容

对嵌入式Linux系统进行裁剪、配置和编译,生成自己需要的操作系统映像文件,并将其烧写到flash中。

三、实验设备及工具

硬件:UP-NETARM2410-S嵌入式实验仪、PC机pentumn500以上、硬盘40G以上、内存大于256M。

软件:PC机操作系统REDHAT LINUX 9.0、MINICOM、AMRLINUX开发环境.四、实验步骤

1、设计过程:

2、烧写过程:

(一)、超级终端设置

1、运行Windows 系统下开始→所有程序→附件→通讯→超级终端(HyperTerminal),新建一个通信终端。如果要求输入区号、电话号码等信息请随意输入,出现如图1.5.1 所示对话框时,为所建超级终端取名为arm,可以为其选一个图标。单击“确定”按钮。

2、在接下来的对话框中选择ARM 开发平台实际连接的PC 机串口(如COM1),按确定后出现如图1.5.2 所示的属性对话框,设置通信的格式和协议。这里波特率为115200,数据位8,无奇偶校验,停止位1,无数据流控制。按确定完成设置。

3、完成新建超级终端的设置以后,可以选择超级终端文件菜单中的另存为,把设置好的超级终端保存在桌面上,以备后用。用串口线将PC 机串口和平台UART0 正确连接后,就可以在超级终端上看到程序输出的信息了。

(二)、串口下载烧写

在 Windows xp平台下通过超级终端烧写vivi(bootloader)、内核(Kernel)、根文件系

统(root)的步骤如下:

1、格式化flash 打开超级终端,先按住PC 机键盘的Back Space 键,然后启动2410-S,进入vivi,按照以下命令格式化flash,重新分区。

vivi>bon part 0 128k 192k 1216k 4288k:m 64704k 回车

2、烧写vivi 这时已格式化flash,运行的是SDRAM 中的vivi.vivi>load flash vivi x 回车 此时超级终端提示:

Ready for downloading using xmodem...Waiting...点击超级终端任务栏上“传送”下拉菜单中的“发送文件”,选择协议为Xmodem,选择

镜像文件vivi,点击“发送”,10 秒左右vivi 就烧写到flash 里了.这时要复位2410-S,重新进入vivi>来烧写kernel,root.3、烧写内核映象zImage vivi>load flash kernel x 回车 出现提示:

Ready for downloading using xmodem...Waiting...点击超级终端任务栏上“传送”下拉菜单中的“发送文件”,选择镜像文件zImage,协议

为Xmodem,点击“发送”,4 分钟左右zImage 传输完毕,zImage先传输到SDRAM中,再把数据从SDRAM 复制到flash 里,请等待这一过程结束到出现vivi>,再烧写root,否则会导致烧写kernel 失败。

4、烧写根文件系统(root)vivi>load flash root x 回车

Ready for downloading using xmodem...Waiting...点击超级终端任务栏上“传送”下拉菜单中的“发送文件”,选择镜像文件root.cramfs,协议为Xmodem,点击“发送”,8 分钟左右root.cramfs 烧写完毕;

5、烧写应用程序

用2410-S 实验箱配套网线连接好2410-S 的NIC-1 网口和PC 机的网口,重启2410-S 进

入linux 操作系统的[/mnt/yaffs]下,注意配置IP 在同一网段,执行以下指令: [/mnt/yaffs]ifconfig --查看IP [/mnt/yaffs]ifconfig eth0 192.168.0.111 --配置eth0 IP [/mnt/yaffs]inetd --启动ftp

打开ftp 软件FlashFXP(在光盘中/img/flashvivi 目录中提供),点击界面中上部黄色闪

电符号,建立快速连接,输入地址192.168.0.111,用户名:root,密码:无。连接进入ftp 服务,上传“yaffs.tar.bz2”到2410-S 的/var 文件夹下,3 分钟左右上传完毕。

这时不能重启2410-S,否则上传过程白费。接下来在超级终端中输入: [/mnt/yaffs]cd..--转换到/mnt 下 [/mnt]rm-rf /yaffs/* --删除/yaffs 下文件 [/mnt]cd /var --转到var 目录下

[/var]tar xjvf yaffs.tar.bz2 –C /mnt/yaffs --解压yaffs.tar.bz2 到mnt/yaffs 目录下

如图1.5.9 所示,注意大小写(C 为大写),需5 分钟左右

解压缩结束,整个烧写实验就完成了。

五、实验心得

了解了Linux内核与root的知识,能够利用串口通讯下载方式完成它们的烧写过程。实验四 嵌入式软件设计与交叉编译

一、实验目的

1.掌握嵌入式Linux软件设计方法原理 2.掌握Makefile文件设计方法。

3.熟悉Linux下静态库和共享库的设计。

二、实验内容

(1)编写一个带输入、输出的由5个文件组成的嵌入式软件;(2)写好makefile文件,并上机调试;(3)用变量指明两种编译器。

三、实验设备及工具

硬件:UP-NETARM2410-S嵌入式实验仪、PC机pentumn500以上、硬盘40G以上、内存大于256M。

软件:PC机操作系统REDHAT LINUX 9.0、MINICOM、AMRLINUX开发环境.四、程序分析

input.h: #define N 10 void input(char *s);

input.c:

#include #include Void input(char *s){ Printf(“input your name please:”);Scanf(“%s”, s);} output.h #define M 5 Void output(char *s)output.c #include #include Void output(char *s){ Printf(“hello %s!n”, s);} main.c #include #include #include “input.h” #include “output.h” int main(){ int i = 0;char name[N];input(name);for(i=0;i

CC=armv4l-unknown-linux-gcc EXEC=zc OBJS=main.o input.o output.o $(EXEC):$(OBJS)$(CC)-o $(EXEC)$(OBJS)install: $(EXP_INSTALL)$(EXEC)$(INSTALL_DIR)clean:-rm-f $(EXEC)&.o

五、实验结果

pc机上执行时 # make //若已执行过,则用# make clean 清除后再执行# make #./zc 结果:

[/mnt/yaffs]cd /host/exp/basic/zc/ [/host/exp/basic/zc]./zc input your name,please:zc hello zc!hello zc!hello zc!hello zc!hello zc!

六、实验心得

初步了解了交叉编译原理,GUN开发套件包括一系列开发测试工具,主要组件为Gcc。实验详细说明了基于ARM和Linux的嵌入式系统的交叉编译环境的建立方法,并给出了具体的步骤。实验结果表明,可以在x86平台编译调试ARM平台上运行的程序。并通过实验认识嵌入式系统上C语言编程与普通PC机上C语言编程的不同点,掌握使用交叉编译环境编译嵌入式系统程序的方法。实验五

嵌入式驱动程序设计

一、实验目的

1.学习在LINUX下进行驱动设计的原理。

2.掌握使用模块方式进行驱动开发调试的过程。

二、实验内容

在PC 机上编写简单的虚拟硬件驱动程序并进调试,实验驱动的各个接口函数的实现,分析并理解驱动与应用程序的交互过程。

三、实验设备及工具

硬件:UP-NETARM2410-S嵌入式实验仪、PC机pentumn500以上、硬盘40G以上、内存大于256M。

软件:PC机操作系统REDHAT LINUX 9.0、MINICOM、AMRLINUX开发环境

四、实验步骤

1、在PC(宿主机)上编译调试驱动程序。(1)阅读和理解源代码

进入/arm2410cl/exp/drivers/01_demo,使用vi 编辑器或其他编辑器阅读理解源代码。

(2)编译驱动模块及测试程序

上面介绍了在Makefile 中有两种编译方法,可以在本机上使用gcc 也可以使用交叉编 • 确定

• # KERNELDIR = /arm2410cl/kernel/linux-2.4.18-2410cl • KERNELDIR = /usr/src/linux(3)测试驱动程序

如果使用gcc 编译的话,需要通过下面的命令来建立设备节点,如果使用交叉编译器的话,不需要建立设备节点。#mknod /dev/demo c 254 0 首先要插入驱动模块demo.o,然后可以用lsmod 命令来查看模块是否已经被插入,在不使用该模块的时候还可以用rmmod 命令来将模块卸载。• insmod demo.o • lsmod demo.o •./test_demo

2、使用arm编译器在实验箱调试驱动程序。

五、实验结果分析

1.编译demo.c 为demo.o;编译test_demo.c 为test_demo。

gcc-c demo.c gcc-o test_demo test_demo.c 2.若编译器选择的是gcc(请查看Makefile文件),需要用以下命令建立节点:

#mknod /dev/demo c 254 0 若编译器选择的是armv4l-unknown-linux-gcc 则不需要mknod命令建立节 点。

3.使用insmod demo.o插入模块,使用lsmod 列出所有插入的模块。查看demo的插入情况: #insmod demo.o 6.运行test程序测试驱动的各个接口运行情况。

#./test_demo 结果:

PC机上的运行结果: 实验箱上的运行结果:

7.运行ad程序测试驱动的各个接口运行情况

六、实验心得

掌握了在Linux下常用编译器的使用,进一步掌握了Makefile的编写和使用以及Linux下的程序编译与交叉编译的过程。实验六

触摸屏驱动程序设计

一、实验目的

1、了解在 UP-TECH S2410/P270 DVP平台上实现触摸屏Linux 驱动程序的基本原理。

2、了解 Linux 驱动开发的基本过程。

二、实验内容

以一个简单字符设备驱动程序为原型,剖析其基本结构。进行部分改写之后并编译实现其相应功能。

三、预备知识

1、掌握在 Linux 集成开发环境中编写和调试程序的基本过程。

2、了解 ARM 芯片(本实验是针对ARMS3C2410 系列)的基本结构。

3、了解 Linux 内核中关于设备控制的基本原理。

四、实验设备及工具

硬件:UP-NETARM2410-S嵌入式实验仪,PC机pentumn500以上, 硬盘40G以上,内存大于128M。软件::PC 机操作系统REDHAT LINUX 9.0 +超级终端(或X-shell)+ AMRLINUX 开发环境

五、实验原理

1、Linux 设备驱动概述

Linux 设备驱动程序属于Linux 内核的一部分,并在Linux 内核中扮演着十分重要的角色。它们像一个个“黑盒子”使某个特定的硬件响应一个定义良好的内部编程接口,同时完全隐蔽了设备的工作细节。用户通过一组标准化的调用来完成相关操作,这些标准化的调用是和具体设备驱动无关的,而驱动程序的任务就是把这些调用映射到具体设备对于实际硬件的特定操作上。

我们可以把设备驱动作为内核的一部分,直接编译到内核中,即静态编译,也可以单独作为一个模块(module)编译,在需要它的时候再动态的把它插入到内核中。在不需要时也可把它从内核中删除,即动态连接。显然动态连接比静态连接有更多的好处,但在嵌入式开发领域往往要求进行静态连接,尤其是像S3C44B0 这种不带MMU 的芯片。但在S3C2410等带MMU 的ARM 芯片中我们依然可以使用动态连接。目前Linux 支持的设备驱动可分为三种:字符设备(character device),块设备(blockdevice),网络接口设备(network interface)。当然它们之间的也并不是要严格的加以区分。

2、Linux 关于字符设备的管理

驱动程序在 Linux 内核中往往是以模块形式出现的。与应用程序的执行过程不同,模块通常只是预先向内核注册自己,当内核需要时响应请求。模块中包含两个重要的函数:init_module 和cleanup_module。前者是模块的入口,它为模块调用做好准备工作,而后者则是在模块即将卸载时被调用,做一些清扫工作。

驱动程序模块通过函数: int register_chrdev(unsigned int major, const char *name, struct file_operations *fops);来完成向内核注册的。其中unsigned int major 为主设备号,const char *name 为设备名,至于结构指针struct file_operations *fops 它在驱动程序中十分重要。

在我们编写好一个驱动程序模块后,按传统的主次设备号的方法来进行设备管理,则我们应手工为该模块建立一个设备节点。命令: mknod /dev/ts c 254 0

其中/dev/ts 表示我们的设备名是ts,“C”说明它是字符设备,“254”是主设备号,“0”是次设备号。一旦通过mknod 创建了设备文件,它就一直保留下来,除非我们手工删除它。

3、触摸屏的控制

本系统触摸屏的控制是使用的 S3c2410 处理器自带的触摸屏控制器,这部分的开发主要参考S3c2410 处理器的芯片手册的第416 页到第419 页,具体详见流程图。这部分的控制主要是设置触摸屏的采样模式,处理器提供的模式: 1.正常的转换模式

2.手动的x/y 位置转换模式 3.自动的x/y 位置转换模式

我们这里使用的是第3 种转换模式。需要注意的是在完成一次x/y 坐标采样的过程中需要一次模式转换即在点击触摸屏之前是等待中断模式,当有触摸动作产生触摸屏中断以后,在x/y 的坐标采集驱动中设置成自动的x/y 位置转换模式,在完成采集以后再转换回等待中断。ADC控制寄存器 ADC触摸屏控制寄存器

注意:在自动模式,ADC触摸屏控制寄存器要在开始读之前重新配置ADC开始延迟寄存器

ADC转换数据寄存器(ADCDAT1)

4.触摸屏相关电路图

六、实验步骤

1、改写该驱动程序,在其基础上实现一些你想要的简单功能。由于驱动程序的复杂性,不容易上手且又容易出问题,所以建议你先只对其中的调试信息做一些改动,在运行该驱动程序时看看其在屏幕上的打印信息。在你对整个过程及相关硬件有较多的一些了解之后再动手做一些功能上的调整。

2、结合 ARM-Linux 的移植实验中的相关内容,把改动的驱动程序编译进内核,并下载内核验证结果。你只要把该驱动在必要地方修改后(注意修改前的代码一定要做备份)保存代码,回到内核目录,make bzImage 编译内核,然后下载编译好的内核。

进入expbasic4_ad目录,使用vi编辑main.c: #include #include #include #include #include #include

#include #include “s3c2410-adc.h” #define ADC_DEV “/dev/adc/0raw” static int adc_fd =-1;static int init_ADdevice(void){ if((adc_fd=open(ADC_DEV, O_RDWR))<0){ printf(“Error opening %s adc devicen”, ADC_DEV);return-1;} } static int GetADresult(int channel){ int PRESCALE=0XFF;int data=ADC_WRITE(channel, PRESCALE);write(adc_fd, &data, sizeof(data));read(adc_fd, &data, sizeof(data));return data;} static int stop=0;static void* comMonitor(void* data){ getchar();stop=1;return NULL;} int main(void){ int i;float d;pthread_t th_com;void * retval;//set s3c44b0 AD register and start AD if(init_ADdevice()<0)return-1;/* Create the threads */ pthread_create(&th_com, NULL, comMonitor, 0);printf(“nPress Enter key exit!n”);while(stop==0){ for(i=0;i<=2;i++){

//采样0~2 路A/D 值 d=((float)GetADresult(i)*3.3)/1024.0;printf(“a%d=%8.4ft”,i,d);} usleep(1);printf(“r”);} /* Wait until producer and consumer finish.*/ pthread_join(th_com, &retval);printf(“n”);return 0;}

七、实验结果与分析

在PC机终端

[ root @ localhost / ]# cd /arm2410cl/exp/basic/04_ad/ [ root @ localhost 04_ad]# make armv4l-unknown-linux-gcc-c-o main.o main.c armv4l-unknown-linux-gcc-o../bin/ad main.o-lpthread armv4l-unknown-linux-gcc-o ad main.o-lpthread [root@ localhost 04_ad]# ls ad hardware.h main.o Makefile.bak s3c2410-adc.h bin main.c Makefile readme.txt src 把makefile文件中cc=gcc改为cc=arm4vl-unknown-linux-gcc用于机箱上,[ root @ localhost 04_ad]# make clean [ root @ localhost 04_ad]# make 新建终端

[root@ localhost root]# minicom [/mnt/yaffs] mount-t nfs 192.168.0.10:/arm2410cl /host [/mnt/yaffs] cd /host/exp/basic/04_ad/ [/host/exp/basic/04_ad]./ad Press Enter key exit!a0= 0.6316 a1= 2.3880 a2= 1.9594

七、实验心得

通过实验掌握了S3C2410芯片上的8通道110位AD转换器的工作原理;熟悉了各种A/D转换器原理和性能指标;掌握Linux下A/D设备驱动程序设计的基本方法;掌握了Makefile的编写和使用;学习A/D接口原理,了解实现A/D系统对于系统软件和硬件要求。

第五篇:嵌入式系统开发技术题库2

嵌入式系统开发技术题库2

一、选择题

1:下面关于嵌入式系统逻辑组成的叙述中,错误的是()。A:嵌入式系统与通用计算机一样,也由硬件和软件两部分组成

B:硬件的主体是CPU和存储器,它们通过I/O接口和I/O设备与外部世界联系 C:嵌入式系统的CPU主要使用的是数字信号处理器 D:嵌入式系统的软件配置有些很简单,有些比较复杂 2:下面关于数字信号处理器的叙述中错误的是()。A:它是一种适用于数字信号处理的微处理器 B:它的英文缩写是DPS C:它支持单指令多数据(SIMD)并行处理的指令

D:它能显著提高音频、视频等数字信号的数据处理效率

3:片上系统是嵌入式处理器芯片的一个重要品种,下列叙述中错误的是()。A:SoC已经成为嵌入式处理器芯片的主流发展趋势 B:它是集成电路加工工艺进入到深亚微米时代的产物

C:片上系统使用单个芯片进行数据的采集、转换、存储和处理,但不支持I/O功能 D:片上系统既能把数字电路也能把模拟电路集成在单个芯片上

4:按照软硬件技术复杂程度进行分类,可以把嵌入式系统分为哪三大类?()。A:高端系统、中端系统和低端系统 B:军用系统、工业用系统和民用系统 C:硬实时系统、准实时系统和非实时系统 D:片上系统、微控制器和数字信号处理器

5:半导体集成电路是微电子技术的核心。下面有关集成电路的叙述中错误的是()。

A:集成电路有小规模、中规模、大规模、超大规模和极大规模等多种,嵌入式处理器芯片一般属于大规模集成电路

B:集成电路的制造大约需要几百道工序,工艺复杂且技术难度非常高

C:集成电路大多在硅衬底上制作而成,硅衬底是单晶硅锭经切割、研磨和抛光而成的圆形薄片 D:集成电路中的电路及电子元件,需反复交叉使用氧化,光刻,掺杂和互连等工序才能制成 6:一幅1024 x 768的彩色图像,每个像素使用16位表示,采用压缩比为5倍的算法压缩图像数据之后,其数据量大约是多少MB?()。A:0.3 B:0.5 C:1 D:1.5 7:以太网中计算机间以帧为单位进行通信,下列选项中不属于以太网数据帧内容的是()。A:IP地址 B:MAC地址 C:有效载荷 D:校验信息

8:下面是IP协议中A类IP地址有关规定的叙述,其中正确的是()。A:它适用于中型网络

B:它适用的网络最多只能连接65534台主机 C:它不能用于多目的地址发送(组播)D:它的二进制表示中最高位一定是“0” 9:对于嵌入式处理器说法正确的是()。A:ARM处理器采用CISC和RISC相结合的结构 B:嵌入式处理器都采用哈佛结构

C:ARM处理器具有耗电省、功能强、成本低等特点 D:ARM处理器内部的总线标准是PCI Express 10:以下关于ARM处理器的叙述中,错误的是()。A:ARM7~ARM11为经典ARM处理器

B:Cortex-A系列为应用Cortex处理器,主要面向高端应用 C:Cortex-M系列为面向移动计算领域的嵌入式处理器 D:Cortex-R系列应用于实时应用的场合

11:关于ARM的工作状态,以下说法正确的是()。A:ARM处理器的工作状态包括ARM状态和Thumb状态两种 B:ARM状态支持16位指令宽度也支持32位指令宽度

C:Thumb状态或Thumb-2状态下,代码密度低于ARM状态,占用存储空间变大 D:ARM处理器复位后自动进入ARM状态

12:ARM处理器当前运算操所产生的标志位记录在以下哪个寄存器中?()。A:PSP B:MSP C:SPSR D:CPSR 13:ARM处理器如果R1=0x98001200,已知在小端模式下,内存0x98001204中存放数据0x35, 0x98001205中存放数据0x36, 0x98001206中存放数据0x37, 0x98001207中存放数据0x38, 在指令LDR R0,[R1,#4]执行后,R0中的值为()。A:0x35363738 B:0x36353837 C:0x38373635 D:0x37383536 14:ARM处理器将R0中一个字的数据,存入由R1指示的内存区域,则使用的指令是()。A:STR R0,[R1] B:LDR R0,[R1] C:STRH R0,[R1] D:STRB R0,[R1] 15:在以下ARM处理器指令中可让寄存器R1中指定位“清零”的指令操作码为()。A:MOV B:AND C:ADD D:ORR 16:ARM处理器如果R1=0x00000080,则指令MOV R0,R1, LSL#2执行后,R0的值为()。A:0x00000200 B:0x00000320 C:0x00000020 D:0x00000040 17:以下ARM处理器的指令或伪指令错误的是()。A:MOV R1,R2 B:LDR R1,#0x12345678 C:LDR R1,=0x00000020 D:ADC R1,R2,R3 18:ARM处理器在比较指令之后,如果要依据是否相等转移到指定地址L1,则以下指令错误的是()。A:BEQ L1 B:BNE L1 C:BXEQ L1 D:BLAL L1 19:下面是有关嵌入式系统的最小系统组成的叙述: Ⅰ.嵌入式最小系统包括嵌入式处理器 Ⅱ.嵌入式最小系统包括电源电路 Ⅲ.嵌入式最小系统包括时钟电路 Ⅳ.嵌入式最小系统包括复位电路 上述叙述中,正确的是()。A:仅Ⅰ和Ⅲ B:仅Ⅰ和Ⅱ C:仅Ⅱ、Ⅲ和Ⅳ D:全部

20:下面关于JTAG的叙述中,错误的是()。A:JTAG技术是一种嵌入式测试技术

B:大多数ARM嵌入式处理器芯片不包含JTAG接口 C:多个器件可以通过JTAG接口串联在一起进行测试 D:通过芯片的JTAG接口可以实现在线编程功能

21:典型的嵌入式系统硬件由嵌入式最小硬件系统及相关通道或接口组成,若一个嵌入式系统需要完成模拟量输出功能,该功能是由下面列出的嵌入式系统的哪个通道实现的?()。A:前向通道 B:后向通道 C:人机交互通道 D:相互互连通道

22:基于ARM内核的嵌入式处理器芯片采用系统总线与外围总线两层结构的方式构建片上系统,下面列出的组件中,不与系统总线相连的组件是()。A:电源管理与时钟控制器 B:DMA控制接口 C:RTC D:中断控制器

23:下面是基于ARM内核的嵌入式芯片中有关GPIO的叙述,其中错误的是()。A:GPIO作为输入接口时具有缓冲功能 B:GPIO作为输出接口时具有锁存功能 C:GPIO的引脚一般是多功能复用的

D:GPIO一般只具有0态和1态,不具有高阻状态

24:基于ARM内核的嵌入式芯片中包含互连通信组件,下面不属于互连通信组件的是()。A:PWM B:SPI C:I2C D:Ethernet 25:下面是关于嵌入式系统使用的存储器的叙述:

Ⅰ.嵌入式系统使用的存储器按照其存取特性可分为RAM和ROM Ⅱ.嵌入式系统使用的存储器按照其所处物理位置可分为片内存储器和片外存储器以及外部存储器 Ⅲ.嵌入式系统使用的存储器按照存储信息的类型可分为程序存储器和数据存储器 Ⅳ.新型的铁电存储器FRAM在嵌入式系统中得到了应用 上述叙述中,正确的是()。A:仅Ⅰ和Ⅱ B:仅Ⅱ和Ⅲ C:仅Ⅰ和Ⅲ D:全部

26:下面关于I2C的叙述中,错误的是()。A:I2C即集成电路互连总线

B:I2C具有SDA、SCL和ACK共3条信号线

C:I2C传送数据时,每次传送的字节数目没有限制 D:I2C是多主总线

27:下面是关于UART的叙述,其中错误的是:()。

A:ARM芯片中的UART收发信息时,可以采用FIFO模式,也可以采用普通模式 B:UART传送信息的格式以起始位开始,以停止位结束 C:UART传送信息时,一次传送的数据位的长度只能是8位 D:基于UART可组成RS-232接口

28:下面是关于嵌入式系统中使用的键盘的叙述,其中错误的是()。

A:利用嵌入式芯片的GPIO构成线性键盘时,一个按键需要占用一个GPIO引脚 B:采用矩阵键盘结构时,8个GPIO引脚最多能构成12个按键的键盘 C:采用机械式按键设计键盘时,按键按下时会产生抖动 D:矩阵键盘通常用行扫描法或反转法读取按键的特征值

29:uC/OS-II操作系统启动的过程中,Bootloader执行完毕后,调用应用程序主文件(通常是main.c)里的main()函数。main()函数在执行过程中,除了用户函数和硬件初始化函数之外,需要执行以下三个主要的uC/OS-II函数: I.OSStart()II.OSTaskCreate()III.OSInit()它们的执行顺序是()。A:I、II、III B:III、I、II C:II、III、I D:III、II、I 30:uC/OS-II系统中的每个任务都处在以下5种状态之一:休眠态、就绪态、运行态、挂起态(等待某一事件发生)和被中断态,以下哪个说法是错误的()。

A:任务处于休眠态,相当于该任务驻留在外存中,但还没有交给内核管理

B:任务处于就绪态,意味着该任务已经准备好,可以运行了,但由于该任务的优先级比正在运行的任务的优先级低,还暂时不能运行

C:任务处于运行态,指任务得到了CPU的控制权正在运行之中

D:任务处于被中断态,是指发生中断时执行相应的中断服务,原来正在运行的任务暂时停止运行,进入了被中断状态

31:uC/OS-II总是运行处于就绪态任务中优先级最高的那个任务,以下哪个说法是错误的()。A:真正实现任务切换的函数是OSCtxSw()B:任务级的调度是由函数OSSched()完成 C:中断级的调度是由函数OSIntExit()完成 D:实现上下文切换的函数是OSSched()32:uC/OS-II允许中断嵌套,嵌套层数可达多少层?()。A:32 B:26 C:128 D:255 33:uC/OS-II能够提供周期性时钟信号(即所谓的时钟节拍),用于实现任务的正确延时和超时确认。节拍率应在什么范围内?()。A:10 Hz~100Hz B:10Hz~1000Hz C:100 Hz~1000Hz D:100 Hz~10000Hz 34:uC/OS-II的事件控制块有4种类型,需要使用4个不同的函数来创建。如下选项中哪一个用于创建事件控制块?()。A:OSTaskCreate()B:OSThreadCreate()C:OSQCreate()D:OSCtxSw()35:下面关于Linux内核的有关叙述中,错误的是()。

A:进程调度模块负责控制进程对CPU资源的使用,所采取的调度策略是使得各个进程能够平均访问CPU,但并不保证内核能及时地执行硬件操作

B:Linux内存管理模块的功能之一是屏蔽各种硬件内存结构的差异并向上返回统一的访问接口 C:网络接口模块包含网络接口驱动程序

D:支持进程之间各种通信机制,其通信机制主要包括信号、管道、消息队列、信号量、共享内存和套接字

36:关于U-Boot,以下说法错误的是()。

A:U-Boot全称USB Bootloader,通过USB接口完成启动支持多种处理器和操作系统 B:U-Boot支持PowerPC、x86、ARM等多种体系结构的处理器

C:U-Boot支持嵌入式Linux、VxWorks、QNX、RTEMS、Windows CE等操作系统 D:U-Boot采用两个阶段完成操作系统的引导加载

37:关于微内核和宏内核操作系统,如下哪一项的说法是错误的?()。A:VxWorks是典型的微内核结构嵌入式操作系统

B:iOS追根溯源是一个类UNIX操作系统,它属于宏内核架构 C:Android OS是典型的宏内核操作系统

D:一般认为微内核系统的实时性较好,故Symbian归类为强实时嵌入式操作系统 38:以下关于VxWorks操作系统的叙述中,错误的是()。

A:是目前公认为实时性很强、可靠性很高的一种嵌入式实时操作系统 B:在航空航天、通信和国防领域具有广泛的应用

C:属于大型商用操作系统,具有配套的VMWare集成开发环境,为开发者带 来很大方便

D:支持基于抢占式优先级调度的任务管理

39:嵌入式系统开发时,应该根据应用需求来选择相应的开发工具软件。RVDS是一个较常用的开发工具软件,下面的有关叙述中错误的是()。

A:RVDS中包括工程管理器、编译连接器、调试器和指令集仿真器 B:RVDS只支持ARM内核的微处理器芯片 C:RVDS支持对Flash存储器的编程

D:RVDS编译的代码比ADS1.2编译的代码执行效率高

40:若基于Linux操作系统所开发的ARM应用程序源文件名为test.c,那么要生成该程序代码的调试信息,编译时使用的GCC命令正确的是()。A:arm-linux-gcc-c-o test.o test.c B:arm-linux-gcc-S-o test.o test.c C:arm-linux-gcc-o test test.c D:arm-linux-gcc-g-o test test.c

二、填空题

1:SoC芯片中的CPU绝大多数是以IP核的方式集成在芯片中的,很少再自行设计开发。目前32位嵌入式处理器主要采用的是由____【1】____国一家专门从事RISC处理器内核设计公司设计的____【2】______内核。

2:我国大陆地区目前广泛使用的汉字编码国家标准有____【3】______和GB18030两种,常用汉字采用___【4】____个字节表示。3:在Internet中负责选择合适的路由,使发送的数据分组(packet)能够正确无误地按照地址找到目的计算机所使用的是___【5】____协议簇中的___【6】____协议。

4:ARM处理器有7种异常,按向量地址从小到大排列的顺序是:__【7】_____、未定义指令UND、软件中断SWI、指令预取中止PABT、数据访问中止DABT、__【8】_____以及快速中断FIQ。

5:在ARM处理器中,R0~R15是通用寄存器,其中作为堆栈指针SP使用的寄存器是___【9】____,作为程序链接寄存器LR使用的是___【10】____。

6:已知ARM处理器的R1=0x12345678, R2=0xFF00FF00,则执行指令ORR R0,R1,R2后,寄存器R0=___【11】____,R1=___【12】____。

7:已知ARM处理器进位标志C=1, R1=1000, R2=99, 执行指令ADDC R0,R1,R2之后,R0=___【13】____, R1=___【14】____。

8:ARM处理器用一条指令完成有条件的无符号数加法运算,并更新CPSR中的状态,条件是如果相等, 要求指令执行R1+R2,结果送R3中,则这条指令为___【15】____;如果条件是大于,要求指令执行R1-R2,结果放R3中,则该指令为___【16】___。

9:为了连接ARM内核与处理器芯片中的其他各种组件,ARM公司定义了总线规范,该规范用4个大写英文字母表示为___【17】____,即先进的微控制器___【18】____体系结构。

10:ARM处理器芯片内部的___【19】____组件包括ADC和DAC,有的还带有比较器等。这对于既需要处理____【20】___信号又需要处理模拟信号的混合系统的设计提供了较好的解决方案。

11:目前有两种主要的闪存技术,一种是___【21】____Flash,其特点是以字节为单位随机存取,另一种是___【22】____Flash,以页(行)为单位随机存取。(填写用英文大写字母表示的简称)12:如存储器的工作频率为333MHz,数据线宽度为32位,每个周期传输1次数据,则存储器的带宽=___【23】____MB/s。若存储器总线采用串行总线,以10位为一个数据帧(包含一个字节的存储数据),则总线带宽=总线频率/___【24】____。

13:SPI的信号线MISO称为____【25】___数据线, MOSI称为___【26】____数据线。14:响应时间(Response Time)是计算机从识别一个外部事件到做出响应的时间。在RTOS运行过程中响应时间是重要指标之一,其具体指标包括:___【27】____延迟时间和___【28】____切换时间。15:uC/OS-II 是目前常用的嵌入式操作系统之一,其内核只提供____【29】___调度、任务间通信与同步、任务管理、时间管理和___【30】____管理等基本功能,资源消耗非常小。

16:具有操作系统的嵌入式系统加电后最初执行的操作称为引导或者自举(Boot),对应的程序称为引导程序,或者引导加载程序(Bootloader)。引导加载程序主要完成___【31】____、外设存在自检、内存地址映射、初始化外围设备、内存寻址定位、加载并启动___【32】____。17:由于Bootloader的实现依赖于CPU的体系结构,因此大多数Bootloader都分为stage1和stage2两大部分。依赖于CPU体系结构的代码,比如设备初始化代码等,通常都放在stage1中,且使用___【33】____语言来实现,以达到短小精悍的目的。而stage2则通常用C语言来实现,这样可以实现更复杂的功能,而且代码会具有更好的可读性和___【34】____性。18:RTLinux基本的设计理念就是“架空”Linux内核,以便让其他实时进程能尽快地被执行。RTLinux开发者并没有针对实时操作系统的特性而重写Linux的内核,而是将Linux的内核代码做一些修改,将Linux的任务以及Linux内核本身作为一个___【35】____优先级的任务,而实时任务作为最___【36】____优先级的任务。

19:嵌入式系统开发时,由于受到目标机资源的限制,需要建立一个___【37】____与目标机组成的调试架构来完成开发工作。若目标机为裸机环境时,通常需要通过___【38】____接口来完成硬件环境测试及初始软件的调试和下载。

20:基于嵌入式WEB的应用系统中,构件设计阶段需要设计支持以太网通信的电路,包括以太网控制电路及以太网____【39】___电路。若选用的以太网控制芯片为AX88796芯片,并用S3C2410芯片的nGCS2引脚连接到AX88796芯片的片选引脚上(即CS引脚上,CS低电平有效),那么,AX88796芯片内部寄存器的读/写地址,其首地址是___【40】____。

三、综合题

2:

1、某机械设备的控制器,其基本功能要求有: 需要有8个数字量输入,用于采集设备的状态信息;且需要8个数字量输出,用于控制设备动作。具备一个RS-232接口,可以和上位机连接,接收上位机发送的命令及参数。需要提供一个基准定时信号,定时时间间隔为0.01秒。需要彩色LCD显示器,用于显示状态信息等。根据上述功能要求的描述,若采用S3C2410芯片为核心来构建该机械设备控制器的硬件平台,请完善下面的叙述和C语言程序(需要使用的控制寄存器的格式见题后说明)。

(1)若硬件设计时采用GPIO端口E的GPE0~GPE7引脚作为8个数字量输出,那么软件设计时其初始化语句是:rGPECON=(rGPECON|0x00005555)&___【1】____。若软件设计时需要通过GPE5引脚输出“1”来驱动执行机构动作,那么语句是:rGPEDAT= rGPEDAT | ___【2】____。(注:rGPECON是端口E的控制寄存器所对应的变量,rGPEDAT是端口E的数据寄存器所对应的变量)

(2)硬件设计时,选用UART0来完成RS-232接口电路设计。在软件设计时,其初始化程序中波特率设置为9600bps,数据格式设置为:8位数据位、奇校验、1位停止位。请补充完善下面的UART0初始化函数(注:主频参数为PCLK): void UART0_Init(){ rGPHCON=(rGPHCON&0xFFFFFF00)|___【3】____;//端口H相应引脚功能初始化 rUFCON0=0x0;//FIFO不使能 rUMCON0=0x0;rULCON0=___【4】____;//设置线路控制寄存器 rUCON0= 0x145;//设置控制寄存器

rUBRDIV0=((int)(PCLK/___【5】____)1);//设置波特率,小数采用四舍五入 }(3)按照上面UART0初始化函数所设置的通信速率,每秒钟最多能传输___【6】____个字节的信息。若上位机有大小为4KB的初始参数需要下载到控制器中,那么,约需传输____【7】___秒才能完成下载(1K=1024,精确到小数点后面1位数字)。

(4)系统中所需要的0.01秒基准定时时间选用S3C2410芯片内部的Timer0部件来产生。若系统的主频参数PCLK为264MHz,分频器值选择为16,预分频系数选择为3,那么,Timer0的计数常数为___【8】____。软件设计时,设计了如下的Timer0初始化函数,请补充完善。(注:下面程序中⑨、⑩、⑿用8位十六进制数表示,⑾用4位十六进制数表示)void Timer0Int(void){ //设置定时器配置寄存器0(TCFG0)

rTCFG0=___【9】____;//Timer0预分频系数选择为3,该寄存器中其它无关位均为0 //设置定时器配置寄存器1(TCFG1)

rTCFG1=___【10】___;// Timer0分频器值为16,该寄存器中其它无关位均为0 //设置计数常数

rTCNTB0=___【11】____;//设置控制寄存器TCON rTCON=___【12】____;//更新TCNTB0和TCMPB0,该寄存器中其它无关位均为0 rTCON=0x00000009;//设置Timer0自动装载,并启动 }(5)彩色LCD显示屏的硬件接口电路由S3C2410的专用GPIO端口__【13】_____和端口___【14】____相关引脚配以驱动电路来设计。软件设计时,需要通过设置它们控制寄存器的值分别为___【15】____和____【16】___来确定它们的引脚功能。

(6)系统的软件可以设计为在无操作系统的环境下运行。设计者自行设计系统的启动引导程序,在该程序中完成异常向量设置、堆栈指针设置以及必要的硬件初始化。ARM9体系结构中规定的IRQ异常所对应的异常向量地址为___【17】____。Timer0部件所产生的0.01秒基准时间到时将引起IRQ异常。由于IRQ异常向量地址与下一个异常向量地址之间间隔为___【18】____个字节,因此,通常在IRQ异常向量地址处设计一条转移指令。堆栈指针的设置需按工作模式来进行。设置IRQ模式下的堆栈指针,需在R0“清0”后用指令ORRR1,R0,#0x12|___【19】____和MSR CPSR_CXSF,R1来使CPU核进入IRQ模式,然后再给SP寄存器赋值作为该模式下的堆栈指针。这些初始化工作完成后,即可通过指令___【20】____来引导应用程序的主函数main()。说明:下面是试题解答时需要用到的寄存器格式及相关说明。1)端口C的控制寄存器(GPCCON)引脚GPCCON的位描述

GPC15[31:30]00=输入,01=输出,10=VD7,11=保留 GPC14[29:28]00=输入,01=输出,10= VD6,11=保留 GPC13[27:26]00=输入,01=输出,10= VD5,11=保留 GPC12[25:24]00=输入,01=输出,10= VD4,11=保留 GPC11[23:22]00=输入,01=输出,10= VD3,11=保留 GPC10[21:20]00=输入,01=输出,10= VD2,11=保留 GPC9[19:18]00=输入,01=输出,10= VD1,11=保留 GPC8[17:16]00=输入,01=输出,10= VD0,11=保留 GPC7[15:14]00=输入,01=输出,10=LCDVF2,11=保留 GPC6[13:12]00=输入,01=输出,10= LCDVF1,11=保留 GPC5[11:10]00=输入,01=输出,10=LCDVF0,11=保留 GPC4[9:8]00=输入,01=输出,10=VM,11=IIS数据输出

GPC3[7:6]00=输入,01=输出,10=VFRAME,11= IIS数据输入 GPC2[5:4]00=输入,01=输出,10=VLINE,11=保留 GPC1[3:2]00=输入,01=输出,10=VCLK,11=保留 GPC0[1:0]00=输入,01=输出,10=LEND,11=保留 2)端口D的控制寄存器(GPDCON)引脚GPDCON的位描述

GPD15[31:30]00=输入,01=输出,10=VD23,11=保留 GPD14[29:28]00=输入,01=输出,10= VD22,11=保留 GPD13[27:26]00=输入,01=输出,10= VD21,11=保留 GPD12[25:24]00=输入,01=输出,10= VD20,11=保留 GPD11[23:22]00=输入,01=输出,10= VD19,11=保留 GPD10[21:20]00=输入,01=输出,10= VD18,11=保留 GPD9[19:18]00=输入,01=输出,10= VD17,11=保留 GPD8[17:16]00=输入,01=输出,10= VD16,11=保留 GPD7[15:14]00=输入,01=输出,10= VD15,11=保留 GPD6[13:12]00=输入,01=输出,10= VD14,11=保留 GPD5[11:10]00=输入,01=输出,10= VD13,11=保留 GPD4[9:8]00=输入,01=输出,10= VD12,11=保留 GPD3[7:6]00=输入,01=输出,10= VD11,11=保留 GPD2[5:4]00=输入,01=输出,10= VD10,11=保留 GPD1[3:2]00=输入,01=输出,10= VD9,11=保留 GPD0[1:0]00=输入,01=输出,10= VD8,11=保留 3)端口E的控制寄存器(GPECON)引脚GPECON的位描述

GPE15[31:30]00=输入,01=输出,10=IICSDA,11=保留 GPE14[29:28]00=输入,01=输出,10=IICSCL,11=保留 GPE13[27:26]00=输入,01=输出,10=SPICLK0,11=保留 GPE12[25:24]00=输入,01=输出,10=SPIMOSI0,11=保留 GPE11[23:22]00=输入,01=输出,10=SPIMISO0,11=保留 GPE10[21:20]00=输入,01=输出,10=SSDAT3,11=保留 GPE9[19:18]00=输入,01=输出,10=SSDAT2,11=保留 GPE8[17:16]00=输入,01=输出,10=SSDAT1,11=保留 GPE7[15:14]00=输入,01=输出,10=SSDAT0,11=保留 GPE6[13:12]00=输入,01=输出,10=SDCMD,11=保留 GPE5[11:10]00=输入,01=输出,10=SDLCK,11=保留

GPE4[9:8]00=输入,01=输出,10=IISSDO,11=IIS数据输出 GPE3[7:6]00=输入,01=输出,10=IISSI,11= IIS数据输入 GPE2[5:4]00=输入,01=输出,10=CDCLK,11=保留 GPE1[3:2]00=输入,01=输出,10=IISCLK,11=保留 GPE0[1:0]00=输入,01=输出,10=IISLRCK,11=保留 4)端口H的控制寄存器(GPHCON)引脚GPHCON的位描述

GPH10[21:20]00=输入,01=输出,10=CLKOUT1,11=保留 GPH9[19:18]00=输入,01=输出,10= CLKOUT0,11=保留 GPH8[17:16]00=输入,01=输出,10=UEXTCLK,11=保留 GPH7[15:14]00=输入,01=输出,10=RXD2,11=保留 GPH6[13:12]00=输入,01=输出,10=TXD2,11=保留 GPH5[11:10]00=输入,01=输出,10=RXD1,11=保留

GPH4[9:8]00=输入,01=输出,10=TXD1,11=IIS数据输出 GPH3[7:6]00=输入,01=输出,10=RXD0,11= IIS数据输入 GPH2[5:4]00=输入,01=输出,10=TXD0,11=保留 GPH1[3:2]00=输入,01=输出,10=nRTS0,11=保留 GPH0[1:0]00=输入,01=输出,10=nCTS0,11=保留 5)UART线路控制寄存器(ULCONn n可以是0、1、2)ULCONn的位[7][6][5:3][2][1]描述保留 值为0确定红外模式 0=正常操作模式

1=正常操作模式确定校验类型 0xx=无校验 100=奇校验

101=偶校验确定停止位数 0=1位停止位

1=2位停止位确定数据位 00=5位01=6位

10=7位11=8位6)TCFG0寄存器 TCFG0的位功能描述初始状态值

[31:24]保留0x00[23:16]在此不用0x00 [15:8]确定Timer2,Timer3,Timer4的预分频系数0x00[7:0]确定 Timer0,Timer1的预分频系数0x007)TCFG1寄存器 TCFG1的位功能描述初始状态值[31:24]保留0x00 [23:20]在此不用0b0000 [19:16]确定Timer4的分频器值0000=2 0001=4 0010=8 0011=16 [15:12]确定Timer3的分频器值0000=2 0001=4 0010=8 0011=16 [11:8]确定Timer2的分频器值0000=2 0001=4 0010=8 0011=16 [7:4]确定Timer1的分频器值0000=2 0001=4 0010=8 0011=16 [3:0]确定Timer0的分频器值0000=2 0001=4 0010=8 0011=16 说明:设置TCFG0、TCFG1可以确定预分频器系数、分频器值,如:通过设置TCFG0为0x0000001F,Timer0的预分频器系数选择为31,设置TCFG1为0x00000001,Timer0的分频器值选择为4。通过下面公式计算定时器的计数常数:

定时器输入时钟频率=PCLK/(预分频系数+1)/分频器值 计数常数=定时时间间隔/(1/定时器输入时钟频率)预分频系数的范围为0~255,分频器值的取值范围为2、4、8、16。6)TCON寄存器(注:此处不用的位被省略,其值默认为0x0000000)

TCON的位功能描述初始状态值厖0x0000000[3]确定Timer0的自动装载功能 1=自动装载0=一次停止0b0[2]确定Timer0的输出反转位 1=TOUT0反转0=TOUT0不反转0b0[1]确定Timer0的更新

1=更新TCNTB0和TCMPB0 0=不更新0b0[0]确定Timer0的启动/停止 1=启动0=停止0b0

第套2参考答案

一、选择题答案

1-5:CBCAA 6-10:AADCC 21-25:BCDAD 26-30:BCBDA

11-15:DDCAB 16-20:ABDDB 31-35:DDACA 36-40:ADCBD

二、填空题答案

1:英 2:ARM 3:GB2312 4:2 5:TCP/IP 6:IP 7:复位

8:外部中断请求 9:R13 10:R14

三、综合题答案 11:0xFF34FF78 12:0x12345678 13:1100 14:1000 15:ADDCEQ R3,R1,R2 16:SUBHIS R3,R1,R2 17:AMBA 18:总线 19:模拟 20:数字

21:NOR 22:NAND 23:1332 24:10

25:主机输入从机输出26:主机输出从机输入27:中断 28:任务 29:任务 30:存储

31:加电自检 32:操作系统 33:汇编 34:可移植 35:低 36:高 37:宿主机 38:JTAG 39:驱动

40:0x10000000

1:0xFFFF5555 2:0x0020 3:0x000000AA 4:0x23 5:(9600×16)+ 0.5 6:872 7:4.7 8:41250 9:0x00000003 10:0x00000003 11:0xA122 12:0x00000002 13:C 14:D 15:0xAAAAAAAA 16:0xAAAAAAAA 17:0x00000018 18:4 19:0xC0 20:BL_main

下载嵌入式系统开发总结(uCCOS+uCGUI+uCFS)word格式文档
下载嵌入式系统开发总结(uCCOS+uCGUI+uCFS).doc
将本文档下载到自己电脑,方便修改和收藏,请勿使用迅雷等下载。
点此处下载文档

文档为doc格式


声明:本文内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:645879355@qq.com 进行举报,并提供相关证据,工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。

相关范文推荐

    嵌入式LINUX系统开发入门学习步骤和技能总结

    嵌入式LINUX系统开发入门学习步骤和技能总结对于很多学习嵌入式LINUX系统开发的人来说,经验和技巧是很重要的,要不然就会落得一个事倍功半的效果。对于一个初学者或是一个零基......

    系统开发总结

    课程综合论文系统开发总结经过了两个月紧张而有序的系统开发,收获颇丰,感触颇深。现下分经验收获、教训反思、下步设想三大部分总结如下: 一、经验收获 1.编写程序前,对已完成设计......

    基于ARM的嵌入式设备中uCLinux系统开发.

    基于ARM的嵌入式设备中uCLinux系统开发 1引言信息家电和手持设备大大加速了嵌入式系统的发展,而ARM体系32位高性能、低功耗处理器和嵌入式操作系统Linux无疑成为佼佼者。因为......

    系统开发总结5篇

    宿舍管理信息系统 系统管理 指导老师(李政忙老师) 开发团队成员: 姓名: 杨正明姓名: 胡友文姓名: 赵 坤姓名: 卓仁慧姓名: 肖远林姓名: 李茂良姓名: 宋 洁总结书写人:宋学号:学......

    数据库系统开发总结

    数据库系统开发课程指导思想: 1. 掌握SQL的基本语法,重视SQL语言的基本编程 2. 针对数据库应用项目编程,从总体功能出发进行系统功能设计和数据库设计,在设计的 基础上,灵活编程......

    嵌入式Linux操作系统开发流程及服务器配置概念

    嵌入式Linux操作系统开发流程及服务器配置概念1、建立开发环境。GCC(GNU C Compiler,GNU的C语言编译器)是一套由GNU工程开发的支持多种编程语言的编译器。GCC是大多数类Unix操......

    嵌入式总结

    一、嵌入式系统原理与应用课程总结 这个学期我学习了《嵌入式原理与应用》这门课程,虽然这个学期马上就要结束了,对嵌入式的学习也要告一段落了,但是我觉得收获还是很大的。学......

    嵌入式实验总结

    如今,嵌入式系统已经在众多电气电子产品上应用,有人预测今后5年发展形势看好。嵌入式是典型的交叉学科,电信、电子、电气、计算机、通信等等都有涉及。 嵌入式理论、实践要求多......