嵌入式系统实验报告

嵌入式系统实验报告
嵌入式系统实验报告

实验一系统认识实验

一、实验目的

学习Dais软件的操作,熟悉程序编写的操作步骤及调试方法。

二、实验设备

PC计算机一台,Dais-52PRO+或Dais-PRO163C实验系统一套。

三、实验内容

编写程序,将80h~8Fh共16 个数写入单片机内部RAM 的30h~3Fh空间。

四、实验步骤

1.运行Dais软件,进入集成开发环境,软件弹出设置通信端口对话框(如图2-1-1),

请确保实验装置与PC正确连接,并已打开实验装置电源,使其进入在待命状态。

这里选择与实验装置实际相连的通信端口,并单击“确定”。如通信正确则进入Dais

软件主界面,否则弹出“通信出错”的信息框(如图2-1-2),请检查后重试。

图2-1-1设置通信端口对话框图2-1-2通信错误信息框

2.通信成功后,单击菜单栏“设置”→“仿真模式”项打开对话框,选择需要设置型

号、程序/数据空间。这里我们将型号设置为“MCS-51实验系统”,外部数据区

设置为“系统RAM”,用户程序区设置为“片外(EA=0)”,如图2-1-3所示,最

后单击“确定”按钮保存设置。

图2-1-3设置工作方式对话框

3.工作方式设置完毕后,单击菜单栏“文件”→“新建”项或按Ctrl+N组合键(建

议单击工具栏“”按钮)来新建一个文件,软件会出现一个空白的文件编辑窗口。

4.在新窗口中输入程序代码(A51\2_1.ASM):

ORG 0000H

LJMP MAIN

ORG 0100H

MAIN: MOV R1,#30H ;片内RAM首地址

MOV A,#80H ;写入数据初值

MOV R7,#16 ;循环变量

LOOP1: MOV @R1,A ;写数据到片内RAM

INC R1 ;地址增量

INC A ;数据+1

DJNZ R7,LOOP1 ;循环变量-1,不为0继续

SJMP $ ;结束

END

5.单击菜单栏“文件”→“保存”项(建议单击工具栏“”按钮)保存文件。若

是新建的文件尚未命名,系统会弹出文件保存对话框(如图2-1-4),提示用户选择文件保存的路径和文件名,再单击“保存”按钮。

图2-1-4 文件保存对话框

6. 单击菜单栏“编译”→“文件编译、链接、装载”项或按Ctrl+F9组合键(建议单

击工具栏“”按钮),对当前文件进行编译和链接,若程序无语法错误,则开始自动装载,装载完毕提示如图2-1-5所示的信息框。

图2-1-5 编译信息框

7. 当编译无误且下载成功后,即进入调试状态,当前PC 行高亮突出显示,源程序窗

口左侧显示小圆点以标识可执行语句行,如图2-1-6所示。

图2-1-6 进入调试状态的主界面

8. 单击菜单栏“视图”→“存储空间”→“CPU 内部存储区”项打开内存窗口,如

图2-1-7。

文件存放的路径

注意:由于编译器对路径和文件名的要求,请确保路径和文件名均不含中文和空格,不要将文件存放在“桌面”、“我的文档”等路径,并遵循“8.3”命令规则,即前缀长度不超过8字符、后缀长度不超过3字符。

输入新文件名

图2-1-7初始时的CPU内部存储区数据显示

9.单击菜单栏“调试”→“单步运行”项或按F7快捷键(建议单击工具栏“”按

钮),单步运行程序,观察寄存器和内存单元的数据变化;

10.也可单击菜单栏“调试”→“连续运行”项或按F9快捷键(建议单击工具栏“”

按钮),开始全速运行。

11.在全速运行后,须暂停运行以便在待命状态查看运行结果,暂停可单击菜单栏“调

试”→“暂停”项或按Esc快捷键(建议单击工具栏“”按钮)。

12.再观察CPU内部存储区单元,验证程序运行结果(如图2-1-8所示)。

图2-1-8程序运行后的CPU内部存储区数据显示

13.除了用程序修改内存单元,可以在Dais软件直接修改。用鼠标单击某个内存单元

后,按键盘的0~9或A~F,直接写入数据以覆盖该内存单元原有数据。如图2-1-9所示。

图2-1-9修改后的内存单元数据显示

14.除了单步或全速运行,还可以使用断点手段来调试程序。单击菜单栏“调试”→“复

位”项或按Ctrl+F2组合键(建议单击工具栏“”按钮)进行复位,以便重新运行程序。

15.单击源程序编辑窗口左侧的行号即可快速设置断点,断点行为红色高亮显示(如图

2-1-10),若要删除该断点只需再次单击断点行的行号即可清除断点。

图2-1-10设置断点后的源程序窗口

16.设置断点后,单击菜单栏“调试”→“连续运行”项或按F9快捷键(建议单击工

具栏“”按钮),使用全速运行方式,待程序运行到断点行时自动停下(如图2-1-11)。

图2-1-11全速运行后遇断点暂停的源程序窗口

五、操作练习

修改程序,将CPU内部存储区30h~3Fh单元的16个数据复制到40h~4F单元,通过单步、断点等调试手段验证程序功能,查看40h~4Fh单元的数据是否传送正确。

ORG 0000H

LJMP MAIN

ORG 0100H

MAIN: MOV R1,#30H

MOV R0,#40H ;片内RAM首地址

MOV A,#80H ;写入数据初值

MOV R7,#16 ;循环变量

LOOP1: MOV A,@R1

MOV @R0,A

INC R1

INC R0 ;地址增量

DJNZ R7,LOOP1 ;循环变量-1,不为0继续

SJMP $ ;结束

END

六、实验心得

通过第一次的上机实验,我初步接触到了Dais软件,并对其有了一定的熟悉,能顺利完成程序的单步运行,连续运行,设置断点,查看存储器等操作,并掌握了该软件程序编写的操作步骤及调试方法,这对我接下来的实验很有帮助。

实验二数码转换实验

一、实验目的

掌握不同进制数及编码相互转换的程序设计方法,加深对数制转换的理解。

二、实验设备

PC计算机一台,Dais-52PRO+或Dais-PRO163C实验系统一套。

三、实验内容及步骤

1.BCD整数转换为二进制整数

将BCD 码整数0~255存入片内RAM的20h、21h、22h中,然后转换为二进制整数00h~FFh,保存到寄存器R4中。

参考程序(A51\2_2_1.ASM):

ORG 0000H

LJMP MAIN

ORG 0100H

MAIN: MOV R0,#20H ;BCD存放高位地址

MOV R7,#3 ;BCD码0~255,最多3位

CLR A

MOV R4,A

LP1: MOV A,R4

MOV B,#10

MUL AB ;乘10

ADD A,@R0 ;加下一位的值

INC R0 ;指向下一单元

MOV R4,A ;结果存入R4

DJNZ R7,LP1 ;转换未结束则继续

SJMP MAIN ;设置断点,观察实验结果R4中的内容

END

实验步骤:

1)编写程序,经编译、链接无误后装载到实验系统;

2)修改CPU内部存储器20h、21h、22h单元的内容,如:00h,05h,08h;

3)在SJMPMAIN语句行设置断点,然后运行程序;

4)程序遇到断点后暂停,此时查看寄存器R4的内容,应为3Ah;

5)重新修改20h、21h、22h单元的内容,再次运行程序,验证程序的正确性。

2.二进制整数转换为十进制整数

将16位二进制整数存入R3、R4寄存器中,转换为十进制整数,以组合BCD形式存储在CPU内部RAM的20h、21h、22h单元中。

参考程序(A51\2_2_2.ASM ):

