电脑桌面
添加蜗牛文库到电脑桌面
安装后可以在桌面快捷访问

浙工大 嵌入式实验报告

栏目:合同范文发布:2025-01-30浏览:1收藏

浙工大 嵌入式实验报告

第一篇:浙工大 嵌入式实验报告

金艳霞

通信2班

201203110210

实验五 Linux交叉编译平台

一、实验目的

1.掌握一些基本的linux读写操作 2.利用vcc编译c程序

3.通过nfs挂载到实验箱中,利用交叉编译执行文件

二.实验设备

1.Arm9试验箱 2.Pc机

3.Linux系统服务器

三.实验过程及实验结果 1.连接电脑箱

2.设置交叉编译环境 启动putty.exe 登陆192.168.1.116

3.添加软件包至实验目录: ① [shiyan@localhost ~]$ cd /home/shiyan ② [shiyan@localhost ~]$ tar –zxvf arm-linux-gcc-3.4.4-glib-2.3.5-static.tar.gz tar-zxvf arm-linux-gcc-3.4.4-glib-2.3.5-static.tar.gz ③ [shiyan@localhost201203110210] $export PATH=$PATH:/home/shiyan/201203110210/opt/crosstool/arm-linux/gcc-3.4.4-glib-2.3.5/arm-linux/bin ④ [shiyan@localhost 201203110210]$ set OSTYPE=linux-gnu PATH=/usr/lib/qt-3.3/bin:/usr/kerberos/bin:/usr/local/bin:/bin:/usr/bin:/home/shiyan/bin:/home/shiyan/opt/crosstool/arm-linux/gcc-3.4.4-glibc-2.3.5/arm-linux/bin:/home/shiyan/opt/crosstool/arm-linux/gcc-3.4.4-glibc-2.3.5/arm-linux/bin:/home/shiyan/opt/crosstool/arm-linux/gcc-3.4.4-glibc-2.3.5/arm-linux/bin 可以看出路径已添加 ⑤ [shiyan@localhost 201203110210]$ arm-linux-g再按tab arm-linux-g++

arm-linux-gcc

arm-linux-gcc-3.4.4 arm-linux-gccbug

arm-linux-gcov ⑥ [shiyan@localhost 201203110210]$ arm-linux-gcc arm-linux-gcc: no input files 此时出错,无此文件 3.测试程序 ① 创建hello.c [shiyan@localhost ~]$ vi hello.c #include int main(){ printf(“jin123”);return 0;}

:wq ② 查看是否生成文件

[shiyan@matrix 201203110210]$ ls arm-linux-gcc-3.4.4-glib-2.3.5-static.tar.gz hello.c 已经生成 ③ 打开hello.c [shiyan@localhost ~]$./hello.c-bash:/hello cannot execute binary file 表示无法在服务器上执行 ④ 交叉编译hello.c [shiyan@localhost ~]$ arm-linux-gcc-o hello hello.c ⑤ 将文件拷贝到nfs下

[shiyan@localhost ~]$ cp hello /home/shiyan/nfs ⑥ 挂载服务器到板子上

/ $ mount –tnfs-o nolock 192.168.1.116:/home/shiyan/nfs/mnt/nfs / $cdmnt/nfs ⑦ 打开hello文件 / $./hello

结果输出: Jin 123

四.实验总结

上述实验可以得出,交叉编译的二进制可以在板子上运行,却不能在服务器上运行,很好的认清了交叉编译的意义和功能。

实验六Armboot下载运行及tcp实验

一.实验目的

1.掌握armboot的编译 2.掌握tftp工具的使用 3.掌握armboot下载运行

4.掌握windows的 tcp客户端的建立及通信过程 5.掌握tcp的基本原理

二.实验设备

1.Arm9试验箱 2.Pc机

3.Linux系统服务器

三.实验过程及实验结果 1)Armboot

① 编译armboot-1.1.0 cd /home/shiyan/arm-linux-2.6/armboot-1.1.0 [shiyan@matrix armboot-1.1.0]$ make

② 产生的armboot.bin拷贝到tftp的目录服务下

[shiyan@matrixarmboot-1.1.0]$ cparmboot.bin /home/shiyan/arm-linux-2.6/armboot-1.1.0/tftpboot/armboot ③ 打开arm9开发板,在五秒内按ESC,检查网络环境

CPE>printenv bootdelay=3 baudrate=38400 ethaddr=00:40:25:00:00:01 netmask=255.255.255.0 sererip=192.168.1.65 ipaddr=192.168.1.111 serverip=192.168.1.30

Environment size: 139/131068 bytes ④ 将armboot的网络环境改为tftp服务的网络地址

setenv serverip 192.168.1.220 CPE>saveenv Un-Protected 1 sectors Erasing sector 6...ok.0x800e0000

o Flash...done.Protected 1 sectors

⑤ 将armboot.bin文件通过tftp传输到内存0x2000000H中

CPE>tftp 0x2000000 armboot.bin ARP broadcast 1 ARP broadcast 2

⑥ 运行

go 0x2000000

⑦ 检查网络环境

CPE> printenv bootdelay=3 baudrate=38400 ethaddr=00:40:25:00:00:01 netmask=255.255.255.0 sererip=192.168.1.65 ipaddr=192.168.1.111 serverip=192.168.1.220

通过serverip的改变可看出armboot下载的正确性。

实验七 Mount挂载实验

一.实验目的 1.掌握一些基本的linux读写操作(touch指令)2.掌握Usb挂载方法 3.掌握配置nfs的方法

二.实验设备

1.2.3.4.Arm9试验箱 Pc机

Linux系统服务器 U盘

三.实验过程及实验结果 A.文件夹挂载 1.服务器

[shiyan@matrix ~]$/etc/rc.d/init.d/nfs start 2.板子挂载

/ $ ifconfig eth0 192.168.1.98 / $ mount-t nfs-o nolock 192.168.1.220:/home/shiyan/nfs/mnt/nfs /$ df Filesystem

1k-blocks

Used Available Use% Mounted on /dev/mtdblock1

1024

544

480 53% /mnt/mtd 192.168.1.220:/home/shiyan/nfs 515455456 59590720 429681056 12% /mnt/nfs B.Usb 挂载

① 将u盘插入arm9开发板,并启动 ② 查看盘符信息

/ $ fdisk-l

③ 创建一个/mnt/usb文件夹

/ $ mkdir /mnt/usb ④ 把sda1盘符mount到/mnt/usb文件上

/ $ mount /dev/sda1 /mnt/usb/ / $ cd /mnt/usb /mnt/usb $ ls

⑤ 创建文件,并输入字符串

/mnt/usb $ vi jin.txt

hello!

⑥ 解挂载

/mnt/usb $ unmount /mnt/usb/ /bin/sh: unmount: not found ⑦ 将u盘拔出,插入电脑,观察该文件

结果正确

实验八RTC时钟驱动实验

一.实验目的

1.了解RTC工作原理 2.掌握RTC时钟驱动编程

二.实验内容

1.编写RTC驱动程序

2.通过insmod加载驱动程序 3.编写代码修改RTC内部时间

三.实验设备

1.PC机

2.Arm9实验箱客户端 3.Linux操作系统服务端

四.实验过程及结果

1.实验代码

#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #define DRIVER_VERSION

“0.01” /* Register map */ /* rtc section */ // control and status registers #define REG_CS1 0x00

#define TEST1

(1<<7)

// 0-normal mode, must be set to logic 0 during normal operations;1-EXT_CLK test mode #define STOP

(1<<5)

// 0-RTC source clock runs;1-the RTC clock is stopped(CLKOUT at 32.768KHz is still available)#define TESTC

(1<<3)

// 0-power-on reset(POR)override facility is disable;set to logic 0 for normal operation;1-POR override may be enable #define REG_CS2 0x01 #define TI_TP

