版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、 11 / 11嵌入式系统设计大作业学号姓名:罗翔1、 叙述JTAG接口在嵌入式开发中的作用。答:(1)用于烧写FLASH 烧写FLASH的软件有很多种包括jatg.exe fluted flashpgm等等,但是所有这些软件都是通过jtag接口来烧写flash的,由于pc机上是没有jtag接口的,所以利用并口来传递信息给目标板的jtag接口。所以就需要并口转jtag接口的电路。 (2)用于调试程序 同时应该注意到jtag接口还可以用来调试程序。而调试程序(如ARM开发组件中的AXD)为了通过jtag接口去调试目标板上的程序
2、,同样是使用pc的并口转jtag接口来实现与目标板的通信。这样,并口转jtag接口的电路就有了两种作用。 (3)仿真器 根据(1)和(2)的总结,并口转jtag接口的电路是两种应用的关键,而这种电路在嵌入式开发中就叫仿真器。并口转jtag接口的电路有很多种,有简单有复杂的,常见的仿真器有Wigger,EasyJTAG,Multi-ICE等。这些所谓的仿真器的内部电路都是并口转jtag接口,区别只是电路不同或使用的技术不同而已。 2、 叙述嵌入式平台的搭建过程,以linux为例。答:1) 一:建立宿主机开发环境
3、160; 建立交叉编译的环境即在宿主机上安装与开发板相应的编译器及库函数,以便能够在宿主机上应用开发工具编译在目标板上运行的Linux引导程序,内核,文件系统和应用程序 交叉编译:在特殊的环境下,把嵌入式程序代码编译成不同的CPU所对应的机器代码。 开发时使用宿主机上的交叉编译,汇编及链接工具形成可执行的二进制代码(该代码只能在开发板上执行),然后下载到开发板上运行 2) 下载和安装arm-Linux-gcc编译工具链 下载最新的arm-Linux-gcc并解压至当前目录下 在系统配置文件profile中设置环境
4、变量 方法:直接在profile文件中加入搜索路径 立即使新的环境变量生效:运行source命令,检查是否将路径加入到path,测试是否安装成功, 编译程序,测试交叉工具链 3) 配置超级终端minicom minicom是宿主机与目标板进行通信的终端:在宿主机Linux终端中输入:minicom-s或输入minicom然后按ctrl+A+O对超级终端minicom进行配置,再选择串口并配置串口,最后保存即可 4) 建立数据共享服务:NFS服务是Linux系统中经常使用的数据文件共享服务 5)
5、 编译嵌入式系统内核:内核配置,建立依存关系,建立内核 6) 制作文件系统3、 给出现今有哪些用于嵌入式开发的芯片名称,他们分别是哪些公司的产品?体系结构是什么?S3C2410X基于ARM的Sumsang;XscalePXA255/PXA270基于ARM的Intel;摩托罗拉MC基于68k;Power 601基于Power PC;MIPS32Kc基于MIPS4、 现今较流行的嵌入式操作系统有哪些? 答: (1) VxWorks (2)wince (3)linux (4)android (5)C/OS-5、 PXA270嵌入式开发板的接口有哪些? 答: 全
6、双工异步串行口和硬件流控制串行口,10M标准以太网接口10M/100M标准 以太网接口,USB接口,红外通讯口,音频接口,存储卡口,视频和触摸屏接口摄像头接口,RTC时钟接口,调试接口,下载接口,电源接口。6、 请写出Nor Flash和 Nand Flash的区别。 Nor FlashNand Flash接口时序同SRAM,容易使用地址/数据线复用,数据位较窄读取速度较快读取速度较慢檫除速度慢,以64-128KB的块为单位檫除速度快,以8-32KB的块为单位写入速度慢写入速度快随机存取速度较快,支持XIP(eXecute In Place,芯片内执行),适用于代码存储。在
7、嵌入式系统中,常用于存放引导程序、根文件等顺序读取速度较快,随机存取速度慢,适用于数据存储(如大容量的多媒体应用)。在嵌入式系统中,常用于存放用户文件系统等单片容量较小为1-32MB 单片容量较大为8-128MB,提高了单元密度最大檫写次数为10万次最大檫写次数为100万次7、 冯。诺依曼架构与哈佛架构的区别。 答: 他们的主要区别是计算机的存储结构和总线连接形式不同。 在冯·诺依曼的结构中,存储器内部的数据存储空间和程序存储空间是合在一起的,他们共享存储器总线,即数据和指令在同一条总线上通过时分复用的方式进行传输,这种结构在高速运行时,不能达到同时取指令和取操作
8、数的目的从而形成传输过程的瓶颈。 在哈佛总线体系结构的芯片内部,数据存储空间和程序存储空间是分开的,所以哈佛总线体系在指令执行时可以同时存取指令(来自程序空间)和取操作数(来自数据空间),因此具有更高的执行效率,修正的哈佛总线结构还可以在程序空间和数据空间之间相互传送数据。8、 单周期3级流水的情况下,第10个指令周期时,第几条指令执行结束? 答: 第七条 9、下面是linux下的一个简单的设备驱动程序,写出linux设备驱动常用的数据结构,同时阅读下面代码,请给出测试程序中的每条语句加以注释。设备驱动程序Keypad.c的源代码:#include <linux/module.
9、h>/最基本的文件,支持动态添加和卸载模块。#include <linux/fs.h>/包含了文件操作相关struct的定义#include <linux/init.h>/初始化头文件#include <linux/poll.h>/轮询文件#include <linux/types.h>#include <linux/fs.h>#include <linux/rtc.h>/可以在芯片上产生周期性的中断#include <linux/delay.h>/延时头文件#include <asm/hardwa
10、re.h>/与处理器相关的硬件#include <asm/delay.h>/延时头文件#include <asm/uaccess.h>/与处理器相关的入口#define LEDnKEY_MAJOR 251#define KEYPAD_NAME "X-Hyper250 Keypad"#define KEYPAD_VERSION "Version 0.1"#define EXT_KEY_CS EXT_PORT2/宏定义#define EXT_LED_CS EXT_PORT3/宏定义#define LED_SHOW 10/宏定义/
11、*EXT_KEY_CS 为向外部LED进行数值设定,它定义在其它头文件里*/void led_off_on() /*/int i;EXT_LED_CS = 0xff;for(i =0 ; i<8;+i)EXT_LED_CS = (1 << i) & 0xff);/点亮相应LED灯udelay(30000);/调用udelay函数来延迟EXT_LED_CS = 0xff;/*应用程序用open来打开设备文件,实际上调用驱动的lednkey_open()函数*/int lednkey_open(struct inode *inode, struct file *filp)
12、/打开设备文件MOD_INC_USE_COUNT;/模块自身通过return (0); /* success */ int lednkey_release(struct inode *inode, struct file *filp)/释放设备文件led_off_on();MOD_DEC_USE_COUNT;return (0);ssize_t lednkey_read(struct file *filp, char *Putbuf, size_t length, loff_t *f_pos)/*按键读取函数*/unsigned short BottonStatus;/按键状态 unsigne
13、d char Bottontmp = 0;int i;BottonStatus = ( EXT_KEY_CS & 0xff );for(i = 0 ; i < 8; +i)if( (BottonStatus >> i) & 1) = 0 ) /判断哪个按键按下Bottontmp = (i+1);copy_to_user( Putbuf, &Bottontmp, length);/*将数据从内核态拷贝到用户态,这是由定义在<asm/uaccess.h>里的特殊函数实现在不同的空间传输任意字节的数据*/return length;ssize_t
14、 lednkey_write(struct file *filp, const char *Getbuf, size_t length, loff_t *f_pos)int num;unsigned char UsrWantLed; copy_from_user( &UsrWantLed, Getbuf, length);/将数据从用户态拷贝到核心态num = ( (UsrWantLed) & 0xff );/确定哪一位要进行设定EXT_LED_CS = (1 << (num-1);/点亮相应LED灯return (0);int lednkey_ioctl(stru
15、ct inode *inode, struct file *filp, unsigned int cmd,unsigned long arg)/lednkey_ioctl 接口函数,主要用于获取或者改变正在运行的设备参数switch(cmd)case LED_SHOW: if(arg)led_off_on(); break;return 0;/以下这些驱动函数是与用户的应用程序里对设备文件操作的函数相对应的struct file_operations lednkey_fops = open: lednkey_open,read: lednkey_read,write: lednkey
16、_write,ioctl: lednkey_ioctl,release: lednkey_release,;static int _init xhyper250_keypad_init(void)/*初始化设备函数,在函数名之前加上这个属性之后,系统会在初始化完成之后丢弃初始化函数,收回它所占用的内存,以减小内核所占用的内存空间,它只对内建的驱动起作用*/int result;result = register_chrdev(LEDnKEY_MAJOR, "lednkey", &lednkey_fops);/*向操作系统注册一个主号为251,设备名为"le
17、dnkey",并传递设备驱动程序的指针为lednkey_fops(全局变量) ,其中register_chrdev ( )是内核提供的函数,作用是完成注册新的字符设备*/printf("%s %s initialized.n",KEYPAD_NAME, KEYPAD_VERSION);led_off_on();return 0;static void _exit xhyper250_keypad_exit(void)/向操作系统卸载设备函数 unregister_chrdev( LEDnKEY_MAJOR, "lednkey
18、" ); led_off_on();module_init(xhyper250_keypad_init); /显式声明初始化设备函数module_exit(xhyper250_keypad_exit); /显式声明卸载设备函数测试文件的源代码如下:#include<stdio.h>#include<stdlib.h>#include<unistd.h>#include<sys/types.h>#include<sys/stat.h>#include<fcntl.h>#define LED_SHOW 10/宏定义int fd;static char *dev_name = "/dev/keypad"int main(int argc, char *argv)int data = 0, pre_data;fd = open( dev_name , O_RDWR );/使用函数open打开设备keypadif( !(fd >=0) )printf("
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 二零二五年度特殊功能性内墙涂料研发与应用合同3篇
- 二零二五年度公司对公司智能化办公租赁合同3篇
- 2025上海市国有土地使用权出让合同范本
- 二零二五年度能源企业公司挂靠能源供应合同3篇
- 2025年度内部承包合同协议书:XX部门内部承包销售业绩提成协议3篇
- 二零二五年度全款购车车辆认证合同模板3篇
- 二零二五年度农村房屋赠与合同附带农用设备配套协议
- 2025年度土地流转承包与农村金融服务合作协议3篇
- 二零二五年度解除劳动合同经济补偿金及员工心理咨询服务合同3篇
- 2025年度办公室租赁合同(含企业活动策划与执行)3篇
- 中国AI+Agent应用研究报告
- 2024年人教版初二道德与法治上册期末考试卷(附答案)
- 2024至2030年中国工控安全行业发展状况及投资潜力分析报告
- DL-T5153-2014火力发电厂厂用电设计技术规程
- 2022年人力资源管理各专业领域必备知识技能
- 租赁(出租)物品清单表
- 提高聚氯乙烯卷材地面一次验收合格率
- 【部编版】2022年语文七年级上:作文能力提升—谋篇布局(含答案)
- 甲型H1N1流感防治应急演练方案(1)
- LU和QR分解法解线性方程组
- 漏油器外壳的落料、拉深、冲孔级进模的设计【毕业论文绝对精品】
评论
0/150
提交评论