嵌入式系统实验报告

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

大连理工大学

本科实验报告

课程名称:嵌入式系统实验

学院(系):电子信息与电气工程学部

专业:自动化

班级: 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 <>

#pragma import(__use_no_semihosting_swi) .\n");

.\n");

.\n");

于task2 挂起时间为3 秒,所以在

task2 挂起期间task1 能执行两次,而当第三次时由于task1 与task2 同时处于

就绪态,由优先级次序,还是先执行task1 在执行task2.然后就这样周而复始

的循环下去。

为验证ucos 的强实时性,可以去掉task2()的“OSTimeDly(3000);”

然后

令task1()中的“OSTimeDly(1000);”改为“OSTimeDly(10);”。观察到

的实

验现象是在超级终端上显示被“run task1”打断的”“ run task2”,反

之把task1

和task2 的优先级交换则在超级终端上只显示“run task2”。这说明ucos 的

实时性得到了验证,因为在任何时候只要高优先级的任务都可以打断正在执

行的

低优先级任务,反之低优先级任务却不可打断正在执行的高优先级的任务。

七、实验心得

该实验使我了解了uCOS-II 内核的主要结构,对所学知识有了加深刻的理解和认识,

基本掌握了将uCOS-II 内核移植到ARM920T 处理器上的方法,能够正确完成基本操作得

出正确结果。

大连理工大学实验预习报告

学院(系):电信专业:自动化班级: 0804 姓名:何韬学号:组: ___

实验时间: 2011-11-12 实验室: d108 实验台:

指导教师签字:成绩:

实验二ARM的串行口实验

一、实验目的和要求

1.掌握ARM 的串行口工作原理。

2.学习编程实现ARM 的UART 通讯。

3.掌握CPU 利用串口通讯的方法。

二、实验原理和内容

实验原理:

1.硬件电路图

核心板电路接口:

硬件电路图—MAX3232:

接口连线:

2.异步串行I/O

异步串行方式是将传输数据的每个字符一位接一位(例如先低位、后高位)地传送。数据的各不同位可以分时使用同一传输通道,因此串行I/O 可以减少信号连线,最少用一对线即可进行。接收方对于同一根线上一连串的数字信号,首先要分割成位,再按位组成字符。为了恢复发送的信息,双方必须协调工作。在微型计算机中大量使用异步串行I/O 方式,双方使用各自的时钟信号,而且允许时钟频率有一定误差,因此实现较容易。但是由于每个字符都要独立确定起始和结束(即每个字符都要重新同步),字符和字符间还可能有长度不定的空闲时间,因此效率较低。

图2-1 串行通信字符格式

图2-1 给出异步串行通信中一个字符的传送格式。开始前,线路处于空闲状态,送出连续“1”。传送开始时首先发一个“0” 作为起始位,然后出现在通信线上的是字符的二进制编码数据。每个字符的数据位长可以约定为5 位、6 位、7 位或8 位,一般采用ASCII 编码。后面是奇偶校验位,根据约定,用奇偶校验位将所传字符中为“1”的位数凑成奇数个或偶数个。也可以约定不要奇偶校验,这样就取消奇偶校验位。最后是表示停止位的“1” 信号,这个停止位可以约定持续1 位、位或2 位的时间宽度。至此一个字符传送完毕,线路又进入空闲,持续为“1”。经过一段随机的时间后,下一个字符开始传送才又发出起始位。

每一个数据位的宽度等于传送波特率的倒数。微机异步串行通信中,常用的波特率为50,

95,110,150,300,600,1200,2400,4800,9600,119200 等。接收方按约定的格式接收数据,并进行检查,可以查出以下三种错误: 1)奇偶错:在约定奇偶检查的情况下,接收到的字符奇偶状态和约定不符。 2)帧格式错:一个字符从起始位到停止位的总位数不对。 3)溢出错:若先接收的字符尚未被微机读取,后面的字符又传送过来,则产生溢出错。

每一种错误都会给出相应的出错信息,提示用户处理。

3.ARM 自带的串行口寄存器

ARM 自带两个串行口,各带有16 字节的F IFO(先入先出寄存器),最大波特率。每个UART 有7 种状态:溢出错误、校验错误、帧错误、暂停态、接收缓冲区准备好、发送缓冲区空、发送移位缓冲器空,这些状态可以由相应的UTRSTATn/UERSTATn 表示,并且与发送接收缓冲区相对应的有错误缓冲区。波特率的可以通过控制波特率寄存器(UBRDIVn )控制。

与UART 有关的寄存器主要有以下几个:

(1)UART 线性控制寄存器ULCONn

该寄存器的第6 位决定是否使用红外摸式,位5~3 决定校验方式,位2 决定停止位长度,位1 和0决定每帧的数据位数。

参考:普通模式,无奇偶校验,1位停止位,8为数据长度。

相关文档
最新文档