(1<<4)

// 0-int is active when TF is active(subject to the status of TIE)#define AF

(1<<3)#define TF

(1<<2)#define AIE

(1<<1)#define TIE

(1<<0)

// Time and date registers #define REG_SC 0x02

// vl_seconds(0-59)#define REG_MN 0x03

// minutes(0-59)#define REG_HR 0x04

// hours(0-23)#define REG_DT 0x05

// days(1-31)#define REG_DW 0x06

// weekdays(0-6)#define REG_MO 0x07

// century_months(1-12)#define REG_YR 0x08

// years(0-99)

// Alarm registers #define REG_MA 0x09

// minute_alarm #define AE_M

(1<<7)#define REG_HA 0x0a

// hour_alarm #define AE_H

(1<<7)#define REG_DA 0x0b

// day_alarm #define AE_D

(1<<7)#define REG_WA 0x0c

// weekday_alarm #define AE_W

(1<<7)// CLKOUT control register #define REG_CC 0x0d #define FE

(1<<7)// Timer registers #define REG_TC 0x0e

// timer_control #define TE

(1<<7)#define REG_TMR 0x0f

// timer #define RTC_SECTION_LEN

/* i2c configuration */ #define I2C_ADDR

0xa2 ///////////////////////////////////////////////////////////// #define DEFAULT_I2C_CLOCKDIV

180//for APB 108MHz staticunsignedlong rtc_status;staticvolatileunsignedlong rtc_irq_data;staticunsignedlong rtc_freq = 1;/*FTRTC010 supports only 1Hz clock*/ staticstruct fasync_struct *rtc_async_queue;static DECLARE_WAIT_QUEUE_HEAD(rtc_wait);extern spinlock_t rtc_lock;MODULE_AUTHOR(“GM Corp.”);MODULE_LICENSE(“GM License”);externint GM_i2c_xfer(struct i2c_msg *msgs, int num, int clockp);/* block read */ staticint i2c_read_regs(u8 reg, u8 buf[], unsigned len){ struct i2c_msg msgs[1];//////////////

buf[0] = reg;

msgs[0].addr = I2C_ADDR>>1;

msgs[0].flags = 0;

msgs[0].len = 1;

msgs[0].buf = buf;

if(GM_i2c_xfer(msgs, 1, DEFAULT_I2C_CLOCKDIV)!= 1)return-1;//////////////

msgs[0].addr = I2C_ADDR>>1;

msgs[0].flags = 1;

msgs[0].len = len+1;

msgs[0].buf = buf;