ORG 0000H LJMP MAIN ORG 0100H

MAIN: MOV R0,#22H ;转换结果低位地址

MOV A,R0

PUSH ACC ;A 累加器压栈 MOV R7,#3 CLR A

LP1: MOV @R0,A ;结果存储地址清零 DEC R0 DJNZ R7,LP1 POP ACC MOV R0,A MOV R7,#16 LP2: PUSH ACC CLR C

MOV A,R4 ;R4中为二进制数的低位 RLC A MOV R4,A

MOV A,R3 ;R3中为二进制数的高位 RLC A MOV R3,A MOV B,#3

LP3: MOV A,@R0

ADDC A,@R0 ;执行乘2操作 DA A ;十进制调整 MOV @R0,A ;结果保存 DEC R0 DJNZ B,LP3 POP ACC

;A 累加器出栈

MOV R0,A DJNZ R7,LP2 SJMP MAIN ;设置断点观察结果, 可进行下一次转换 END

实验步骤:

1) 编写程序,程序流程图如图2-2-1所示,经编译、链接无误后装载到实验系统; 2) 修改R3、R4寄存器,例如分别为A2h 、FCh ; 3) 在SJMPMAIN 语句行设置断点,然后运行程序;

4) 程序遇到断点后暂停,此时查看CPU 内部存储器20h 的内容,应为:04h 、17h 、

24h ;

5) 反复修改R3、R4寄存器的值,验证程序的正确性。

图2-2-1 程序流程图

四、实验心得

在这次实验中,我通过运行既定程序后对程序经行了分析,掌握了将BCD整数转换为二进制整数和二进制整数转换为十进制整数的程序设计方法,对数制的转换有了一个更深刻的认识,并自己编程实现了二进制数和BCD整数的转换,受益匪浅。

实验三 运算程序设计实验

一、实验目的

了解运算类指令以及运算类程序的设计方法。

二、实验设备

PC 计算机一台,Dais-52PRO+或Dais-PRO163C 实验系统一套。

三、实验内容及步骤

1. 多字节加法程序

多字节十进制加法程序,被加数存放于20h 起始的RAM 空间,加数存放于28h 起始的RAM 空间,将两数相加,结果存放于20h 起始的RAM 空间。

参考程序(A51\2_3_1.ASM ):

ORG 0000H LJMP MAIN

ORG 0100H ;执行程序前先修改R7的值 MAIN: MOV R0,#20H ;被加数起始地址 MOV R1,#28H ;加数起始地址 CLR C

LP1: MOV A,@R0

ADDC A,@R1 ;带进位加法运算 DA A ;十进制调整 MOV @R0,A ;保存运算结果 INC R0 ;指向下一单元 INC R1 DJNZ R7,LP1 CLR A MOV ACC.0,C MOV @R0,A ;最高位有进位时此地址中为1 NOP

;设置断点查看运算结果

SJMP MAIN

;若需继续运算, 改变加数, 被加数及R7

END

实验步骤:

1) 编写程序,程序流程图如图2-3-1所示,经编译、链接无误

后装载到实验系统;

2) 为被加数及加数赋值:修改内存单元20h 为1234h 、28h 为1111h ,寄存器R7为

02h ;

3) 在SJMPMAIN 语句行设置断点,然后运行程序;

4) 程序遇到断点后暂停,此时查看内存单元20h 起始的内容,应为:2345h ; 5) 反复修改被加数、加数及字节数R7的值,验证程序的正确性。

图2-3-1 程序流程图

2. 双字节无符号数乘法

利用单字节乘法指令来扩展成多字节乘法运算,扩展时以字节为单位进行乘法运算。被乘数在R2、R3中,乘数在R4、R5中,乘积保存R0指向的20h~23h 内存单元。运算法则见图2-3-2。

R2

R3×R 5H

R3×R 5L

R3R4R5×

R2×R 5H R2×R 5L R3×R 4H

R3×R 4L

R2×R 4H

R2×R 4L +(R0-3)

(R0-2)

(R0-1)

(R0)

图2-3-2 乘法运算法则

参考程序(A51\2_3_2.ASM ):

ORG 0000H LJMP MAIN ORG 0100H

MAIN: MOV R0,#23H ;运算结果低位地址 MOV A,R0 PUSH ACC CLR A MOV R7,#4

LP1: MOV @R0,A ;运算结果存储单元清零

DEC R0 DJNZ R7,LP1 POP ACC MOV R0,A MOV A,R3 MOV B,R5 MUL AB ;计算R3*R5 MOV @R0,A ;计算的低8位保存

MOV A,B DEC R0

MOV @R0,A ;保存运算的高8位 MOV A,R2 MOV B,R5 MUL AB ;计算R2*R5

ADD A,@R0 ;此次运算低8位+R3*R5运算的高8位 MOV @R0,A DEC R0 MOV A,B

ADDC A,#00H ;R2*R5的高8位加进位位

MOV @R0,A

INC R0

MOV A,R3

MOV B,R4

MUL AB ;计算R3*R4

ADD A,@R0

MOV @R0,A

MOV A,B

DEC R0

ADDC A,@R0

MOV @R0,A

DEC R0

CLR A

ADDC A,#00H

MOV A,@R0

MOV A,R2

MOV B,R4

MUL AB ;计算R2*R4

INC R0

ADD A,@R0

MOV @R0,A

MOV A,B

DEC R0

ADDC A,@R0

MOV @R0,A

NOP ;设置断点查看运算结果

SJMP MAIN ;如需进行下一次运算, 可修改R2 R3,R4 R5的值

END

实验步骤:

1)编写程序,经编译、链接无误后装载到实验系统;

2)设置被乘数R2, R3为03h, 50h、乘数R4, R5为04h, 60h;

3)在SJMPMAIN语句行设置断点,然后运行程序;

4)程序遇到断点后暂停,此时查看内存单元20h起始的内容,应为:00h、0Eh、7Eh、

00h;

5)反复修改被乘数、乘数的值,验证程序的正确性。

3.双字节除法

MCS-51指令系统中仅有单字节除法指令,若要扩展为双字节除法,可以采用“移位相减”的算法来实现。本例程的被除数在R7、R6中,除数在R5、R4中,将商存入R7、R6中,余数存入R3、R2中。程序流程图如图3-3-3所示。

参考程序(A51\2_3_3.ASM):

ORG 0000H

图2-3-3 程序流程图

LJMP MAIN

ORG 0100H

MAIN: MOV A,R4 ;执行程序前为

;R5R4(除数)赋值

JNZ DDIV0 ;除数不为0,转DDIV0

MOV A,R5 JZ ERROR

;除数为0,转ERROR

DDIV0: MOV R2,#00H ;余数寄存器清零 MOV R3,#00H

MOV R1,#16 ;循环次数为16

DDIV1: CLR C;R3 R2 R7 R6左移1位 MOV A,R6 RLC A MOV R6,A MOV A,R7 RLC A MOV R7,A MOV A,R2 RLC A MOV R2,A MOV A,R3 RLC A MOV R3,A

MOV A,R2 ;部分余数减除数 SUBB A,R4 ;低8位相减 JC DDIV2 ;不够减, 转DDIV2 MOV R0,A ;暂存相减结果 MOV A,R3

SUBB A,R5 ;高8位相减 JC DDIV2 ;不够减, 转DDIV2 INC R6 ;够减, 则商为1 MOV R3,A ;相减结果送R3 R2中 MOV A,R0 MOV R2,A

DDIV2: DJNZ R1,DDIV1 ;16位未除完则继续 CLR F0 ;除数合法标志

