1第一部分Linux系统概述2概要Linux定义Linux种类Linux优势如何选择linux版本Linux内核简介3Linux的定义Linux一般是指Linux内核、Linux系统、Linux发行版。严格意义上说Linux是指由LinusTorvalds维护的并发布的内核。它的代码基只包括内核而不包括其它方面的应用。内核提供系统核心服务,如进程管理,进程的调度,虚拟文件系统,内存的管理等等。嵌入式Linux,一般是指把Linux内核移植到一个专用嵌入式设备的CPU和主板上。现在有很多公司提供嵌入式Linux解决方案。通常包括一个移植的内核、嵌入式Linux的开发工具以及根据应用需要裁减的应用程序等,有时还提供实时扩展的内核。就大部分而言,嵌入式Linux和桌面Linux提供的API函数和内核源代码都是相同的。开发工具主要包括源码浏览器、交叉编译器、调试器、CVS等项目管理软件等等。这些工具一般都是装在主机上。4嵌入式Linux种类嵌入式系统的划分一般是根据使用对象进行划分,消费类电子、工控设备等。为了更好的理解所设计的系统,可以按照尺寸,时间约束,网络,用户交互程度等因素划分。尺寸:小系统,中等系统,大系统小系统-CPU的性能比较低,ROM2MBRAM4MB中系统-CPU的性能中等,ROM32MBRAM64MB左右大系统-CPU性能高,存储量大时间约束:实时,非实时网络连接性用户交互5嵌入式Linux种类是否支持MMU不支持MMU:ucLinux,主要应用在ARM7系列微处理系统中,如三星公司的S3C44B0,S3C4510等,无MMU,不支持虚地址,直接访问内存,所有程序中访问的地址都是物理地址。支持MMU:嵌入式Linux,主要应用在ARM9系列微处理器系统中,如三星公司的S3C2410,Intel公司的PXA255等。6MMU实现虚拟存储空间即将虚拟存储空间影射到实际物理存储空间。使编程人员不用考虑具体程序所放在物理存储空间的具体位置和程序的大小。存储器访问权限的控制任务间通讯,对自己的内存、堆栈等进行保护,只能通过管道、信号量、共享内存等方式进行通讯。控制Cache。7Linux的主要特点开放性开放性是指系统遵循世界标准规范,特别是遵循开放系统互连(OSI)国际标准。多用户多用户是指系统资源可以被不同用户各自拥有使用,即每个用户对自己的资源(例如:文件、设备)有特定的权限,互不影响。多任务多任务是现代计算机的最主要的一个特点。它是指计算机同时执行多个程序,而且各个程序的运行互相独立。Linux系统调度每一个进程平等地访问微处理器。良好的用户界面Linux向用户提供了两种界面:用户界面和系统调用。用户界面可分为基于文本的命令行界面和图形界面,作为人机交互界面。系统调用给用户提供编程时使用的界面。用户可以在编程时直接使用系统提供的系统调用命令。8Linux的主要特点设备独立性指操作系统把所有外部设备统一当作成文件来看待,只要安装它们的驱动程序,任何用户都可以象使用文件一样,操纵、使用这些设备,而不必知道它们的具体存在形式。丰富的网络功能完善的内置网络是Linux的一大特点。可靠的系统安全Linux采取了许多安全技术措施,包括对读、写进行权限控制、带保护的子系统、审计跟踪、核心授权等。良好的可移植性可移植性是指将操作系统从一个平台转移到另一个平台使它仍然能按其自身的方式运行的能力。9嵌入式Linux优势Linux的费用低;Linux的所有部分可以充分地定制;Linux可以运行在低档,便宜的硬件平台;Linux的功能是强大的;Linux对源代码质量有一个高标准;Linux内核非常小,而且紧凑;Linux有很好的支持;Linux有很多合适的工具;10Linux的版本内核版本与发型版本操作系统的内核版本指的是在Linus本人领导下的开发小组开发出的系统内核的版本号,如2.4.x,2.6.x。有一些组织或商业厂家,将Linux系统的内核与外围应用软件和文档包装起来,并提供一些系统安装界面和系统设定与管理工具,这样就构成了一个发行版本,如RedHat、Debian。11如何选择Linux的版本DIY-自己动手做一个满足需要的Linux版本选择商用Linux版本授权和涉及到的授权是否满足你的需要,是否有合适的开发工具是否能够提供足够的支持信誉文档12嵌入式Linux发展现状RT-LinuxRT-Linux是利用Linux进行实时系统开发比较早的尝试,是一种硬实时操作系统。目前RT-Linux已成功应用于航天飞机的空间数据采集、科学仪器测控,以及电影特技图像处理等众多领域。RT-Linux的原理是采用双内核机构,即将Linux的内核代码进行少量修改,将Linux任务以及Linux内核本身作为实时内核的一个优先级最低的任务,即实时任务优先级高于普通Linux任务,即在实时任务存在的情况下运行实时任务,否则才运行Linux本身的任务。实时任务不同于Linux普通进程,它是以Linux的内核模块(LinuxLoadableKernelModule,LKM)的形式存在的。需要运行实时任务的时候,将这个实时任务的内核模块插入到内核中去。实时任务和Linux一般进程之间的通信通过共享内存或者FIFO通道来实现。13RT-Linux的工作原理图14uClinux控制领域中的linux系统。它包含linux常用的API,内核小于512K,保留了linux原有的高稳定性、强大的网络功能和卓越的文件系统支持功能等优点。目前已支持的CPU芯片有,Motorola公司的68K系列、PowerPC系列以及ARM公司的系列芯片。官方网站,。uClinux最大特点就是不支持MMU。uClinux系统对内存的访问是直接的,即不需要经过MMU,直接将地址发送到地址线上,所有程序访问的都是实际的物理地址,这样一方面减小了内核的体积,另一方面又增强了系统的实时性能。但内存空间得不到保护,对于应用开发者来说,必须明白自己程序运行的位置,以及保证不会破坏其它程序运行空间以及系统的稳定。uClinux也可以使用RT-Linux的实时补丁,以增强其实时性。15MizilinuxMIZI韩国MIZI公司所公布的开放源代码的免费嵌入式操作系统arm-Linux。大部分的2410系统板上都是采用的mizilinux。16Linux内核简介Linux文件系统Linux内核Linux的启动17Linux主要目录介绍与Windows一样,在Linux中也是通过目录来组织文件的。但不同的是,在Linux下只有一个根目录,而不象Windows那样一个分区一个根目录。18Linux下常用的命令、工具系统启动时要用到的程序、系统内核,引导配置文件等。Linux就是从这里启动的。所有的设备文件。但不是具体的驱动程序,而是一个访问这些外部设备的端口。系统管理时要用到的各种配置文件和子目录。用户主目录,用户独立的空间非标准目录,内空,但决不能删系统管理员的系统管理程序一个虚拟的文件系统,可用来访问到内存里的内容。包含许多被/bin/和/sbin/中的程序使用的库文件大多数情况下是空的,用来保存异常时候的丢失文件超级用户(管理员)的专用目录外部设备的挂接点,通常用cdrom与floppy两个子目录通常用来安装各种软件的地方。/usr/src、/usr/bin系统运行时的各种临时文件19Linux的内核结构Linux内核主要由5个子系统组成:进程调度进程间通讯内存管理虚拟文件系统网络接口20进程调度(ProcessScheduling)进程:程序执行的一个范例。进程的4要素:一段供进程执行的程序,该程序可以被多个进程执行;独立的内核堆栈;进程控制快;独立的存储空间;pid_tfork(void)函数:生成进程。voidmain(){for(;;)fork();}Exit():退出进程。21进程调度进程的状态运行态r、休眠态s、僵死态z作用:控制进程对CPU的访问。当需要选择下一个进程运行时,由调度程序选择最值得运行的进程。可运行进程实际上是仅等待CPU资源的进程,如果某个进程在等待其它资源,则该进程是不可运行进程。Linux使用了比较简单的基于优先级的进程调度算法选择新的进程。进程处于操作系统的中心位置,其他的子系统都依赖它。因为每个子系统都需要挂起或恢复进程。一般情况下,当一个进程等待硬件操作完成时,它被挂起;当操作真正完成时,进程被恢复执行。22进程通讯(Interprocesscommunication)管道和FIFO信号量消息队列共享内存23进程通讯--管道(pipe)管道管道是进程之间单向的数据流:一个进程写入管道的所有数据都有内核定向到另一个进程,另一个进程由此可以从管道中读取数据。管道的特点:管道被看作是打开的文件,但是在已经装载的文件系统中没有映象;管道是单向的,只提供一个方向的数据流,如果需要双向数据流,必须创建两个管道,每个方向一个一个管道可以被多个进程使用,如果一个管道被多个进程使用,必须使用文件加锁机制管道的一个主要缺点是:用户无法打开一个现有的管道,除非管道是由一个公共的祖先进程创建的,否则两个任意进程就不能共享同一个管道。此问题可由FIFO解决。FIFO命名管道,指代先进先出。每个FIFO有一个路径名与之关联,从而允许无亲缘关系的进程访问同一个FIFOFIFO是半双工的。24管道相关函数创建管道intpipe(intfd[2]);该函数返回两个文件描述字:fd[0],fd[1]。前者打开文件读,后者打开文件写。从管道中读数据read(intfd,void*buff,unsignednbytes)管道描述符fd,传送数据地址buf,传送字节数nbytes向管道中写数据write(intfd,void*buff,unsignednbytes)25进程通讯--信号量(semaphores)信号量信号量是个整数对象,是个计数器,用来为多个进程共享的数据结构提供受控访问信号量大于0,表示受保护的资源可用,信号量小于等于0,受保护资源不可用只能通过原语操作而改变信号量相关函数创建信号量intsemget(key_tkey,intnSems,intflag)根据路径名产生一个关键字key_tftok(constchar*pathname,intproj_id);控制信号量intsemctl(intsemid,intsemnum,intcmd)对信号量+1或-1测试是否为0intsemop(intsemid,structsembuf*sops,unsignedshortnsops)26进程通讯--共享内存(ShareMemory)共享内存最有用的进程间通信机制,允许两个或多个进程通过把公共数据结构放入一个共享内存段来访问它们。共享内存区是最快的进程间通信机制。一旦这样的内存区映射到它的进程的地址空间,这些进程间数据的传递就不再涉及内核。主要局限就是它不能提供同步,如果两个进程企图修改相同的共享内存区域,内存不能串行化这些操作。使用共享内存区必须设计出他们自己的同步协议客户服务器共享内存客户地址空间服务器地址空间27共享内存相关函数创建一个尚未存在的共享内存区intshmget(key_tkey,size_tsize,intoflag);共享内存区同虚拟地址范围联系起来void*shmat(intshmid,constvoid*shmaddr,intflag)断接这个内存区intshmdt(constvoid*shmaddr)删除这个内存区intshmctl(intshmid,intcmd,structshmid_ds*buff)28进程通讯--消息队列进程彼此之间可以同IPC消息进行通信。进程产生的每个消息都