if(GM_i2c_xfer(msgs, 1, DEFAULT_I2C_CLOCKDIV)!= 1)return-1;return 0;} /* block write */ staticint i2c_set_regs(u8 reg, u8 const buf[], unsigned len){

u8 i2c_buf[10];struct i2c_msg msgs[1];

i2c_buf[0] = reg;

memcpy(&i2c_buf[1], &buf[0], len);

msgs[0].addr = I2C_ADDR>>1;

msgs[0].flags = 0;

msgs[0].len = len+1;

msgs[0].buf = i2c_buf;

if(GM_i2c_xfer(msgs, 1, DEFAULT_I2C_CLOCKDIV)!= 1)return-1;return 0;} staticint set_time(struct rtc_time const *tm){ int sr;

u8 regs[RTC_SECTION_LEN] = { 0, };

printk(“stop RTCn”);

regs[0] = STOP;

regs[1] = 0x00;

// disable interrupt and clear all flags

sr = i2c_set_regs(REG_CS1, regs, 2);if(sr < 0){

// write control and status registers

printk(“%s: stop RTC failedn”, __func__);return sr;

}

printk(“set_time Date(y/m/d):%d/%d/%d Time(h/m/s):%d/%d/%dn”,tm->tm_year,tm->tm_mon,tm->tm_mday,tm->tm_hour,tm->tm_min,tm->tm_sec);

regs[REG_SC-REG_SC] = BIN2BCD(tm->tm_sec);

regs[REG_MN-REG_SC] = BIN2BCD(tm->tm_min);

regs[REG_HR-REG_SC] = BIN2BCD(tm->tm_hour);

regs[REG_DT-REG_SC] = BIN2BCD(tm->tm_mday);

regs[REG_MO-REG_SC] = BIN2BCD(tm->tm_mon);

regs[REG_YR-REG_SC] = BIN2BCD(tm->tm_year-100);

regs[REG_DW-REG_SC] = BIN2BCD(tm->tm_wday & 7);/* write RTC registers */

sr = i2c_set_regs(REG_SC, regs, RTC_SECTION_LEN);if(sr < 0){

printk(“%s: writing RTC section failedn”, __func__);return sr;

}

printk(“start RTCn”);

regs[0] = 0x00;

sr = i2c_set_regs(REG_CS1, regs, 1);if(sr < 0){

// write control and status registers

printk(“%s: start RTC failedn”, __func__);return sr;

}

return 0;

} staticvoid read_time(struct rtc_time *tm){ int sr;

u8 regs[RTC_SECTION_LEN] = { 0, };

sr = i2c_read_regs(REG_SC, regs, RTC_SECTION_LEN);if(sr < 0){

printk(“%s: reading RTC section failedn”, __func__);return;

}

tm->tm_sec = BCD2BIN(regs[REG_SC-REG_SC]&0x7f);

tm->tm_min = BCD2BIN(regs[REG_MN-REG_SC]&0x7f);

tm->tm_hour = BCD2BIN(regs[REG_HR-REG_SC]&0x3f);

tm->tm_mday = BCD2BIN(regs[REG_DT-REG_SC]&0x3f);

tm->tm_wday = BCD2BIN(regs[REG_DW-REG_SC]&0x07);

tm->tm_mon = BCD2BIN(regs[REG_MO-REG_SC]&0x1f);/* rtc starts at 1 */

tm->tm_year = BCD2BIN(regs[REG_YR-REG_SC])+100;

printk(“read_time Date(YY/MM/DD):%d/%d/%d Time(hh/mm/ss):%d/%d/%dn”,tm->tm_year,tm->tm_mon,tm->tm_mday,tm->tm_hour,tm->tm_min,tm->tm_sec);} staticunsigned AIE_stat=0;/*ijsung: arch-indep function*/ staticint rtc_open(struct inode *inode, struct file *file){ if(test_and_set_bit(1, &rtc_status))return-EBUSY;

rtc_irq_data = 0;return 0;} staticint rtc_release(struct inode *inode, struct file *file){ unsignedchar buf[7];

rtc_status = 0;return 0;} staticint rtc_fasync(int fd, struct file *filp, int on){ return fasync_helper(fd, filp, on, &rtc_async_queue);} staticunsignedint rtc_poll(struct file *file, poll_table *wait){

poll_wait(file, &rtc_wait, wait);return(rtc_irq_data)? 0 : POLLIN | POLLRDNORM;} static loff_t rtc_llseek(struct file *file, loff_t offset, int origin){ return-ESPIPE;} ssize_t rtc_read(struct file *file, char *buf, size_t count, loff_t *ppos){

DECLARE_WAITQUEUE(wait, current);unsignedlong data;

ssize_t retval;if(count

add_wait_queue(&rtc_wait, &wait);

set_current_state(TASK_INTERRUPTIBLE);for(;;){

spin_lock_irq(&rtc_lock);

data = rtc_irq_data;if(data!= 0){

rtc_irq_data = 0;break;

}

spin_unlock_irq(&rtc_lock);if(file->f_flags & O_NONBLOCK){

retval =-EAGAIN;goto out;

} if(signal_pending(current)){

retval =-ERESTARTSYS;goto out;

}

schedule();

}

spin_unlock_irq(&rtc_lock);

data-= 0x100;/* the first IRQ wasn't actually missed */

retval = put_user(data,(unsignedlong *)buf);if(!retval)

retval = sizeof(unsignedlong);out:

set_current_state(TASK_RUNNING);

remove_wait_queue(&rtc_wait, &wait);return retval;} staticint rtc_ioctl(struct inode *inode, struct file *file, unsignedint cmd, unsignedlong arg){ struct rtc_time tm, tm2;unsignedchar buf[7];switch(cmd){ case RTC_AIE_OFF:

printk(“Not Supportn”);return 0;case RTC_AIE_ON:

printk(“Not Supportn”);return 0;case RTC_ALM_READ:

printk(“Not Supportn”);return 0;case RTC_ALM_SET:

printk(“Not Supportn”);return 0;case RTC_RD_TIME:

read_time(&tm);break;

case RTC_SET_TIME:

{ unsigned usertime;unsignedchar buf[7];if(!capable(CAP_SYS_TIME))return-EACCES;if(copy_from_user(&tm,(struct rtc_time*)arg, sizeof(tm)))return-EFAULT;

set_time(&tm);

} return 0;case RTC_IRQP_READ: return put_user(rtc_freq,(unsignedlong *)arg);case RTC_IRQP_SET: if(arg!= 1)return-EINVAL;return 0;case RTC_EPOCH_READ: return put_user(1970,(unsignedlong *)arg);default: return-EINVAL;

} return copy_to_user((void *)arg, &tm, sizeof(tm))?-EFAULT : 0;} staticstruct file_operations rtc_fops = {

owner:

THIS_MODULE,llseek:

rtc_llseek,read:

rtc_read,poll:

rtc_poll,ioctl:

rtc_ioctl,open:

rtc_open,release: rtc_release,fasync:

rtc_fasync, };staticstruct miscdevice ftrtc010rtc_miscdev = {

RTC_MINOR,“rtc”, &rtc_fops };staticint rtc_read_proc(char *page, char **start, off_t off, int count, int *eof, void *data){ // unsigned alarm_time;unsignedchar buf[7];

char *p = page;int len;struct rtc_time tm;

read_time(&tm);//printk(“RTC...%dn”,xtime.tv_sec);

p += sprintf(p, “rtc_timet: %02d:%02d:%02dn”

“rtc_datet: %04d-%02d-%02dn”

“rtc_epocht: %04dn”,tm.tm_hour + 1, tm.tm_min, tm.tm_sec,tm.tm_year + 1900, tm.tm_mon + 1, tm.tm_mday, 2000);// read_alarm(&tm);// p += sprintf(p, “alrm_timet: %2dth day of week dayn” //

“alrm_datet: N/A for Platformn”, //

tm.tm_wday);

p += sprintf(p, “alrm_timet: Not Supportn”

“alrm_datet: Not Supportn”);

p += sprintf(p, “alarm_IRQt: %sn”, AIE_stat ? “yes” : “no”);

len =(poff;if(len < 0)

len = 0;

*eof =(len <= count)? 1 : 0;

*start = page + off;return len;} staticint __init rtc_init(void){

misc_register(&ftrtc010rtc_miscdev);

create_proc_read_entry(“driver/rtc”, 0, 0, rtc_read_proc, NULL);

printk(“PCF8563 Real Time Clock drivern”);return 0;} staticvoid __exit rtc_exit(void){

remove_proc_entry(“driver/rtc”, NULL);

misc_deregister(&ftrtc010rtc_miscdev);} module_init(rtc_init);module_exit(rtc_exit);

2.挂载usb / $ ifconfig eth0 192.168.1.99 / $ mount-t nfs-o nolock 192.168.1.220:/home/shiyan/nfs /mnt/nfs / $ fdisk –l / $ mkdir /mnt/usb / $ mount /dev/sda1 /mnt/usb/ / $ cd /mnt/usb

3.找到u盘中的pcf8563.ko /mnt/usb $ ls

4.加载pcf8563.ko /mnt/usb $ insmod pcf8563.ko

5.更改日期并写入

6.重启检验日期

与当前时间相符

实验九视频采集RTP发送及远程视频监控实验

一.实验目的 1.理解视频传输原理

2.掌握在IP网络中实现视频传输的方法 3.理解远程控制原理

4.掌握在windows下TCP客户端建立及通信过程

二.实验内容

1.搭建点对点视频传输模式 2.开启视频采集

3.开启Windows下tcp客户端,完成控制命令

三.实验设备

1.硬件:基于双核处理器架构的网络音视频传输教学实验系统;

对接线; 串口连接线; 网线;

集线器(HUB),PC机;

2.软件:H.264流媒体软件

设备端视频采集程序 设备端视频传输程序 串口操作软件

四.实验步骤及结果 A.视频采集

1.连接好实验箱,打开串口通信端,远程mount到home/nfs文件夹 / $ mount-t nfs-o nolock 192.168.1.116:/home/shiyan/nfs /mnt/nfs 2.挂载服务器下nfs与板子的/mnt/nfs,进入/mnt/nfs文件夹 / $ cd /mnt/nfs 3.输入ls命令,目录下文件 /mnt/nfs $ ls 123321

clientxxww

readme

tcpserver StartLog0

ffgpio.ko

server

tcpserver19 a

gpio_test

serverfxf

tcpserver_arm_11 bo

hello

serverxw

tcpserver_hdt client

nfs1

tcpclient

tcpserver_zn client_arm

ok

tcpclient19

tcpsever client_arm_17

program_20_1.c

tcpclient_29

tw2835_menu client_arm_st20

program_20_2.c

tcpclient_arm_11 xianshi client_dalan

programyk

tcpclient_hdt

yk clientxw

programyq

tcpclient_zn

yq 4.运行tw2835_menu进行视频采集 /mnt/nfs $./tw2835_menu&

5.进入挂载目录并查看文件 /mnt/nfs $ cd nfs1 /mnt/nfs/nfs1 $ ls dev_app.app

hello

vedio.confTCPS1

dev_app3

ffgpio.ko

tw2835_menu dev_app

gpio_test

tw2835_pic 6.运行dev_app到板子IP192.168.1.9 /mnt/nfs/nfs1 $./dev_app 192.168.1.9 7.开启H.264流媒体播放器进行视频接受 a)用解码器解码,并允许注册.bat

b)打开H.264流媒体播放器,点击开启视频接收

B.远程视频监控

1.重复以上实验1~4步

2.进入已挂载目录/mnt/nfs/nfs1,看到多个程序 /mnt/nfs $ cd nfs1 /mnt/nfs/nfs1 $ ls StartLog0

dev_app.app

hello

vedio.conf TCPS1

dev_app3

image.info

www boot.sh

ffgpio.ko

tw2835_menu 3.运行TCPS1 /mnt/nfs/nfs1 $./ TCPS1 4.程序进入等待状态,等待TCP连接到来

5.开启H.264流媒体播放器,点击“开始视频接收”,屏幕变黑

6.点击“控制功能”,输入设备端ip地址192.168.1.68,点击连接

7.设备端出现下列字样,表示连接成功

Servergetconnectionfrom192.168.1.68 8.点击“开启视频监控”,获得视频数据

实验十一Tcp网络编程

一、实验目的

1.了解网络编程原理 2.了解套接字的使用

二、实验原理