SJMP MAIN ;设置断点观察结果, 可继续下一轮运算 ERROR: SETB F0 ;除数非法标志

SJMP MAIN ;设置断点观察结果, 可继续下一轮运算 END

实验步骤:

1) 编写程序,程序流程图如图2-3-3所示,经编译、链接无误后装载到实验系统; 2) 设置被除数R7, R6为46h,EEh 、除数R5, R4为23h, 67h ; 3) 在SJMPMAIN 语句行设置断点,然后运行程序;

4)程序遇到断点后暂停,此时查看寄存器R7, R6(商)与R3, R2(余数),应分别为

00h,02h与00h、20h;

5)反复修改被除数、除数的值,验证程序的正确性。

四、实验心得

在这次实验中,我顺利运行了多字节的加法、双字节无符号乘法和双字节除法程序并得到了预期的结果,通过对程序进行分析,我对多字节数的运算在单片机内实现有了一个更深刻的认识,提高了对程序的分析理解能力。

实验四查表程序设计实验

一、实验目的

学习查表程序的设计方法,熟悉MCS-51指令系统。

二、实验设备

PC计算机一台,Dais-52PRO+或Dais-PRO163C实验系统一套。

三、实验内容及步骤

1.采用查表的方法将16进制数转换为ASCII码

根据ASCII码表可知,0~9的ASCII码为30h~39h,A~F的ASCII码为41h~46h,算法为(假定待转换的数存放在R7中):

当R7≤9时,相应的ASCII码为:R7+30h;

当R7>9时,相应的ASCII码为:R7+30h+07h。

参考程序(A51\2_4_1.ASM):

ORG 0000H

LJMP MAIN

ORG 0100H

MAIN: MOV DPTR,#ASCII ;表格首地址送DPTR

MOV A,R7 ;R7中为待转换的数

ANL A,#0FH ;取低4位

MOVC A,@A+DPTR ;查表

MOV R5,A ;低4位转换结果送R1

MOV A,R7

ANL A,#0F0H ;取待转换数的高4位

SWAP A ;高4位与低4位交换

MOVC A,@A+DPTR ;查表

MOV R6,A ;高4位转换结果送R2

SJMP MAIN ;设置断点观察结果

ASCII: DB "0123456789ABCDEF"

END

实验步骤:

1)编写程序,经编译、链接无误后装载到实验系统;

2)设置待转换数据R7为8Ah;

3)在SJMPMAIN语句行设置断点,然后运行程序;

4)程序遇到断点后暂停,此时查看寄存器R6, R5的值,R6中为高4位转换结果38h,

R5中为低4位转换结果41h;

5)反复修改R7的值,验证程序的正确性。

2.通过查表实现y=x2

x为0~9的十进制数,存放于寄存器R7,以BCD 码的形式保存,结果y以BCD码的形式存放于寄存器R6。

参考程序(A51\2_4_2.ASM):

ORG 0000H

LJMP MAIN

ORG 0100H

MAIN: MOV DPTR,#SQR ;取表格首地址

MOV A,R7 ;要计算的值

MOVC A,@A+DPTR ;查表

MOV R6,A ;结果保存

SJMP MAIN

SQR: DB 00H,01H,04H,09H,16H ;平方表

DB 25H,36H,49H,64H,81H

END

实验步骤:

1)编写程序,经编译、链接无误后装载到实验系统;

2)设置R7的值,如R7=09h;

3)在SJMPMAIN语句行设置断点,然后运行程序;

4)程序遇到断点后暂停,此时查看寄存器R6的值,应为81h;

5)反复修改R7的值,验证程序的正确性。

四、实验心得

通过这次实验,我对查表程序的设计方法有了一个更加深刻的理解:查表程序常用于数据的补偿、修正、计算、转换等场合,具有程序简单、执行速度快等特点。同时,通过对查表指令“Movc A,@A+DPTR”和“Movc A,@A+PC”的运用,我对它们区别也有了体会:指令“MOVC A,@A+DPTR”完成把A中的内容作为一个无符号数与DPTR中的内容相加,所得结果为某一程序存储单元的地址,然后把该地址单元中的内容送到累加器A中。指令“MOVC A,@A+PC”以PC作为基址寄存器,PC的内容和A的内容作为无符号数,相加后所得的数作为某一程序存储单元的地址,然后把该地址单元中的内容送到累加器A 中。

实验五数据排序实验

一、实验目的

熟悉MCS-51指令系统,掌握数据排序程序的设计方法。

二、实验设备

PC计算机一台,Dais-52PRO+或Dais-PRO163C实验系统一套。

三、实验内容及步骤

在单片机片内RAM的30h~3Fh写入16个数,编写实验程序,将这16个数按照由小到大的顺序排列。

参考程序(A51\2_5.ASM):

ORG 0000H

LJMP MAIN

ORG 0100H

MAIN: MOV R0,#30H ;数据起始地址

MOV R7,#16 ;排序数据个数

LP1: MOV A,R7

MOV R6,A

MOV A,R0

MOV R1,A

INC R1

LP2: MOV A,@R0 ;取出一个数据

CLR C

SUBB A,@R1 ;与第二个数进行比较

JC LP3 ;R0中的数小于R1中的数则跳转

MOV A,@R0 ;R0中的数大于R1中的数, 交换数据

XCH A,@R1

MOV @R0,A

LP3: INC R1

DJNZ R6,LP2

INC R0

DJNZ R7,LP1

SJMP $

END

图2-5-1 程序流程图

实验步骤:

1)编写程序,经编译、链接无误后装载到实验系统;

2)待排序的数据存放于片内RAM的30h~3Fh单元,可在存储器窗口直接输入;

3)在SJMP $语句行设置断点,然后运行程序;

4)程序遇到断点后暂停,此时查看片内RAM的30h~3Fh单元数据,应从小到大排列;

5)继续向片内RAM的30h~3Fh单元填入数据,重新运行程序,验证程序的正确性。

四、实验感想

在这次实验中,我顺利完成了实验的验证,实验的程序是通过冒泡法进行数据的排序,实验原理简单,程序也不复杂,程序使用条件转移指令实现了程序的循环,加深了我对条件转移指令的理解。

实验六 位操作实验

一、实验目的

掌握位指令的使用,学习位程序的设计方法。

二、实验设备

PC 计算机一台,Dais-52PRO+或Dais-PRO163C 实验系统一套。

三、实验内容及步骤

编写实验程序,计算Y = A ⊕B ,也可表示为Y = A ?B+?AB 。

MCS-51单片机内部有一个一位微处理器,借用进位标志Cy 作为位累加器。位操作指令的操作对象是内部RAM 的位寻址区,即字节地址为20h~2Fh 单元中连续的128位(位地址为00h~7Fh ),以及特殊功能寄存器中的可位寻址的位。

参考程序(A51\2_6.ASM ): QA EQU 00H QB EQU 01H QY EQU 04H ORG 0000H LJMP MAIN ORG 0100H

MAIN: MOV C,QA

ANL C,/QB ;C=QA(QB 非) MOV QY,C MOV C,QA CPL C

ANL C,QB ;C=(QA 非)QB

ORL C,QY ;C=QA(QB 非)+(QA 非)QB MOV QY,C

SJMP MAIN ;设置断点, 观察20H 的值 END

实验步骤:

1) 编写程序,经编译、链接无误后装载到实验系统; 2) 修改片内RAM 的20h 单元的数据,如01h ; 3) 在SJMP $语句行设置断点,然后运行程序;

4) 程序遇到断点后暂停,此时查看片内RAM 的20h 单元,应为11h ; 继续修改片内RAM 的20h 单元的数据,重新运行程序,验证程序的正确性。

四、实验感想

