ImageVerifierCode 换一换
格式:DOCX , 页数:25 ,大小:462.34KB ,
资源ID:5449030      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/5449030.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(嵌入式Linux实验报告.docx)为本站会员(b****3)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

嵌入式Linux实验报告.docx

1、嵌入式Linux实验报告嵌 入 式 程 序 设 计实 验 报 告评 语:成绩教 师:年 月 日班 级: 学 号: 姓 名: 地 点: EII-506 时 间: 2013年6月 实验一开发环境的搭建与配置【实验目的】1)熟悉嵌入式Linux开发平台。2)掌握嵌入式Linux开发平台的开发环境搭建与配置。3)了解minicom配置串口通信参数的过程。4)了解嵌入式Linux的启动过程。5)掌握程序交叉编译运行及调试的一般方法。6)掌握网络文件系统NFS的配置方法。7)掌握嵌入式系统内核的编译、文件系统的打包及镜像的下载方法。【实验内容】1)连接实验开发板与宿主机。2)在虚拟机中的CentOS(宿主

2、机)搭建开发环境。3)在宿主机中配置minicom。4)分析嵌入式Linux的启动过程。5)在宿主机上编写简单的C语言程序并用交叉编译工具进行编译,然后传输到目标机上运行。6)在宿主机上编写简单的C语言程序并用交叉编译工具进行编译,用gdbserver进行远程调试。7)配置NFS并用NFS进行文件拷贝。8)嵌入式系统内核编译与文件系统的打包。9)内核文件镜像与文件系统镜像的下载(从宿主机下载到目标机)。【实验步骤】连接实验开发板,对虚拟机进行设置工具链的配置tftp的安装进入minicom软件,配置串口通信参数有关串口通信选项的含义:Filenames and paths:选择需要传输的文件和

3、路径File transfer protocols:选择传输文件的通信协议Serial port setup:设置串口通信参数Save setup as dfl:将设置好的各项参数保存为dflSave setup as:将设置好的各项参数保存为自定义的文件名Exit:退出返回到minicom设置好后的终端Exit from Minicom:从minicom命令中退出返回Linux终端将光标移到Serial port setup,按回车键会弹出串口通信参数的配置菜单。实验开发板的启动嵌入式Linux系统的启动过程分析1)启动BootloaderBootloader是嵌入式系统的引导加载程序,它是

4、系统上电后运行的第一段程序,其作用类似于PC机上的BIOS。在本系统中这段程序的起始地址为0x。Bootloader在完成初始化RAM、初始化串口、检测处理器类型、设置Linux启动参数后,开始调用Linux内核。本系统Linux内核镜像zImage放在Flash中,Bootloader首先把它拷贝到RAM中,然后跳转到RAM中对zImage进行解压缩。解压缩后启动内核。2)加载内核内核启动后先进行一系列与内核相关的初始化,然后调用第一个用户进程init进程并等待用户进程的执行。具体的过程如下:进行与体系结构相关的第一个初始化工作,首先通过检测出来的处理器类型进行处理器内核的初始化,然后进行内

5、存结构的初始化,最后开启MMU,创建内核页表,映射所有的物理内存和IO空间;创建异常向量表和初始化中断处理函数;初始化系统核心进程调度器和时钟中断处理机制;初始化串口控制台,在minicom中看到的系统启动过程中的信息都是通过串口输出的;创建和初始化系统cache,为各种内存调用机制提供缓存,包括动态内存分配、虚拟文件系统及页缓存;初始化内存管理,检测内存大小及被内核占用的内存情况;初始化系统的进程间通信机制(IPC);创建init进程,结束内核的启动。3)执行init进程。内核被加载后,第一个运行的程序便是/sbin/init,init进程是所有进程的发起者和控制者,它的进程号是1。init