嵌入式Linux的网络通信程序是基于套接字模式的。Socket实际是网络传输层供给应用层的接口。常见的Socket有三种类型。1.流式Sockct 流式套接字提供可靠的,面向连接的通信流,它使用TCP协议,从而保证了数据传输的正确性和顺序性。Socket编程采用客户/服务器模式。因此编程分为服务器端和客户端。服务器端:首先建立Socket,返回该Socket的描述符;配置Socket的端口和IP地址;建立监听函数,检测是否有客户端向服务器端发送请求,若有则接收该请求,将其放到接收队列中;从接收队列中接收一个请求;并向客户端发送确认连接信息。客户端:建立一个Socket,返回该Socket的描述符,配置Socket端口和IP地址;向服务器发送连接请求,并接收服务器发回的确认连接信息。双方通信结束后,关闭其Socket。2.数据报Socket,数据通过相互独立的报文进行传输,数据报套接字定义了一种无连接的服务,是无序的,并且不保证是可靠的,无差错的。它使用数据报协议UDP。3.原始Socket 使用Socket编程时可以开发客户机和服务器端应用程序,它们可以在本地网络上进行通信,也可以通过Internet在全球范围内进行通信。编写并运行Socket的客户端和服务器端程序,双方通过套接字建立了服务连接请求,并且通过一些方法提高Socket的性能。

三、实验步骤

编写服务器端源程序和客户端源程序

1.代码:

program_20_1.c #include #include #include #include #include #include #include #include #include #include #include #include

int main(int argc, char *argv[]){

int sockfd,new_fd;

struct sockaddr_in server_addr;

struct sockaddr_in client_addr;

int portnumber;

const char hello[]=“Hello and Byen”;// for setsockopt()SO_REUSEADDR, below

int yes = 1;int addrlen;

if(argc!=2)

{

fprintf(stderr,“Usage:%s portnumberan”,argv[0]);

exit(1);

}

if((portnumber=atoi(argv[1]))<0)

{

fprintf(stderr,“Usage:%s portnumberan”,argv[0]);

exit(1);

}

/* 服务器端开始建立socket描述符 */

if((sockfd=socket(AF_INET,SOCK_STREAM,0))==-1)

{

fprintf(stderr,“Socket error:%sna”,strerror(errno));

exit(1);

}

printf(“Server-socket()is OK...n”);

// “address already in use” error message

if(setsockopt(sockfd, SOL_SOCKET, SO_REUSEADDR, &yes,sizeof(int))==-1)

{

perror(“Server-setsockopt()error lol!”);

exit(1);

}

printf(“Server-setsockopt()is OK...n”);

/* 服务器端填充 sockaddr结构 */

bzero(&server_addr,sizeof(struct sockaddr_in));

server_addr.sin_family=AF_INET;

server_addr.sin_addr.s_addr=htonl(INADDR_ANY);

server_addr.sin_port=htons(portnumber);

memset(&(server_addr.sin_zero), '', 8);

/* 捆绑sockfd描述符 */

if(bind(sockfd,(struct sockaddr *)(&server_addr),sizeof(struct sockaddr))==-1)

{

fprintf(stderr,“Bind error:%sna”,strerror(errno));

exit(1);

}

printf(“Server-bind()is OK...n”);

/* 监听sockfd描述符 */

if(listen(sockfd,5)==-1)

{

fprintf(stderr,“Listen error:%sna”,strerror(errno));

exit(1);

}

printf(“Server-listen()is OK...n”);

while(1)

{

/* 服务器阻塞,直到客户程序建立连接 */

addrlen = sizeof(client_addr);

if((new_fd=accept(sockfd,(struct sockaddr *)(&client_addr),&addrlen))==-1)

{

printf(“Accept error:%sna”,strerror(errno));

exit(1);

}else{

printf(“Server-accept()is OK...n”);}

printf(“New connection from %s on socket %dn”, inet_ntoa(client_addr.sin_addr), new_fd);

if(write(new_fd,hello,strlen(hello))==-1)

{

printf(“Write Error:%sn”,strerror(errno));

exit(1);

}else{ printf(“Write something to the client, then close it.n”);

} close(new_fd);

}

close(sockfd);

exit(0);} program_20_2.c

/TCPClient示例/ #include #include #include #include #include #include #include #include

int main(int argc, char *argv[]){

int sockfd;

char buffer[1024];

struct sockaddr_in server_addr;struct hostent *host;int portnumber,nbytes;if(argc!=3){

fprintf(stderr,“Usage:%s hostname portnumberan”,argv[0]);

exit(1);}

if((host=gethostbyname(argv[1]))==NULL){

herror(“Get host name errorn”);

exit(1);}

if((portnumber=atoi(argv[2]))<0){

fprintf(stderr,“Usage:%s hostname portnumberan”,argv[0]);

exit(1);}

/* 客户程序开始建立 sockfd描述符 */

if((sockfd=socket(AF_INET,SOCK_STREAM,0))==-1){

fprintf(stderr,“Socket Error:%san”,strerror(errno));

exit(1);}

/* 客户程序填充服务端的资料 */ bzero(&server_addr,sizeof(server_addr));server_addr.sin_family=AF_INET;

server_addr.sin_port=htons(portnumber);

server_addr.sin_addr=*((struct in_addr *)host->h_addr);/* 客户程序发起连接请求 */

if(connect(sockfd,(struct sockaddr *)(&server_addr),sizeof(struct sockaddr))==-1){

fprintf(stderr,“Connect Error:%san”,strerror(errno));

exit(1);}

/* 连接成功了 */

if((nbytes=read(sockfd,buffer,1024))==-1){

fprintf(stderr,“Read Error:%sn”,strerror(errno));

exit(1);}

buffer[nbytes]='';

printf(“I have received:%sn”,buffer);/* 结束通讯 */ close(sockfd);exit(0);} 2.步骤

① 交叉编译服务端程序

[shiyan@matrix ~]$ cd /home/shiyan [shiyan@localhost ~]$ gcc-o clientjin program_20_1.c [shiyan@localhost ~]$ arm-linux-gcc-o serverjin program_20_2.c [shiyan@localhost ~]$ cp /home/shiyan/serverjin /home/shiyan/nfs

② 执行

[shiyan@localhost ~]$./clientjin 3456

③ 打开实验箱,并挂载 / $ ifconfig eth0 192.168.1.55 up / $ ping 192.168.1.116 / $ mount-t nfs-o nolock 192.168.1.116:/home/shiyan/nfs /mnt/nfs / $ cd mnt/nfs /mnt/nfs $ ls

④ 执行客户端程序

/mnt/nfs $./serverjin 192.168.1.116 3456

接受到数据,实验成功

实验十二 WEB服务器程序

一. 实验目的

1.掌握httpd工具制作web服务器的基本流程 2.掌握实验设备的连接和调试

二. 实验内容

1.运行实验箱

2.通过路由器将实验箱和pc机连接

3.在pc机上运行浏览器,看是否运行网页服务器

三.实验设备

1.Pc机

2.嵌入式实验箱 3.Pc机操作系统

四.实验步骤

1.连接好实验箱,挂载nfs文件

/ $ ifconfig eth0 192.168.1.55 / $ ping 192.168.1.116 / $ mount-t nfs-o nolock 192.168.1.116:/home/shiyan/nfs /mnt/nfs 3.进入nfs1/www文件夹查看可执行文件thttpd / $ cd mnt/nfs/nfs1 /mnt/nfs /nfs1 $ ls /mnt/nfs /nfs1/www $ ls

4.运行web服务器

/mnt/nfs /nfs1/www $./thttpd –c./thttpd.conf /mnt/nfs /nfs1/www $ cd thttpd/ /mnt/nfs /nfs1/www/thttpd $ ls

5.查看网络文件

/mnt/nfs /nfs1/www/thttpd $ cd html /mnt/nfs /nfs1/www/thttpd/html $ ls /mnt/nfs /nfs1/www/thttpd/html $ cat index.html

6.打开浏览器输入192.168.1.55,进入web页面

第二篇:嵌入式实验报告

目录

实验一 跑马灯实验.........................................................................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的软件仿真功能。

实验二 按键输入实验

一.实验简介

在实验一的基础上,使用按键控制流水灯速度,及使用按键控制流水灯流水方向。

二.实验目的

熟练使用库函数操作GPIO,掌握中断配置和中断服务程序编写方法,掌握通过全局变量在中断服务程序和主程序间通信的方法。