这次实验程序比较简单,就是通过位运算实现两个数的异或,但是通过这次实验,我不但对51单片机的位寻址和位操作指令有了一个更深刻的认识,而且对51单片机内的位寻址区域也有了一个更深刻的印象,是一次受益匪浅的实验。

表2-6 异或真值表

嵌入式操作系统实验报告

中南大学信息科学与工程学院实验报告 姓名:安磊 班级:计科0901 学号: 0909090310

指导老师:宋虹

目录 课程设计内容 ----------------------------------- 3 uC/OS操作系统简介 ------------------------------------ 3 uC/OS操作系统的组成 ------------------------------ 3 uC/OS操作系统功能作用 ---------------------------- 4 uC/OS文件系统的建立 ---------------------------- 6 文件系统设计的原则 ------------------------------6 文件系统的层次结构和功能模块 ---------------------6 文件系统的详细设计 -------------------------------- 8 文件系统核心代码 --------------------------------- 9 课程设计感想 ------------------------------------- 11 附录-------------------------------------------------- 12

课程设计内容 在uC/OS操作系统中增加一个简单的文件系统。 要求如下: (1)熟悉并分析uc/os操作系统 (2)设计并实现一个简单的文件系统 (3)可以是存放在内存的虚拟文件系统,也可以是存放在磁盘的实际文件系统 (4)编写测试代码,测试对文件的相关操作:建立,读写等 课程设计目的 操作系统课程主要讲述的内容是多道操作系统的原理与技术,与其它计算机原理、编译原理、汇编语言、计算机网络、程序设计等专业课程关系十分密切。 本课程设计的目的综合应用学生所学知识,建立系统和完整的计算机系统概念,理解和巩固操作系统基本理论、原理和方法,掌握操作系统开发的基本技能。 I.uC/OS操作系统简介 μC/OS-II是一种可移植的,可植入ROM的,可裁剪的,抢占式的,实时多任务操作系统内核。它被广泛应用于微处理器、微控制器和数字信号处理器。 μC/OS 和μC/OS-II 是专门为计算机的嵌入式应用设计的,绝大部分代码是用C语言编写的。CPU 硬件相关部分是用汇编语言编写的、总量约200行的汇编语言部分被压缩到最低限度,为的是便于移植到任何一种其它的CPU 上。用户只要有标准的ANSI 的C交叉编译器,有汇编器、连接器等软件工具,就可以将μC/OS-II嵌入到开发的产品中。μC/OS-II 具有执行效率高、占用空间小、实时性能优良和可扩展性强等特点,最小内核可编译至2KB 。μC/OS-II 已经移植到了几乎所有知名的CPU 上。 严格地说uC/OS-II只是一个实时操作系统内核,它仅仅包含了任务调度,任务管理,时间管理,内存管理和任务间的通信和同步等基本功能。没有提供输入输出管理,文件系统,网络等额外的服务。但由于uC/OS-II良好的可扩展性和源码开放,这些非必须的功能完全 可以由用户自己根据需要分别实现。 uC/OS-II目标是实现一个基于优先级调度的抢占式的实时内核,并在这个内核之上提供最基本的系统服务,如信号量,邮箱,消息队列,内存管理,中断管理等。 uC/OS操作系统的组成 μC/OS-II可以大致分成核心、任务处理、时间处理、任务同步与通信,CPU的移植等5个部分。如下图:

嵌入式实验报告

课题:按键控制流水灯 专业:物联网工程 班级:01 学号:14154951 姓名:李政 指导教师:何建军 设计日期:2016.12.21—2016.12.30 成绩: 重庆大学城市科技学院电气学院

嵌入式设计报告 一、设计目的作用 通过编程实现对LED灯项目的改变,加深对stm32芯片的理解,对keil软件的熟悉掌握,工程的搭建以及头文件的使用。掌握外部设备的接入以及外部中断的实现。 二、设计要求 用四个按键控制8个流水灯的流水显示 (1).按键A按下时候流水灯按从左往右的流水显示。 (2).按键B按下时候流水灯按从右往左的流水显示。 (3).按键C按下时候流水灯按中心开花的方式流水显示:从中间向两边流水显示 (4).按键D按下时候流水灯按从两边到中心移动的方式流水显示。(5).(选做)引入时针中断: 默认的流水方式: (1)对时钟中断的次数进行计数 (2)当时钟中断的次数除以4的余数为0时:按从左到右的顺序流水显示(3)当时钟中断的次数除以4的余数为1时:按从右到左的顺序流水显示(4)当时钟中断的次数除以4的余数为2时:按中心开花的方式流水显示(5)当时钟中断的次数除以4的余数为3时:从两边到中心移动的方式流水显示。 系统启动时按默认的流水方式显示,当按下A、B、C、D四个按键时,按指定的方式流水显示,当按下按键E时恢复按默认的流水方式。 三、设计的具体实现 1、设计原理 这次使用的是stm32f103系列芯片,芯片引脚如下图

Stm32内部资源

GPIO原理及应用: 有7个16位并行I/O口:PA、PB、PC、PD、 PE、PF、PG 都是复用的,最少有2种 功能,最多有6种功能

嵌入式实验报告

嵌入式技术 实验报告 系别:计算机与科学技术系 班级:计12-1班 姓名:刘杰 学号:12101020128 总成绩: 评语: 日期:

2.在弹出的对话框中依次选择“cedevice emulator emulator kdstub”。 3.选择“Build OS”菜单的“sysgen”开始构建平台。 1.1.4连接,下载和运行平台 1.选择“Target”菜单下的“Connection option”菜单项。 2.在新的对话框中,配置连接关系 3.选择“Target”菜单下的“attach”菜单项,开始下载。 ?实验结果 操作系统定制成功,能正常运行。 ?结果截图 ?问题总结 由于对实验平台了解不够,致使操作过程中添加和删除组件时不知道该如何下手,影响整个实验进度。 实验1.2: 1.打开Platform Builder,并且打开实验1的工程,在实验1的工程基础上做本实验。

进程显示 IE信息查看

报文监测 实验1.3使用Platform Builder开发应用程序 简单实验步骤 1.打开Platform Builder。 2.选择“File”菜单下的“Open Workspace…”,然后打开实验1中创建的平台,本实验要基于 上面的实验的基础上做。 3.选择“File”菜单下的“New Project or File…”,打开“New Project or File”对话框。 4.在“Projects”选项页中选择“WCE Application”;在“Project Name”中输入项目的名字,例 如“MyApp”。 5.在“New Project Wizard – step 1 of 1”中选择“A typical Hello World Application”,点击“Finish” 按钮。 6.选择“Build”菜单中的“Build MyApp.exe”来编译应用程序。

嵌入式操作系统实验报告

中南大学信息科学与工程学院实验报告 :安磊 班级:计科0901 学号: 0909090310 指导老师:宋虹

目录 课程设计容 ----------------------------------- 3 uC/OS操作系统简介 ------------------------------------ 3 uC/OS操作系统的组成 ------------------------------ 3 uC/OS操作系统功能作用 ---------------------------- 4 uC/OS文件系统的建立 ---------------------------- 6 文件系统设计的原则 ------------------------------ 6 文件系统的层次结构和功能模块 --------------------- 6 文件系统的详细设计 -------------------------------- 8 文件系统核心代码 --------------------------------- 9 课程设计感想 ------------------------------------- 11 附录 -------------------------------------------------- 12