6、进程首先读取/etc/inittab文件,并依据此文件来进行初始化工作(首先进行一系列的硬件初始化,然后通过命令行传递过来的参数挂载根文件系统。最后执行一些其它的进程)。init配置文件每行的基本格式为“id:runlevel_ignored:action:process”,其中某些部分可以为空。各部分的具体内容如下:id:指定启动进程的控制终端,如果所启动的进程并不是可以交互的shell,应该会有个控制终端(在PC机上该字段表示配置行的惟一标识)。runlevel_ignored:该字段是忽略掉的,配置inittab时空着它就行了(在PC机上该字段用来配置所启动进程适用的系统运行级别)。4)

7、执行/bin/login程序。有些嵌入式系统在init进程执行完后会执行/bin/login。login程序会提示使用者输入账号及密码,接着编码并确认密码的正确性,如果账号与密码相符,则为使用者初始化环境,并将控制权交给shell,即等待用户登录。本系统在执行完init进程后直接开始执行/bin/sh,进入shell交互程序(跳过了执行/bin/login这一步)。这个可以通过图27中的语句“ttyS0:askfirst:-bin/sh”来说明。程序的交叉编译及运行gdbserver远程调试NFS的配置内核配置与编译文件系统的打包内核与文件系统的下载实验二并发Web服务器的实现一、【实验目的】

8、1)熟悉Linux网络编程。2)了解Web服务器原理。3)掌握嵌入式Linux多进程、多线程、I/O多路复用三种方式并发服务器的实现。二、【实验内容】1)用多进程实现Web服务器。2)用多线程实现Web服务器。3)用I/O多路复用方式实现Web服务器。三、【实验步骤】1.环境配置2.实现多进程Web服务器1)用arm-linux-gcc命令编译源程序,得到可执行程序web_server_process。2)用vi文本编译器创建文件index.html,用于测试Web服务器。3)编辑文件index.html,然后保存并退出vi编辑器。4)在/mnt/nfs/web目录下创建子目录cgi-bin,

9、并用vi文本编辑器在cgi-bin目录下创建文件hello.cgi,用于测试Web服务器。5)编辑文件hello.cgi,然后保存并退出vi编辑器。6)用ls命令可以看到root用户对文件hello.cgi没有执行权限,通过chmod命令来修改hello.cgi的权限,使它称为可执行文件。7)用命令service启动宿主机上的nfs服务,并用exportfs命令查看nfs的共享目录。然后在目标机上挂载nfs8)在目标机中运行web_server_process。9)打开宿主机的浏览器,输入http:/192.168.0.5/file,查看执行结果10)在宿主机的浏览器中输入http:/192.

10、168.0.5,查看执行结果。11)在宿主机的浏览器中输入http:/192.168.0.5/index.html,查看执行结果。12)在宿主机的浏览器中输入http:/192.168.0.5/cgi-bin/hello.cgi,查看执行结果。13)在宿主机的浏览器中输入http:/192.168.0.5/web_server_process.c,查看执行结果。3.实现多线程Web服务器1)用arm-linux-gcc命令编译源程序,得到可执行程序web_server_thread。2)在目标机中运行web_server_thread。3)在宿主机的浏览器中输入http:/192.168.0.

11、5,查看执行结果。4)在宿主机的浏览器中输入http:/192.168.0.5/cgi-bin/hello.cgi,查看执行结果。5)在宿主机的浏览器中输入http:/192.168.0.5/web_server_thread.c,查看执行结果。4.实现I/O多路复用方式的Web服务器1)用arm-linux-gcc命令编译源程序,得到可执行程序web_server_select。2)在目标机中运行web_server_select。3)在宿主机的浏览器中输入http:/192.168.0.5,查看执行结果。4)在宿主机的浏览器中输入http:/192.168.0.5/cgo-bin/hell