三.实验内容

实现初始化GPIO,并配置中断,在中断服务程序中通过修改全局变量,达到控制流水灯速度及方向。

使用JLINK下载代码到目标板,查看运行结果,使用JLINK在线调试。

四.实验设备

硬件部分:PC计算机(宿主机)、亮点STM32实验板、JLINK、示波器。软件部分:PC机WINDOWS系统、MDK KEIL软件、ISP软件。

五.实验步骤

1在实验1代码的基础上,编写中断初始化代码

2在主程序中声明全局变量,用于和中断服务程序通信,编写完成主程序 3编写中断服务程序

4编译代码,使用JLINK下载到实验板 5.单步调试

6记录实验过程,撰写实验报告

六.实验结果及测试

源代码:

我们将通过MiniSTM32 板上载有的3个按钮,来控制板上的2个LED,其中KEY0控制LED0,按一次亮,再按一次,就灭。KEY1 控制LED1,效果同KEY0。KEY_2(KEY_UP),同时控制LED0 和LED1,按一次,他们的状态就翻转一次。

七.实验总结

通过本次实验,我学会了如何使用STM32 的IO 口作为输入用。TM32 的IO 口做输入使用的时候,是通过读取IDR 的内容来读取IO 口的状态的。这里需要注意的是 KEY0 和KEY1 是低电平有效的,而WK_UP 是高电平有效的,而且要确认WK_UP 按钮与DS18B20 的连接是否已经断开,要先断开,否则DS18B20 会干扰WK_UP按键!并且KEY0 和KEY1 连接在与JTAG 相关的IO 口上,所以在软件编写的时候要先禁用JTAG 功能,才能把这两个IO 口当成普通IO 口使用。

实验三 串口实验

一.实验简介

编写代码实现串口发送和接收,将通过串口发送来的数据回送回去。

二.实验目的

掌握STM32基本串口编程,进一步学习中断处理。

三.实验内容

编写主程序,初始化串口1,设置波特率为9600,无校验,数据位8位,停止位1位。编写中断服务程序代码实现将发送过来的数据回送。

四.实验设备

硬件部分:PC计算机(宿主机)、亮点STM32实验板、JLINK、示波器。

软件部分:PC机WINDOWS系统、MDK KEIL软件、ISP软件、串口调试助手。

五.实验步骤

1编写串口初始化代码

2编写中断服务程序代码

3编译代码,使用JLINK或ISP下载到实验板 4记录实验过程,撰写实验报告

六.实验结果及测试

源代码:

把代码下载到 MiniSTM32 开发板,可以看到板子上的LED0 开始闪烁,说明程序已经在跑了。接着我们打开串口调试助手,看到如下信息:

证明串口数据发送没问题。接着,我们在发送区输入上面的文字,输入完后按回车键。然后单击发送,可以得到如下结果:

七.实验总结

通过本次实验,我进一步了解了串口的使用,学会了通过串口发送和接收数据,将通过串口发送来的数据回送回去。该实验的硬件配置不同于前两个实验,串口 1 与USB 串口默认是分开的,并没有在PCB上连接在一起,需要通过跳线帽来连接一下。这里我们把P4 的RXD 和TXD 用跳线帽与P3 的PA9 和PA10 连接起来。

实验四 外部中断实验

一.实验简介

STM32 的 IO 口在本章第一节有详细介绍,而外部中断在第二章也有详细的阐述。这里我们将介绍如何将这两者结合起来,实现外部中断输入。

二.实验目的

进一步掌握串口编程,进一步学习外部中断编程,提高编程能力。

三.实验内容

初始化IO口的输入,开启复用时钟,设置IO与中断的映射关系,从而开启与IO口相对应的线上中断事件,设置触发条件。配置中断分组(NVIC),并使能中断,编写中断服务函数。

四.实验设备

硬件部分:PC计算机(宿主机)、亮点STM32实验板、JLINK、示波器。

软件部分:PC机WINDOWS系统、MDK KEIL软件、ISP软件、串口调试助手。

五.实验步骤

1.2.3.4.编写中断服务程序代码 使用ISP下载到实验板 测试运行结果

记录实验过程,撰写实验报告

六.实验结果及测试

源代码:

打开串口助手。

七.实验总结

首先需要将IO设置为中断输入口: 1)初始化 IO 口为输入。

2)开启 IO 口复用时钟,设置 IO 口与中断线的映射关系。

3)开启与该 IO口相对的线上中断/事件,设置触发条件。

4)配置中断分组(NVIC),并使能中断。

5)编写中断服务函数。

这一节,使用的是中断来检测按键,通过 WK_UP 按键实现按一次 LED0 和 LED 1 同时翻转,按 KEY0 翻转 LED0,按 KEY1 翻转 LED1。

试验中外部中断函数不能进入的原因分析 : 1)GPIO或者AFIO的时钟没有开启。2)GPIO和配置的中断线路不匹配。3)中断触发方式和实际不相符合。

4)中断处理函数用库函数时,写错,经常可能出现数字和字母之间没有下划线。5)外部中断是沿触发,有可能不能检测到沿,比如 中断线是低电平(浮空输入),触发是下降沿触发,可能会出现一直是低电平,高电平的时候是一样的情况,电平持续为高电平。

6)没有用软件中断来触发外部中断,调用函数EXTI_GenerateSWInterrupt;,因为软件中断先于边沿中断处理。

实验五 独立看门狗实验

一. 实验简介

独立看门狗(IWDG)由专用的低速时钟(LSI)驱动,即使主时钟发生故障它也仍然有效。窗口看门狗由从APB1时钟分频后得到的时钟驱动,通过可配置的时间窗口来检测应用程序非正常的过迟或过早的操作。

二.实验目的

通过编程,编写一个独立看门狗驱动程序

三.实验内容

启动 STM32 的独立看门狗,从而使能看门狗,在程序里面必须间隔一定时间喂狗,否则将导致程序复位。利用这一点,我们本章将通过一个 LED 灯来指示程序是否重启,来验证 STM32 的独立看门狗。

四.实验设备

硬件部分:PC计算机(宿主机)、亮点STM32实验板、JLINK。

软件部分:PC机WINDOWS系统、MDK KEIL软件、ISP软件、串口调试助手。

五.实验步骤

1.2.3.4.参考教材独立看门狗部分,编写独立看门狗驱动程序。建立和配置工程 编写代码

使用ISP下载到实验板

记录实验过程,撰写实验报告

六.实验结果及测试

源代码:

在配置看门狗后,看到LED0 不停的闪烁,如果WK_UP 按键按下,就喂狗,只要WK_UP 不停的按,看门狗就一直不会产生复位,保持LED0 的常亮,一旦超过看门狗定溢出时间(Tout)还没按,那么将会导致程序重启,这将导致LED0 熄灭一次。

七.实验总结

通过本次实验,我掌握了启动独立看门狗的步骤: 1)向 IWDG_KR 写入 0X5555。2)向 IWDG_KR 写入 0XAAAA。3)向 IWDG_KR 写入 0XCCCC。

通过上面 3个步骤,启动 STM32 的看门狗,从而使能看门狗,在程序里面就必须间隔一定时间喂狗,否则将导致程序复位。利用这一点,本章通过一个LED 灯来指示程序是否重启,来验证 STM32 的独立看门狗。在配置看门狗后,LED0 将常亮,如果 WK_UP 按键按下,就喂狗,只要 WK_UP 不停的按,看门狗就一直不会产生复位,保持 LED 0 的常亮,一旦超过看门狗溢出时间(Tout)还没按,那么将会导致程序重启,这将导致 LED 0 熄灭一次。

实验七 定时器中断实验

一. 实验简介