课程设计容 在uC/OS操作系统中增加一个简单的文件系统。 要求如下: (1)熟悉并分析uc/os操作系统 (2)设计并实现一个简单的文件系统 (3)可以是存放在存的虚拟文件系统,也可以是存放在磁盘的实际文件系统 (4)编写测试代码,测试对文件的相关操作:建立,读写等 课程设计目的 操作系统课程主要讲述的容是多道操作系统的原理与技术,与其它计算机原理、编译原理、汇编语言、计算机网络、程序设计等专业课程关系十分密切。 本课程设计的目的综合应用学生所学知识,建立系统和完整的计算机系统概念,理解和巩固操作系统基本理论、原理和方法,掌握操作系统开发的基本技能。 I.uC/OS操作系统简介 μC/OS-II是一种可移植的,可植入ROM的,可裁剪的,抢占式的,实时多任务操作系统核。它被广泛应用于微处理器、微控制器和数字信号处理器。 μC/OS 和μC/OS-II 是专门为计算机的嵌入式应用设计的,绝大部分代码是用C语言编写的。CPU 硬件相关部分是用汇编语言编写的、总量约200行的汇编语言部分被压缩到最低限度,为的是便于移植到任何一种其它的CPU 上。用户只要有标准的ANSI 的C交叉编译器,有汇编器、连接器等软件工具,就可以将μC/OS-II嵌入到开发的产品中。μC/OS-II 具有执行效率高、占用空间小、实时性能优良和可扩展性强等特点,最小核可编译至 2KB 。μC/OS-II 已经移植到了几乎所有知名的CPU 上。 严格地说uC/OS-II只是一个实时操作系统核,它仅仅包含了任务调度,任务管理,时间管理,存管理和任务间的通信和同步等基本功能。没有提供输入输出管理,文件系统,网络等额外的服务。但由于uC/OS-II良好的可扩展性和源码开放,这些非必须的功能完全可以由用户自己根据需要分别实现。 uC/OS-II目标是实现一个基于优先级调度的抢占式的实时核,并在这个核之上提供最基本的系统服务,如信号量,,消息队列,存管理,中断管理等。 uC/OS操作系统的组成 μC/OS-II可以大致分成核心、任务处理、时间处理、任务同步与通信,CPU的移植等5个部分。如下图:

嵌入式系统实验报告

实验报告 课程名称:嵌入式系统 学院:信息工程 专业:电子信息工程 班级: 学生姓名: 学号: 指导教师: 开课时间:学年第一学期

实验名称:IO接口(跑马灯) 实验时间:11.16 实验成绩: 一、实验目的 1.掌握 STM32F4 基本IO口的使用。 2.使用STM32F4 IO口的推挽输出功能,利用GPIO_Set函数来设置完成对 IO 口的配置。 3.控制STM32F4的IO口输出,实现控制ALIENTEK 探索者STM32F4开发板上的两个LED实现一个类似跑马灯的效果。 二、实验原理 本次实验的关键在于如何控制STM32F4的IO口输出。IO主要由:MODER、OTYPER、OSPEEDR、PUPDR、ODR、IDR、AFRH和AFRL等8个寄存器的控制,并且本次实验主要用到IO口的推挽输出功能,利用GPIO_Set函数来设置,即可完成对IO口的配置。所以可以通过了开发板上的两个LED灯来实现一个类似跑马灯的效果。 三、实验资源 实验器材: 探索者STM32F4开发板 硬件资源: 1.DS0(连接在PF9) 2.DS1(连接在PF10) 四、实验内容及步骤 1.硬件设计 2.软件设计 (1)新建TEST工程,在该工程文件夹下面新建一个 HARDWARE文件夹,用来存储以后与硬件相关的代码。然后在 HARDWARE 文件夹下新建一个LED文件夹,用来存放与LED相关的代码。 (2)打开USER文件夹下的test.uvproj工程,新建一个文件,然后保存在 LED 文件夹下面,保存为 led.c,在led.c中输入相应的代码。

(3)采用 GPIO_Set 函数实现IO配置。LED_Init 调用 GPIO_Set 函数完成对 PF9 和 PF10 ALIENTEK 探索者 STM32F407 开发板教程 119 STM32F4 开发指南(寄存器版) 的模式配置,控制 LED0 和 LED1 输出 1(LED 灭),使两个 LED 的初始化。 (4)新建一个led.h文件,保存在 LED 文件夹下,在led.h中输入相应的代码。 3.下载验证 使用 flymcu 下载(也可以通过JLINK等仿真器下载),如图 1.2所示: 图1.2 运行结果如图1.3所示:

嵌入式实验报告心得

嵌入式实验报告心得 篇一:嵌入式系统原理实验总结报告 嵌入式系统原理实验总结报告 车辆座椅控制系统实验 XX/5/23 嵌入式系统原理实验总结报告 一、技术性总结报告 (一)题目:车辆座椅控制系统实验(二)项目概述: 1.为了实现车辆座椅控制的自动化与智能化。 2.方便用户通过智能手机与车载传感器之间的联动。 3.使车辆作为当今物联网中重要的一个节点发挥作用。 4.通过车辆座椅控制系统实验实现对嵌入式系统原理课程的熟练掌握与对嵌入式系统原理知识的深化记忆。 5. 加强本组学生对嵌入式系统原理的更深层次的理解与运用。 (三)技术方案及原理 本次试验分为软件、硬件两个部分。 1.软件部分。 A.智能手机部分,包括通过智能手机对座椅的控制部分、手机所携带的身份信息部分。 本部分软件使用Java编写,其程序部分为:主程序:package ;