12、o.cgi,查看执行结果。5)在宿主机的浏览器中输入http:/192.168.0.5/web_server_select.c,查看执行结果。实验三 嵌入式Linux驱动一、【实验目的】1)熟悉嵌入式Linux驱动程序编写框架。2)了解七段数码管驱动程序的工作原理,熟练掌握该驱动程序在嵌入式开发平台的移植和注册使用。3)了解16键矩阵键盘驱动程序的工作原理,熟练掌握该驱动程序在嵌入式开发平台的移植和注册使用。二、【实验内容】1)学习Linux驱动源代码,分析代码中各个函数模块的功能作用。2)在宿主机上交叉编译七段数码管驱动程序,然后移植到目标机上。3)在目标机上注册驱动程序,验证驱动的功能。三

13、、【实验步骤】1.了解七段数码管工作原理七段数码管是显示数字的电子元件,因为借助七个发光二极管以不同组合来显示数字,所以称为七段数码管(如图1)。七段数码管分为共阴极和共阳极,共阳极的七段数码管的正极(或者阳极)为八个发光二极管的共有正极,其他接点为独立发光二极管的负极(或者阴极),使用者只需要把正极接电,不同的负极接地就可以控制七段数码管显示不同的数字。共阴极的七段数码管与共阳极的只是接电的接法相反而已。图12.开发板七段数码管电路介绍开发板上有四个七段共阴数码管,2个一组,第一组七段数码管使用系统LED_CS2作为其位选使能信号,两个数码管的段选信号分别使用数据总线的D0D7位和D8D15

14、位,如图2所示。图2第二组七段数码管使用系统LED_CS3作为其位选使能信号,两个数码管的段选信号分别使用数据总线的D0D7位和D8D15位,如图3所示。图3分析可知,对七段数码管的操作主要是对其位选和段选信号的控制。其中位选信号决定显示哪个七段数码管,段选信号决定其显示的字型信息(共阴极七段数码管段选控制信息如表1),这也是驱动程序和硬件关联的主要部分。D7D6D5D4D3D2D1D0字型DpGFEDCBA编码0011111110X3F1000001100X062010110110X5B3010011110X4F4011001100X665011011010X6D6011111010X7D7

15、000001110X078011111110X7F9011011110X6FA011101110X77B011111000X7CC001110010X39D010111100X5EE011110010X79F011100010X71表13.七段数码管驱动程序分析1)添加驱动程序所需的头文件和变量:SEG_CS1和SEG_CS2就是上面硬件接口所提及的两组七段数码管的位选使能信号,LED10数组中保存的就是在共阴极数码管上面显示09的段选信号。Seg这个结构体用于保存4个数码管即时显示的数字的段选信号。#include #include #include #include #include MO

16、DULE_LICENSE(GPL);/用于声明描述内核模块的许可权限,如果不声明LICENSE,模块被加载时将收到内核被污染(kernel tainted)的警告char LED_MODULE=0;#define DEVICE_NAME xidian_seg7#define SEG_CS1 0x #define SEG_CS2 0x static char LED10=0x3f, 0x06, 0x5b, 0x4f, 0x66, 0x6d, 0x7d, 0x07, 0x7F, 0x6F;unsigned long *CS1_Address, *CS2_Address;structseg char

17、 LED1_Val; char LED2_Val; char LED3_Val; char LED4_Val; char negative;2)同时更新所有七段数码管驱动显示函数:CS1_address对应第一组七段数码管的位选信号,该组第一个数码管的段选信号保存在short变量的低8位,该组第二个数码管的段选信号保存在short变量的高8位。CS2_address对应第二组七段数码管,其余操作和第一组的七段数码管一致。static void Updateled(struct seg *seg_7) unsigned short buff=0x00; buff=seg_7-LED1_Val;