STM32 的定时器是一个通过可编程预分频器(PSC)驱动的 16 位自动装载计数器(CNT)构成。STM32 的通用定时器可以被用于:测量输入信号的脉冲长度(输入捕获)或者产生输出波形(输出比较和 PWM)等。使用定时器预分频器和 RCC 时钟控制器预分频器,脉冲长度和波形周期可以在几微秒到几毫秒间调整。STM32 的每个通用定时器都是完全独立的,没有互相共享的任何资源。

二.实验目的

熟练掌握定时器中断,学会对定时器中断的编程操作。

三.实验内容

使用定时器产生中断,然后在中断服务函数里面翻转 LED1 上的电平,来指示定时器中断的产生,修改中断时间。

四.实验设备

硬件部分:PC计算机(宿主机)、亮点STM32实验板、JLINK。

软件部分:PC机WINDOWS系统、MDK KEIL软件、ISP软件、串口调试助手。

五.实验步骤

1.参考教材定时器中断部分,编写定时器中断的驱动程序。2.编写主程序

3.编译代码,使用JLINK或ISP下载到实验板 4.记录实验过程,撰写实验报告

六.实验结果及测试

源代码:

七.实验总结

通过本次实验,认识到时间中断来控制LED灯的闪烁,同时也可以将时间中断应用到控制其他的程序块。

以TIME3为例产生中断的步骤为 1)TIM3 时钟使能。

2)设置 TIM3_ARR 和 TIM3_PSC 的值。

3)设置 TIM3_DIER 允许更新中断。

4)允许 TIM3 工作。

5)TIM3 中断分组设置。6)编写中断服务函数。

在中断产生后,通过状态寄存器的值来判断此次产生的中断属于什么类型。然后执行相关的操作,我们这里使用的是更新(溢出)中断,所以在状态寄存器 SR 的最低位。在处理完中断之后应该向 TIM3_SR 的最低位写 0,来清除该中断标志。

实验十三 ADC实验

一.实验简介

通过DAC将STM32系统的数字量转换为模拟量。使用ADC将模拟量转换为数字量。

二.实验目的

掌握DAC和ADC编程。

三.实验内容

编写代码实现简单的DAC单次发送

编写代码实现ADC采集DAC发送的数据,并发送到串口

四.实验设备

硬件部分:PC计算机(宿主机)、亮点STM32实验板、JLINK。

软件部分:PC机WINDOWS系统、MDK KEIL软件、ISP软件、串口调试助手。

五.实验步骤

1编写主程序

2编译代码,使用JLINK或ISP下载到实验板,使用串口调试助手观察数据 3记录实验过程,撰写实验报告

六.实验结果及测试

源代码:

七.实验总结

本节将利用 STM32的 ADC1 通道 0 来采样外部电压值,并在串口调试助手中显示出来。步骤如下:

1)开启 PA 口时钟,设置 PA0 为模拟输入。

2)使能 ADC1 时钟,并设置分频因子。

3)设置 ADC1 的工作模式。

4)设置 ADC1 规则序列的相关信息。

5)开启 AD 转换器,并校准。

6)读取 ADC 值。

在上面的校准完成之后,ADC 就算准备好了。接下来我们要做的就是设置规则序列 0 里面的通道,然后启动 ADC 转换。在转换结束后,读取 ADC1_DR 里面的值。

通过以上几个步骤的设置,可以正常的使用 STM32 的 ADC1 来执行 AD 转换操作。

通过本次实验的学习,我们了解了STM32 ADC的使用,但这仅仅是STM32强大的ADC 功能的一小点应用。STM32 的ADC 在很多地方都可以用到,其ADC 的DMA 功能是很不错的,实验十五 DMA实验

一. 实验简介

直接存储器存取(DMA)用来提供在外设和存储器之间或者存储器和存储器之间的高速数据传输。无须CPU干预,数据可以通过DMA快速地移动,这就节省了CPU的资源来做其他操作。

二.实验目的

熟练掌握DMA编程,学会对EPC02的读写操作,学习双缓冲兵乓操作,理解互斥资源。提高编程能力。

三.实验内容

利用外部按键KEY0 来控制DMA 的传送,每按一次KEY0,DMA 就传送一次数据

到USART1,然后在串口调试助手观察进度等信息。LED0 还是用来做为程序运行的指示灯。

这里我们使用到的硬件资源如下: 1)按键KEY0。2)指示灯LED0。

3)使用串口调试助手观察数据

四.实验设备

硬件部分:PC计算机(宿主机)、亮点STM32实验板、JLINK。

软件部分:PC机WINDOWS系统、MDK KEIL软件、ISP软件、网络调试助手。

五.实验步骤

1编写主程序

2编译代码,使用JLINK或ISP下载到实验板,使用串口调试助手观察数据 3记录实验过程,撰写实验报告

六.实验结果及测试

源代码:

伴随 LED0 的不停闪烁,提示程序在运行。我们打开串口调试助手,然后按KEY0,可以看到串口显示如下内容:

七.实验总结

本节利用 STM32 的 DMA 来实现串口数据传送,DMA通道的配置需要: 1)设置外设地址。

2)设置存储器地址。

3)设置传输数据量。

4)设置通道 4 的配置信息。

5)使能 DMA1 通道 4,启动传输。

通过以上 5 步设置,我们就可以启动一次 USART1 的 DMA 传输了。

DMA控制器对DMA请求判别优先级及屏蔽,向总线裁决逻辑提出总线请求。当CPU执行完当前总线周期即可释放总线控制权。此时,总线裁决逻辑输出总线应答,表示DMA已经响应,通过DMA控制器通知I/O接口开始DMA传输。

DMA控制器获得总线控制权后,CPU即刻挂起或只执行内部操作,由DMA控制器输出读写命令,直接控制RAM与I/O接口进行DMA传输。

在DMA控制器的控制下,在存储器和外部设备之间直接进行数据传送,在传送过中不需要中央处理器的参与。开始时需提供要传送的数据的起始位置和数据长度。

当完成规定的成批数据传送后,DMA控制器即释放总线控制权,并向I/O接口发出结束信号。当I/O接口收到结束信号后,一方面停 止I/O设备的工作,另一方面向CPU提出中断请求,使CPU从不介入的状态解脱,并执行一段检查本次DMA传输操作正确性的代码。最后,带着本次操作结果及状态继续执行原来的程序。

由此可见,DMA传输方式无需CPU直接控制传输,也没有中断处理方式那样保留现场和恢复现场的过程,通过硬件为RAM与I/O设备开辟一条直接传送数据的通路,使CPU的效率大为提高。

实验十六 I2C实验

一.实验简介

编程实现对使用I2C接口的EPC02芯片进行写和读操作。

二.实验目的

熟练掌握I2C编程,学会对EPC02的读写操作。

三.实验内容

编写I2C驱动程序,使用驱动程序初始化EPC02,判断设备正确性。

写256个0x5A到EPC02,读出并发送给串口,通过串口调试助手判别是否读到的都是0x5A.四.实验设备

硬件部分:PC计算机(宿主机)、亮点STM32实验板、JLINK。

软件部分:PC机WINDOWS系统、MDK KEIL软件、ISP软件、串口调试助手。

五.实验步骤

1参考教材I2C部分,编写I2C驱动程序。2编写主程序

3编译代码,使用JLINK或ISP下载到实验板 4记录实验过程,撰写实验报告

六.实验结果及测试

伴随 LED0 的不停闪烁,提示程序在运行。我们先按下KEY0,可以看到如下所示的内容,证明数据已经被写入到24C02了。

接着我们按KEY2,可以看我们刚刚写入的数据被显示出来了,如下图所示:

源代码:

七.实验总结

IIC是由数据线 SDA 和时钟 SCL 构成的串行总线,可发送和接收数据。在 CPU 与被控 IC 之间、IC 与 IC 之间进行双向传送,高速 IIC 总线一般可达 400kbps 以上。