import ; import ; import ; import ; import ; import ; import ; import ; import ; import ; import ; import ; import ; import ; import ; import ; import ; import ; import ; import ; import ; import ; import ; import ; import ; import ;import ; import ; import ; public class MainActivity extends ActionBarActivity { private Button Up = null; private Button Left = null; private Button Dowm = null; private Button Right = null; private Socket socket = null; private static final String HOST = "";private static final int PORT = 10007; public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(; initControl();} private void initControl() {

南邮嵌入式系统B实验报告2016年度-2017年度-2

_* 南京邮电大学通信学院 实验报告 实验名称:基于ADS开发环境的程序设计 嵌入式Linux交叉开发环境的建立 嵌入式Linux环境下的程序设计 多线程程序设计 课程名称嵌入式系统B 班级学号 姓名 开课学期2016/2017学年第2学期

实验一基于ADS开发环境的程序设计 一、实验目的 1、学习ADS开发环境的使用; 2、学习和掌握ADS环境下的汇编语言及C语言程序设计; 3、学习和掌握汇编语言及C语言的混合编程方法。 二、实验内容 1、编写和调试汇编语言程序; 2、编写和调试C语言程序; 3、编写和调试汇编语言及C语言的混合程序; 三、实验过程与结果 1、寄存器R0和R1中有两个正整数,求这两个数的最大公约数,结果保存在R3中。 代码1:使用C内嵌汇编 #include int find_gcd(int x,int y) { int gcdnum; __asm { MOV r0, x MOV r1, y LOOP: CMP r0, r1 SUBLT r1, r1, r0 SUBGT r0, r0, r1 BNE LOOP MOV r3, r0 MOV gcdnum,r3 //stop // B stop // END } return gcdnum; } int main() { int a; a = find_gcd(18,9);

printf("gcdnum:%d\n",a); return 0; } 代码2:使用纯汇编语言 AREA example1,CODE,readonly ENTRY MOV r0, #4 MOV r1, #9 start CMP r0, r1 SUBLT r1, r1, r0 SUBGT r0, r0, r1 BNE start MOV r3, r0 stop B stop END 2、寄存器R0 、R1和R2中有三个正整数,求出其中最大的数,并将其保存在R3中。 代码1:使用纯汇编语言 AREA examp,CODE,READONL Y ENTRY MOV R0,#10 MOV R1,#30 MOV R2,#20 Start CMP R0,R1 BLE lbl_a CMP R0,R2 MOVGT R3,R0 MOVLE R3,R2 B lbl_b lbl_a CMP R1,R2 MOVGT R3,R1 MOVLE R3,R2 lbl_b B . END 代码2:使用C内嵌汇编语言 #include int find_maxnum(int a,int b,int c)

嵌入式实验报告

目录 实验一跑马灯实验 (1) 实验二按键输入实验 (3) 实验三串口实验 (5) 实验四外部中断实验 (8) 实验五独立看门狗实验 (11) 实验七定时器中断实验 (13) 实验十三ADC实验 (15) 实验十五DMA实验 (17) 实验十六I2C实验 (21) 实验十七SPI实验 (24) 实验二十一红外遥控实验 (27) 实验二十二DS18B20实验 (30)

实验一跑马灯实验 一.实验简介 我的第一个实验,跑马灯实验。 二.实验目的 掌握STM32开发环境,掌握从无到有的构建工程。 三.实验内容 熟悉MDK KEIL开发环境,构建基于固件库的工程,编写代码实现跑马灯工程。通过ISP 下载代码到实验板,查看运行结果。使用JLINK下载代码到目标板,查看运行结果,使用JLINK在线调试。 四.实验设备 硬件部分:PC计算机(宿主机)、亮点STM32实验板、JLINK。 软件部分:PC机WINDOWS系统、MDK KEIL软件、ISP软件。 五.实验步骤 1.熟悉MDK KEIL开发环境 2.熟悉串口编程软件ISP 3.查看固件库结构和文件 4.建立工程目录,复制库文件 5.建立和配置工程

6.编写代码 7.编译代码 8.使用ISP下载到实验板 9.测试运行结果 10.使用JLINK下载到实验板 11.单步调试 12.记录实验过程,撰写实验报告 六.实验结果及测试 源代码: 两个灯LED0与LED1实现交替闪烁的类跑马灯效果,每300ms闪烁一次。七.实验总结 通过本次次实验我了解了STM32开发板的基本使用,初次接触这个开发板和MDK KEILC 软件,对软件操作不太了解,通过这次实验了解并熟练地使用MDK KEIL软件,用这个软件来编程和完成一些功能的实现。作为STM32 的入门第一个例子,详细介绍了STM32 的IO口操作,同时巩固了前面的学习,并进一步介绍了MDK的软件仿真功能。

嵌入式系统看门狗实验报告

竭诚为您提供优质文档/双击可除嵌入式系统看门狗实验报告 篇一:《嵌入式系统原理与应用》实验报告04-看门狗实验 《嵌入式系统原理与接口技术》实验报告 实验序号:4实验项目名称:看门狗实验 1 2 3 4 篇二:嵌入式实验报告 目录 实验一跑马灯实验................................................. (1) 实验二按键输入实验................................................. .. (3)

实验三串口实验................................................. . (5) 实验四外部中断实验................................................. .. (8) 实验五独立看门狗实验................................................. (11) 实验七定时器中断实验................................................. (13) 实验十三ADc实验................................................. .. (15) 实验十五DmA实验................................................. .. (17) 实验十六I2c实验................................................. .. (21) 实验十七spI实

嵌入式系统实验实验报告

嵌入式系统实验实验报告 一、实验目的 1.基本实验

. Word 资料搭建PXA270嵌入式LINUX开发软硬件环境;安装LINUX操 作系统;安装与配置建立宿主机端交叉编译调试开发环境;配置宿主机 PC 机端的minicom(或超级终端)、TFTP服务、NFS服务,使宿主PC机与PXA270开发板可以通过串口通讯,并开通TFTP 和NFS服务。 2.人机接口 键盘驱动;LCD控制;触摸屏数据采集与控制实验; 3.应用实验 完成VGA显示;Web服务器实验;网络文件传输实验;多线程应用实验。 4.扩展应用实验 完成USB摄像头驱动与视频采集;GPS实验;GSM/GPRS通讯;视频播放移植;USB蓝牙设备无线通讯;NFS文件服务器;蓝牙视频文件服务器。 5.QT实验 完成基本嵌入式图形开发环境搭建;“Hello world!”QT初探;创建一个窗口并添加按钮;对象通信:Signal和Slot;菜单和快捷键;工具条和状态栏;鼠标和键盘事件;对话框;QT的绘图;俄罗斯方块;基于QT的GSM手机在嵌入式LINUX下的设计与实现。 二、实验内容 1.人机接口实验 实验十九键盘驱动实验 ?实验目的:矩阵键盘驱动的编写

?实验内容:矩阵键盘驱动的编写 ?作业要求:完成键盘加减乘除运算 ?实验作业源码及注释: #INCLUDE #INCLUDE #INCLUDE #INCLUDE #INCLUDE #INCLUDE #DEFINE DEVICE_NAME “/DEV/KEYBOARD” INT MAIN(VOID){ INT FD; INT RET; UNSIGNED CHAR BUF[1]; INT I,F,J; DOUBLE X; INT A[2]={0}; CHAR PRE_SCANCODE=0XFF; FD=OPEN(DEVICE_NAME,O_RDWR); IF(FD==-1)PRINTF(“OPEN DEVICE %S ERROR\N”,DEVICE_NAME); ELSE{ BUF[0]=0XFF; I=0;F=0; WHILE(1){ READ(FD,BUF,1);

嵌入式综合实验报告

《嵌入式系统综合实验》报告 学号: 姓名: Shanghai University of Engineering Science School of Electronic and Electrical Engineering

基于STM32的GPS信息显示系统 ——嵌入式系统综合实验报告 班级:0211112 姓名:褚建勤学号:021111228 班级:0211112 姓名:于心忆学号:021111216 班级:0211112 姓名:乐浩奎学号:021111232 一、产品设计要求(产品规格描述) 1 、嵌入式产品名称 GPS信息显示系统 2 、嵌入式产品目的 在学校的生活中,你经常可能需要联系不是同一间宿舍的同学,但是你不能确定他现在在什么地方,这时候全球定位系统(GPS)就可以发挥作用了,但是传统的GPS系统只能提供经纬度信息,不能直观的显示你想要找到人在何处,我们的系统就在传统的GPS的基础上添加了对应位置显示的功能,方便你更方便更快捷的找到你想找的同学 3 、嵌入式产品功能 使用GPS输入用户位置信息 GPS将相关经纬度信息反馈给主处理器 主处理器处理相关位置信息并将信息转换为对应位置在LCD上显示出来 在LCD上输出用户状态信息 4 、嵌入式产品的输入和输出 输入设备:GPS系统 输出设备:LCD 二、产品方案设计(产品设计方案) 1 2 1 )处理器选择 本系统选用基于ARMCortex-M3内核的STM32F103RB嵌入式微控制器作为处理器。 ①选用原因 A 技术因素 工作频率: 最高72MHz。 内部和外部存储器: 128K字节的闪存程序存储器,用于存放程序及数据;多达20K字节的内置SRAM,CPU能以0等待周期访问(读/写)。

西安邮电大学嵌入式实验报告

西安邮电大学 (计算机学院) 课内实验报告 实验名称:嵌入式系统原理与应用 专业名称:软件工程 班级:1101班 学生姓名: 学号(8位): 指导教师:李宥谋 实验日期:2013年12月25日