18、buff=buff|( seg_7-LED2_Val LED3_Val; buff=buff|( seg_7-LED4_Valnegative=0) value=value & (0x17); else value=(0x1LED1_Val=value; else if(position=2) seg_7-LED2_Val=value; else if(position=3) seg_7-LED3_Val=value; else if(position=4) seg_7-LED4_Val=value; 4)实现七段数码管驱动写操作函数:把用户写入的数码管显示更新数据,转换成为要显示数字对应的段

19、选信号,并且保存在led_forall数组中,并且调用Value_setting更新显示数据,最后调用Updateled()更新实际的数码管显示信息。staticssize_t seg7_write(struct file *file, const char *buffer, size_t count, loff_t * ppos) int i; structseg *seg_7=file-private_data; charled_forall4; printk(KERN_EMERG The Module is written,seg7_writen); if(count!=4) print

20、k(KERN_EMERG the count of input is not 4!); return 0; if(copy_from_user(led_forall, buffer, 4) returnEFAULT; for(i=1;iprivate_data; if (!arg) return -EINVAL; if (copy_from_user(&val, (int *)arg, sizeof(char) return -EFAULT; switch(cmd) case 1: value_seting(seg_7, 1, val); break; case 2: value_seting

21、(seg_7, 2, val); break; case 3: value_seting(seg_7, 3, val); break; case 4: value_seting(seg_7, 4, val); break; case 0: seg_7-negative = LED_MODULE; break; default: printk(KERN_EMERGioctl parameter input error,please input number 0-4); break; Updateled(seg_7); return 0; 6)实现七段数码管驱动打开操作函数。staticint s

22、eg7_open(struct inode *inode, struct file *filp) structseg *seg_7; printk(KERN_EMERG The Module is open,seg7_openn); seg_7=kmalloc(sizeof(struct seg), GFP_KERNEL);/分配内存(在内核空间) seg_7-negative=LED_MODULE; filp-private_data=seg_7; return 0;7)实现七段数码管驱动释放函数。staticint seg7_release(struct inode *inode, str

23、uct file *filp) printk(KERN_EMERG The Module is release,seg7_releasen); kfree(filp-private_data); return 0;8)七段数码管驱动文件结构体定义:定义七段数码管驱动程序的打开,写入,释放,Ioctl操作,属主信息。static struct file_operationsEmdoor_fops = open: seg7_open, write: seg7_write, release: seg7_release, ioctl: seg7_ioctl, owner: THIS_MODULE,;9

24、)实现七段数码管驱动初始化函数:映射七段数码管的位选信号的物理实际地址,注册设备。staticint _init seg7_init(void) int ret; printk(KERN_EMERG The Module is Init,seg7_initn); CS1_Address=ioremap(SEG_CS1, 4); CS2_Address=ioremap(SEG_CS2, 4); ret = register_chrdev(56, DEVICE_NAME, &Emdoor_fops); if (ret 0) printk(DEVICE_NAME cant get major num

25、bern); return ret; return 0;10)实现七段数码管驱动模块退出函数与模块描述:取消对七段数码管的位选信号的物理地址的映射,释放设备。static void _exit seg7_exit(void) printk(KERN_EMERG The Module is Exit,seg7_exitn); iounmap(CS1_Address); iounmap(CS2_Address); unregister_chrdev(56, DEVICE_NAME);module_init(seg7_init);module_exit(seg7_exit);MODULE_AUTHO

26、R(Mr.han);MODULE_DESCRIPTION(This is a 7 Segment Led driver demo);11)七段数码管驱动程序的MakefileCFLAGS +=$(DEBFLAGS) -Wallifneq ($(KERNELRELEASE),) obj-m :=xidian_seg7.oelse KERNELDIR ?=./linux-2.6 PWD :=$(shellpwd)ALL: $(MAKE) $(CFLAGS) -C $(KERNELDIR) M=$(PWD) modulesendifclean: rm -fr *.o *.ko *.symvers *

27、 core .depend .*.cmd *.mod.c .tmp_versions4.编写七段数码管驱动的测试程序和Makefile文件1)seg7_test.c源代码:#include #include #include #include #include typedef unsigned char u8;#define SEG_DEV /dev/xidian_seg7 char number=0x3f, 0x06, 0x5b, 0x4f, 0x66, 0x6d, 0x7d, 0x07, 0x7F, 0x6F;voidclear_led(intfd)int i;charval=0;for(i=1;i=4;i+)

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1