IIC总线在传送数据过程中共有三种类型信号,它们分别是:开始信号、结束信号和应答信号。这些信号中,起始信号是必需的,结束信号和应答信号,都可以不要。程序在开机的时候会检测 24C02 是否存在,如果不存在则会在TFTLCD 模块上显示错误信息,同时LED0 慢闪。大家可以通过跳线帽把PC11 和PC12 短接就可以看到报错了。通过本次实验,我掌握了如何使用IIC写入与读出数据,学习了编写I2C驱动程序,使用驱动程序初始化EPC02,判断设备正确性,以及如何在助手上显示。

实验十七 SPI实验

一.实验简介

编程实现对SPI接口的W25Q64进行读写操作。

二.实验目的

熟练掌握SPI编程,学会对的W25Q64读写操作。

三.实验内容

1.2.3.4.5.编写SPI驱动程序 初始化SPI接口

读取SPIFLASH的ID,如果正确继续,否则报错

向SPIFALSH地址0x12AB00开始写一串字符,再读出比较判断是否与写入的一致 向SPIFALSH地址0x12AB00开始写连续256个字节的0x5A,然后读出并发送给串口,通过串口调试助手判别是否读到的都是0x5A.四.实验设备

硬件部分:PC计算机(宿主机)、亮点STM32实验板、JLINK。

软件部分:PC机WINDOWS系统、MDK KEIL软件、ISP软件、串口调试助手。

五.实验步骤

1参考SPI及SPI FLASH部分,编写SPI及SPI FLASH驱动程序(可参考书上代码)。2编写主程序

3编译代码,使用JLINK或ISP下载到实验板 4记录实验过程,撰写实验报告

六.实验结果及测试

源代码:

伴随 LED0 的不停闪烁,提示程序在运行。我们先按下KEY0,可以看到如图13.17.4.2 所示的内容,证明数据已经被写入到W25X16了。

接着我们按KEY2,可以看我们刚刚写入的数据被显示出来了,如下图所示:

七.实验总结

SPI 接口主要应用在EEPROM,FLASH,实时时钟,AD 转换器,还有数字信号处理器和数字信号解码器之间。SPI,是一种高速的,全双工,同步的通信总线,并且在芯片的管脚上只占用四根线,节约了芯片的管脚,同时为 PCB 的布局上节省空间,提供方便,正是出于这种简单易用的特性,现在越来越多的芯片集成了这种通信协议,STM32 也有 SPI 接口。

SPI 的设置步骤:

1)配置相关引脚的复用功能,使能 SPI时钟。

2)设置 SPI 工作模式。

3)使能 SPI。

程序在开机的时候会检测 W25X16 是否存在,如果不存在则会在TFTLCD 模块上显示错误信息,同时LED0 慢闪。大家可以通过跳线帽把PA5 和PA6 短接就可以看到报错了。通过本实验,我掌握了编写SPI程序写入和读取FLASH的方法,掌握了对学会对的W25Q64读写操作。对STM32开发板有了进一步的了解。

实验二十一 红外遥控实验

一. 实验简介

编程实现通过在 ALIENTEK MiniSTM32 开发板上实现红外遥控器的控制。

二.实验目的

掌握编程实现红外遥控控制开发板的方法。

三.实验内容

1.编写红外遥控驱动程序 2.编写红外遥控程序代码 3.使用红外遥控控制开发板

四.实验设备

硬件部分:PC计算机(宿主机)、亮点STM32实验板、JLINK。软件部分:PC机WINDOWS系统、MDK KEIL软件、ISP软件。

五.实验步骤

4.编写红外遥控驱动程序 5.编写红外遥控程序代码

6.编译代码,使用JLINK或ISP下载到实验板 7.记录实验过程,撰写实验报告

六.实验结果及测试

源代码:

使用串口调试助手观察数据

七.实验总结

红外遥控是一种无线、非接触控制技术,具有抗干扰能力强,信息传输可靠,功耗低,成本低,易实现等显著优点,被诸多电子设备特别是家用电器广泛采用,并越来越多的应用到计算机系统中。

通过本节实验,我学习到了如何编程使用红外遥控控制,在本程序中只是简单地输出一个数值,在以后的应用中可以实现更强大的功能,比如用红外远程输入控制开发板进行一些操作。对STM32有了进一步的认识。

实验二十二 DS18B20实验

一. 实验简介

一. 在ALIENTEK MiniSTM32 开发板上,通过 DS18B20 来读取环境温度值。

二.实验目的

巩固SPI编程。掌握使用感应器获取环境温度的方法。

三.实验内容

1.复位脉冲和应答脉冲

2.写时序

3.读时序

四.实验设备

硬件部分:PC计算机(宿主机)、亮点STM32实验板、JLINK。软件部分:PC机WINDOWS系统、MDK KEIL软件、ISP软件。

五.实验步骤

1.2.3.4.参考教材DS18B20编程部分,编写DS18B20驱动程序 编写主程序

编译代码,使用JLINK或ISP下载到实验板 记录实验过程,撰写实验报告

六.实验结果及测试

源代码:

使用串口调试助手观察数据:

七.实验总结

DS18B20 是由 DALLAS 半导体公司推出的一种的“一线总线”接口的温度传感器。与传统的热敏电阻等测温元件相比,它是一种新型的体积小、适用电压宽、与微处理器接口简单的数字化温度传感器。

通过本次实验,我认识到STM32的强大,在开发板上可以添加其他感应器从而实现更强大的功能。添加了DS18B20后的开发板可以感应外界的温度,通过公式计算显示出来。

第三篇:嵌入式实验报告

嵌入式系统及应用课 程设计报告

姓名:陈宥祎

班级:14级计算机01班 学号:1255010116 指导老师:黄卫红

按键输入实验

一.实验简介

在实验一的基础上,使用按键控制流水灯速度,及使用按键控制流水灯流水方向。

二.实验目的

熟练使用库函数操作GPIO,掌握中断配置和中断服务程序编写方法,掌握通过全局变量在中断服务程序和主程序间通信的方法。

三.实验内容

实现初始化GPIO,并配置中断,在中断服务程序中通过修改全局变量,达到控制流水灯速度及方向。

使用JLINK下载代码到目标板,查看运行结果,使用JLINK在线调试。

四.实验设备

硬件部分:PC计算机(宿主机)、亮点STM32实验板、JLINK、示波器。软件部分:PC机WINDOWS系统、MDK KEIL软件、ISP软件。

五.实验步骤

1在实验1代码的基础上,编写中断初始化代码

2在主程序中声明全局变量,用于和中断服务程序通信,编写完成主程序 3编写中断服务程序

4编译代码,使用JLINK下载到实验板 5.单步调试

6记录实验过程,撰写实验报告

六.实验结果及测试

源代码:

我们将通过MiniSTM32 板上载有的3个按钮,来控制板上的2个LED,其中KEY0控制LED0,按一次亮,再按一次,就灭。KEY1 控制LED1,效果同KEY0。KEY_2(KEY_UP),同时控制LED0 和LED1,按一次,他们的状态就翻转一次。

七.实验总结

通过本次实验,我学会了如何使用STM32 的IO 口作为输入用。TM32 的IO 口做输入使用的时候,是通过读取IDR 的内容来读取IO 口的状态的。这里需要注意的是 KEY0 和KEY1 是低电平有效的,而WK_UP 是高电平有效的,而且要确认WK_UP 按钮与DS18B20 的连接是否已经断开,要先断开,否则DS18B20 会干扰WK_UP按键!并且KEY0 和KEY1 连接在与JTAG 相关的IO 口上,所以在软件编写的时候要先禁用JTAG 功能,才能把这两个IO 口当成普通IO 口使用。

串口通信

一.实验简介

编写代码实现串口发送和接收,将通过串口发送来的数据回送回去。

二.实验目的

掌握STM32基本串口编程,进一步学习中断处理。