实验一流水灯实验 一.实验目的及实验环境 1.实验目的 ●熟悉LPC2000系列ARM7微控制器的GPIO输出控制。 2.实验环境 ●硬件:PC机一台 LPC2131教学实验开发平台一套 ●软件:Windows 98/XP/2000系统,ADS1.2集成开发环境。 二.实验内容 使用GPIO口控制8个LED流水灯显示。 三.方案设计 ①启动ADS1.2IDE集成开发环境,选择ARM Executable Image for lpc2131 工程模板建立一个工程LedDisp_C。 ②在user组里编写主程序代码main.c。 ③选用DebugInRam生成目标,然后编译链接工程。 ④将EasyARM教学实验开发平台上的P1.[18:25]管脚对应与LED[1:8]跳线 短接。 ⑤选择Project->Debug,启动AXD进行JTAG仿真调试。 ⑥全速运行程序,程序将会在main.c的主函数中停止。

⑦单击Context Variable图标按钮(或者选择Processor Views->Variables)打开变量观察窗口,通过此窗口可以观察局部变量 和全局变量。选择System Views->Debugger Internals 即可打开 LPC2000系列ARM7微控制器的片内外寄存器窗口。 ⑧可以单步运行程序,可以设置/取消断点;或者全速运行程序,停止程 序运行,观察变量的值,判断LED1~LED8控制是否正确。 四.测试数据及运行结果

嵌入式系统实验报告

郑州航空工业管理学院 嵌入式系统实验报告 (修订版) 20 – 20第学期 赵成,张克新 院系: 姓名: 专业: 学号: 电子通信工程系 2014年3月制

实验一ARM体系结构与编程方法 一、实验目的 了解ARM9 S3C2410A嵌入式微处理器芯片的体系结构,熟悉ARM微处理器的工作模式、指令状态、寄存器组及异常中断的概念,掌握ARM指令系统,能在ADS1.2 IDE中进行ARM汇编语言程序设计。 二、实验内容 1.ADS1.2 IDE的安装、环境配置及工程项目的建立; 2.ARM汇编语言程序设计(参考附录A): (1)两个寄存器值相加; (2)LDR、STR指令操作; (3)使用多寄存器传送指令进行数据复制; (4)使用查表法实现程序跳转; (5)使用BX指令切换处理器状态; (6)微处理器工作模式切换; 三、预备知识 了解ARM嵌入式微处理器芯片的体系结构及指令体系;熟悉汇编语言及可编程微处理器的程序设计方法。 四、实验设备 1. 硬件环境配置 计算机:Intel(R) Pentium(R) 及以上; 内存:1GB及以上; 实验设备:UP-NETARM2410-S嵌入式开发平台,J-Link V8仿真器; 2. 软件环境配置 操作系统:Microsoft Windows XP Professional Service Pack 2; 集成开发环境:ARM Developer Suite (ADS) 1.2。 五、实验分析 1.安装的ADS1.2 IDE中包括和两个软件组件。在ADS1.2中建立类型的工程,工程目标配置为;接着,还需要对工程进行、及链接器设置;最后,配置仿真环境为仿真方式。 2.写出ARM汇编语言的最简程序结构,然后在代码段中实现两个寄存器值的加法运算,给出运算部分相应指令的注释。 ; 文件名:

嵌入式系统实验报告

嵌入式系统实验报告文件排版存档编号:[UYTR-OUPT28-KBNTL98-UYNN208]

大连理工大学 本科实验报告 课程名称:嵌入式系统实验 学院(系):电子信息与电气工程学部 专业:自动化 班级: 0804 学号: 学生姓名:何韬 2011年 11月 18日 大连理工大学实验报告 学院(系):电信专业:自动化班级: 0804 姓名:何韬学号:组: ___ 实验时间: 2011-11-12 实验室: d108 实验台: 指导教师签字:成绩: 实验二ARM的串行口实验 一、实验目的和要求 见预习报告 二、实验原理和内容 见预习报告 三、主要仪器设备

硬件:ARM嵌入式开发平台、用于ARM7TDMI 的JTAG 仿真器、PC机Pentium100 以上、串口线。 软件:PC 机操作系统win98、Win2000 或WinXP 、ARM SDT 或集成开发环境、仿真器驱动程序、超级终端通讯程序。 四、实验步骤 见预习报告 五、核心代码 在主函数中实现将从串口0接收到的数据发送到串口0() int main(void) { char c1[1]; char err; ARMTargetInit(); 通过调用OSTaskCreate()或OSTaskCreateExt()创建至少一个任务; . OSStart(); /ucos-ii/" /* uC/OS interface */ #include "../ucos-ii/add/" #include "../inc/" #include "../inc/sys/" #include "../src/gui/" #include <> #include <>

嵌入式基础实验报告

嵌入式基础实验报告 ——Linux下编译环境的设置 姓名:张耀丹 学号:131012692 班级:13级网络工程二班

一、实验目的 1、熟悉嵌入式Linux 开发环境,学会基于UP-CUP IOT-4412-II 型网关部分平台的Linux 开 发环境的配置和使用 2、利用arm-none-linux-gnueabi-gcc 交叉编译器编译程序,使用基于NFS 的挂载方式进行 实验,了解嵌入式开发的基本过程 二、实验环境 1、硬件:UP-CUP IOT-4412-II 型网关部分嵌入式实验平台,PC 机Pentium 500 以上, 硬盘 40G 以上,内存大于256M 2、软件:Vmware Workstation + Fedora Core 14 + 超级终端/Xshell + ARM-LINUX 交叉编译开 发环境 三、实验内容 1、本次实验使用Fedora14 操作系统环境,安装ARM-Linux 的开发库及编译器。创建一个新 目录,并在其中编写hello.c 和Makefile 文件。 2、学习在Linux 下的编程和编译过程,以及ARM 开发板的使用和开发环境的设置。将已 经编译好的文件通过NFS 方式挂载到目标开发板上运行 四、实验步骤 实验目录:/UP-CUP4412/SRC/exp/basic/Cortex/ 1、编译源程序 (1)在宿主机端任意目录下建立工作目录CortexA9,实际光盘目录中已经给出本次实验所需全面文件及代码,存放在Cortex目录下。 [root@localhost ~]# mkdir CortexA9 [root@localhost ~]# cd CortexA9 (2)编写程序源代码 在Linux 下的文本编辑器有许多,常用的是vim 和Xwindow 界面下的gedit 等,我们在开发过程中推荐使用vim,用户需要学习vim 的操作方法,请参考相关书籍中的关于vim 的操作指南。Kdevelope、anjuta 软件的界面与vc6.0 类似,使用它们对于熟悉windows 环境下开发的用户更容易上手。 实际的CortexA9.c 源代码较简单,如下: #include main() { printf(“**********\n” ); printf(“CortexA9 \n”); printf(“**********\n” ); return 0; }

嵌入式实验报告心得

竭诚为您提供优质文档/双击可除 嵌入式实验报告心得 篇一:嵌入式系统各实验实验报告 嵌入式系统设计实验报告 班级:学号:姓名:成绩:指导教师: xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx 1.实验一 1.1实验名称 博创up-net3000实验台基本结构及使用方法 1.2实验目的 熟悉up-net3000实验平台的核心硬件电路和外设 通过操作系统自带的通讯软件超级终端,检验各个外设的工作状态 1.3实验环境 硬件:ARm嵌入式开发平台、用于ARm7TDmI的JTAg仿真器、pc机 pentium100以上。 软件:pc机操作系统windows、ADs1.2集成开发环境、

仿真器驱动程序、 超级终端通讯程序。 1.4实验内容及要求 一、内容 ①嵌入式系统开发流程概述 ②熟悉up-net3000实验平台的核心硬件电路和外设 ③ARmJTAg的安装与使用 ④通过操作系统自带的通讯软件超级终端,检验各个外设的工作状态 二、要求 通过本次课程对各个外设的了解,为今后各个接口实验打下基础。 1.5实验设计与实验步骤 一、JTAg的驱动程序的安装: 执行armJtag目录下armJtagsetup.exe程序,选择安装目录,安装JTAg软件。 二、通过通讯软件超级终端来检验外设的工作状态: ①运行windows系统下的超级终端(hyperTerminal)应用程序,新建一个通信终端。为所建超级终端取名为arm,可以为其选择第一个图标。单击“确定”按钮。 ②在接下来的对话框中选择ARm开发平台实际连接的pc 机串口(如com1),按确定按钮后出现属性对话框,设置通

嵌入式实验报告

《嵌入式系统导论》实验报告学院: 学号: 姓名: 上海工程技术大学 电子电气工程学院

实验一 GPIO(按键和LED)实验 一、实验要求 1 、掌握基于STM32F103微控制器的嵌入式系统、仿真器和开发用PC机之间的连接方法,能够搭建基于STM32F103微控制器的嵌入式系统交叉开发环境。 2 、熟悉常用的嵌入式开发工具KEIL MDK或IAR EWARM的操作环境和基本功能(包括编辑、编译、链接、调试和下载等),学会创建、配置和管理STM32工程,掌握嵌入式程序的基本调试方法,学会使用逻辑分析仪窗口和外设窗口等信息窗口调试嵌入式程序。 3 、理解LED和按键的构件原理,学会设计它们与微控制器间的接口电路 4 、掌握STM32F103微控制器GPIO的工作原理,熟悉STM32的GPIO库函数 5 、学会使用STM32的GPIO库函数在KEIL MDK或IAR EWARM下开发基于LED和按键的简单嵌入式应用程序 二、实验环境 1 、硬件: ALIENTEK STM32F103嵌入式开发板 2 、软件: KEIL MDK或IAR EWARM 三、实验内容 1 、流水灯实验一: 在KEIL MDK或IAR EWARM 中建立STM32工程,并使用GPIO库函数和延时循环设计基于无限循环架构的嵌入式应用程序,使开发板上的红色LED以一定周期闪烁。 采用软件仿真的方式调试程序,通过“Logic Analyzer”,观察程序模拟运行时连接红色LED的引脚PA8上的输出波形。 采用硬件下载的方式调试程序,观察程序下载硬件运行时红色LED的闪烁情况。 2 、按键控制LED实验:

嵌入式系统实验报告

实验一系统认识实验 一、实验目的 学习Dais软件的操作,熟悉程序编写的操作步骤及调试方法。 二、实验设备 PC计算机一台,Dais-52PRO+或Dais-PRO163C实验系统一套。 三、实验内容 编写程序,将80h~8Fh共16 个数写入单片机内部RAM 的30h~3Fh空间。 四、实验步骤 1.运行Dais软件,进入集成开发环境,软件弹出设置通信端口对话框(如图2-1-1), 请确保实验装置与PC正确连接,并已打开实验装置电源,使其进入在待命状态。 这里选择与实验装置实际相连的通信端口,并单击“确定”。如通信正确则进入Dais 软件主界面,否则弹出“通信出错”的信息框(如图2-1-2),请检查后重试。 图2-1-1设置通信端口对话框图2-1-2通信错误信息框 2.通信成功后,单击菜单栏“设置”→“仿真模式”项打开对话框,选择需要设置型 号、程序/数据空间。这里我们将型号设置为“MCS-51实验系统”,外部数据区 设置为“系统RAM”,用户程序区设置为“片外(EA=0)”,如图2-1-3所示,最 后单击“确定”按钮保存设置。

图2-1-3设置工作方式对话框 3.工作方式设置完毕后,单击菜单栏“文件”→“新建”项或按Ctrl+N组合键(建 议单击工具栏“”按钮)来新建一个文件,软件会出现一个空白的文件编辑窗口。 4.在新窗口中输入程序代码(A51\2_1.ASM): ORG 0000H LJMP MAIN ORG 0100H MAIN: MOV R1,#30H ;片内RAM首地址 MOV A,#80H ;写入数据初值 MOV R7,#16 ;循环变量 LOOP1: MOV @R1,A ;写数据到片内RAM INC R1 ;地址增量 INC A ;数据+1 DJNZ R7,LOOP1 ;循环变量-1,不为0继续 SJMP $ ;结束 END 5.单击菜单栏“文件”→“保存”项(建议单击工具栏“”按钮)保存文件。若 是新建的文件尚未命名,系统会弹出文件保存对话框(如图2-1-4),提示用户选择文件保存的路径和文件名,再单击“保存”按钮。

嵌入式综合实验报告

基于OV511芯片的摄像头图像采集显示系统 【实验目的】 1、掌握OV511摄像头和V4L视频驱动的配置方法。 2、掌握JPEG的交叉编译与移植的过程。 3、掌握帧缓冲编程原理以及利用帧缓冲显示图像的编程方法。 【实验原理】 USB摄像头以其良好的性能和低廉的价格得到广泛应用。同时因其灵活、方便的特性,易于集成到嵌入式系统中,现有的符合Video for Linux标准的驱动程序配合通用应用程序,可以实现USB摄像头视频数据的采集及应用开发。 摄像头属于视频类设备。在目前的Linux核心中,视频部分的标准是Video for Linux(简称V4L)。这个标准其实定义了一套接口,内核、驱动、应用程序以这个接口为标准进行交流。目前的V4L涵盖了视、音频流捕捉及处理等内容,USB摄像头也属于它支持的范畴。 1、Video4Linux和USB摄像头驱动配置 如果需要在Linux操作系统中使用USB摄像头进行视频数据采集,则必须在进行内核配置时,应检查Linux 内核中是否已经添加了对Video4Linux驱动和对USB摄像头驱动模块的支持。 本实验采用静态加载驱动。 首先切换linux源代码所在的目录,并终端输入make menuconfig,系统弹出基于Ncurses 内核配置图形界面(如图1所示),便可进行内核选项的配置。 图1内核配置主界面 1.1、配置界面的使用方法 (1)、在菜单方式的配置界面上可用上下方向键来在各菜单之间移动; (2)、在标有"---->" 标志的地方按回车键进入下级菜单; (3)、按两次或选择则返回到上级菜单; (4)、按“h” 键或选择下面的则可看到配置帮助信息;

江苏科技大学嵌入式实验报告

实验一熟悉嵌入式系统开发环境 一、实验目的: 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地址,开发目录共享,挂载等。 四、实验步骤: 1.掌握嵌入式系统实验平台上的各类接口的位置 UP-TECH S2410/P270 DVP 的硬件配置如表 1.2.1 所示 实物如图 1.2.1 所示:

2.配置windows的超级终端,熟悉vivi的命令行,bootload、kernel、root 和用户程序的介绍; 1)配置windows的超级终端: a)用串口线将 PC 机与 ARM 开发板连接好后,将 UP-TECH S2410、P270 DVP 开发板 开机,然后点击 PC 机上的开始“菜单”然后找到“附件”中“通讯”选项中的“超级终端”, b)然后在超级终端里进行配置,在“名称”中输入要建立的超级终端的名字。 c)在“连接时使用”一栏选择可用的串口号,(这里根据自己的实际情况进行选择)。 d)在“每秒位数”中选择“115200”,“数据流控制”选择“无”,然后点击“确定”按 钮,设置完毕。 2)学习并掌握如下命令: ls,cd ,pwd,cat,more,less,mkdir,rmdir ,rm,mv,cp,tar,ifconfig 3. Linux下minicom的使用与程序挂载 a)打开虚拟机,启动linux; b)新建终端,输入minicom来启动实验箱;

相关文档
最新文档