三.实验内容

编写主程序,初始化串口1,设置波特率为9600,无校验,数据位8位,停止位1位。编写中断服务程序代码实现将发送过来的数据回送。

四.实验设备

硬件部分:PC计算机(宿主机)、亮点STM32实验板、JLINK、示波器。

软件部分:PC机WINDOWS系统、MDK KEIL软件、ISP软件、串口调试助手。

五.实验步骤

1编写串口初始化代码

2编写中断服务程序代码

3编译代码,使用JLINK或ISP下载到实验板 4记录实验过程,撰写实验报告

六.实验结果及测试

源代码:

把代码下载到 MiniSTM32 开发板,可以看到板子上的LED0 开始闪烁,说明程序已经在跑了。接着我们打开串口调试助手,看到如下信息:

证明串口数据发送没问题。接着,我们在发送区输入上面的文字,输入完后按回车键。然后单击发送,可以得到如下结果:

七.实验总结

通过本次实验,我进一步了解了串口的使用,学会了通过串口发送和接收数据,将通过串

口发送来的数据回送回去。该实验的硬件配置不同于前两个实验,串口 1 与USB 串口默认是分开的,并没有在PCB上连接在一起,需要通过跳线帽来连接一下。这里我们把P4 的RXD 和TXD 用跳线帽与P3 的PA9 和PA10 连接起来。

外部中断

一.实验简介

STM32 的 IO 口在本章第一节有详细介绍,而外部中断在第二章也有详细的阐述。这里我们将介绍如何将这两者结合起来,实现外部中断输入。

二.实验目的

进一步掌握串口编程,进一步学习外部中断编程,提高编程能力。

三.实验内容

初始化IO口的输入,开启复用时钟,设置IO与中断的映射关系,从而开启与IO口相对应的线上中断事件,设置触发条件。配置中断分组(NVIC),并使能中断,编写中断服务函数。

四.实验设备

硬件部分:PC计算机(宿主机)、亮点STM32实验板、JLINK、示波器。

软件部分:PC机WINDOWS系统、MDK KEIL软件、ISP软件、串口调试助手。

五.实验步骤

1.2.3.4.编写中断服务程序代码 使用ISP下载到实验板 测试运行结果

记录实验过程,撰写实验报告

六.实验结果及测试

源代码:

打开串口助手。

七.实验总结

首先需要将IO设置为中断输入口: 1)初始化 IO 口为输入。

2)开启 IO 口复用时钟,设置 IO 口与中断线的映射关系。

3)开启与该 IO口相对的线上中断/事件,设置触发条件。

4)配置中断分组(NVIC),并使能中断。

5)编写中断服务函数。

这一节,使用的是中断来检测按键,通过 WK_UP 按键实现按一次 LED0 和 LED 1 同时翻转,按 KEY0 翻转 LED0,按 KEY1 翻转 LED1。试验中外部中断函数不能进入的原因分析 : 1)GPIO或者AFIO的时钟没有开启。2)GPIO和配置的中断线路不匹配。3)中断触发方式和实际不相符合。

4)中断处理函数用库函数时,写错,经常可能出现数字和字母之间没有下划线。5)外部中断是沿触发,有可能不能检测到沿,比如 中断线是低电平(浮空输入),触发是下降沿触发,可能会出现一直是低电平,高电平的时候是一样的情况,电平持续为高电平。

6)没有用软件中断来触发外部中断,调用函数EXTI_GenerateSWInterrupt;,因为软件中断先于边沿中断处理。

独立看门狗实验

一. 实验简介

独立看门狗(IWDG)由专用的低速时钟(LSI)驱动,即使主时钟发生故障它也仍然有效。窗口看门狗由从APB1时钟分频后得到的时钟驱动,通过可配置的时间窗口来检测应用程序非正常的过迟或过早的操作。

二.实验目的

通过编程,编写一个独立看门狗驱动程序

三.实验内容

启动 STM32 的独立看门狗,从而使能看门狗,在程序里面必须间隔一定时间喂狗,否则将导致程序复位。利用这一点,我们本章将通过一个 LED 灯来指示程序是否重启,来验证 STM32 的独立看门狗。

四.实验设备

硬件部分:PC计算机(宿主机)、亮点STM32实验板、JLINK。

软件部分:PC机WINDOWS系统、MDK KEIL软件、ISP软件、串口调试助手。

五.实验步骤

1.2.3.4.参考教材独立看门狗部分,编写独立看门狗驱动程序。建立和配置工程 编写代码

使用ISP下载到实验板

记录实验过程,撰写实验报告

六.实验结果及测试

源代码:

在配置看门狗后,看到LED0 不停的闪烁,如果WK_UP 按键按下,就喂狗,只要WK_UP 不停的按,看门狗就一直不会产生复位,保持LED0 的常亮,一旦超过看门狗定溢出时间(Tout)还没按,那么将会导致程序重启,这将导致LED0 熄灭一次。

七.实验总结

通过本次实验,我掌握了启动独立看门狗的步骤: 1)向 IWDG_KR 写入 0X5555。2)向 IWDG_KR 写入 0XAAAA。3)向 IWDG_KR 写入 0XCCCC。

通过上面 3个步骤,启动 STM32 的看门狗,从而使能看门狗,在程序里面就必须间隔一定时间喂狗,否则将导致程序复位。利用这一点,本章通过一个LED 灯来指示程序是否重启,来验证 STM32 的独立看门狗。在配置看门狗后,LED0 将常亮,如果 WK_UP 按键按下,就喂狗,只要 WK_UP 不停的按,看门狗就一直不会产生复位,保持 LED 0 的常亮,一旦超过看门狗溢出时间(Tout)还没按,那么将会导致程序重启,这将导致 LED 0 熄灭一次。

第四篇:嵌入式实验报告

西安邮电大学

嵌入式处理器及应用实验报告书

学院名称学生姓名专业名称班

: : : :

实验一

ADS 1.2 集成开发环境练习

一、实验目的:

了解ADS 1.2 集成开发环境的使用方法。

二、实验内容:

1.建立一个新的工程。

2.建立一个C源文件,并添加到工程中。3.设置文本编辑器支持中文。4.编译链接工程。5.调试工程。

三、实验步骤:

1.启动ADS 1.2 IDE集成开发环境,选择File—New,使用ARM Executable Image工程模板建立一个工程,工程名称为ADS。

2.选择File—New建立一个新的文件TEST1.S,设置直接添加到项目中,输入程序代码。3.由于ADS安装后默认字体是Courier New,对于中文支持不完善,因此建议修改字体。选择Edit—Perferences,在Font选项设置字体为Fixedsys,Script为CHINESE_GB2312。建议在Tab Inserts Spaces前打勾,使Tab键插入的是多个空格。

4.选择Edit—DebugRel Settings,在DebugRel Settings对话框的左边选择ARM Linker项,然后在Output页设置连接地址ROBase 为0x40000000,RW Base 为0x40003000,在Options页设置调试入口地址Image entry point 为 0x40000000。5.选择Project—Make,将编译链接整个工程。

6.选择Project—Debug,或单击快捷键F5,IDE环境就会启动AXD调试软件。

四、程序清单:

AREA

Example1,CODE,READONLY

;声明代码段Example1

ENTRY

;标识程序入口

CODE32

;声明32 位ARM 指令

START

MOV

R0,#15

;设置参数

MOV

R1,#8

ADDS

R0,R0,R1

;R0 = R0 + R1

B

STA

浙工大 嵌入式实验报告

第一篇:浙工大 嵌入式实验报告 金艳霞 通信2班 201203110210 实验五 Linux交叉编译平台 一、实验目...
点击下载
分享:
最新文档
热门文章
    确认删除?
    QQ
    • QQ点击这里给我发消息
    微信客服
    • 微信客服
    回到顶部