Linux下用户态和内核态内存共享的实现

Linux下用户态和内核态内存共享的实现

ID:37710442

大小:84.00 KB

页数:8页

时间:2019-05-29

Linux下用户态和内核态内存共享的实现_第1页
Linux下用户态和内核态内存共享的实现_第2页
Linux下用户态和内核态内存共享的实现_第3页
Linux下用户态和内核态内存共享的实现_第4页
Linux下用户态和内核态内存共享的实现_第5页
资源描述:

《Linux下用户态和内核态内存共享的实现》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、1引言Linux是一类Unix计算机操作系统的统称。Linux操作系统的内核的名字也是“Linux”。Linux操作系统也是自由软件和开放源代码发展中最著名的例子。Linux是一套免费使用和自由传播的类Unix操作系统。无论是普通用户还是企业用户都可以编写自己的内核代码,再加上对标准内核的裁剪从而制作出适合自己的操作系统。一个或多个内核模块的实现并不能满足一般Linux系统软件的需要,因为内核的局限性太大,如不能在终端上打印,不能做大延时的处理等等。当需要做这些的时候,就需要将在内核态采集到的数据传送到用户态的一个或多个进程中进行处理。这样,内核态与用空间进程通信的方法就显得尤为重要。将

2、列举Linux下基于Netlink机制的内核态与用户态进程通信的方法以及如何实现用户态和内核态的内存共享。2用户态和内核态用户态与内核态是操作系统的两种运行级别,IntelCPU提供Ring0-Ring33种级别的运行模式。Ring0级别最高Ring3最低。用户态:当进程在执行用户自己的代码时,则称其处于用户运行态即用户态。此时处理器在特权级最低的(3级)用户代码中运行。内核态:当一个任务(进程)执行系统调用而陷入内核代码中执行时,就称进程处于内核运行态或简称为内核态。此时处理器处于特权级最高的0级内核代码中执行。当进程处于内核态时,执行的内核代码会使用当前进程的内核栈。在内核态下CPU

3、可执行任何指令,在用户态下CPU只能执行非特权指令。当CPU处于内核态,可以随意进入用户态;而当CPU处于用户态时,用户从用户态切换到内核态只有在系统调用和中断两种情况下发生,一般程序一开始都是运行于用户态,当程序需要使用系统资源时,就必须通过调用软中断进入内核态。3Linux的用户态和内核态Linux使用了Ring3级别运行用户态,Ring0作为内核态。Ring3状态不能访问Ring0的地址空间包括代码和数据Linux进程的4GB地址空间,3GB-4GB部分是共享的,是内核态的地址空间,这里存放着整个内核的代码和所有的内核模块,以及内核所维护的数据。用户运行一个程序,该程序所创建的进程

4、开始是运行在用户态的,如果要执行文件操作,网络数据发送等操作,必须通过write,send等系统调用,这些系统调用会利用内核中的代码来完操作,这时,必须切换到Ring0,然后进入3GB-4GB中的内核地址空间去执行这些代码,完成操作,完成后,切换回Ring3,回到用户态。这样,用户态的程序就不能随意操作内核地址空间,具有一定的安全保护作用。4实现内核态与用户态的通信内核与用户空间共享内存的关键是,用户空间必须知道共享内存的起始地址,这就要求内核空间应该有一种通信机制来通知用户空间。理论上任何内核空间与用户空间的通信方法都可以利用。接下来主要介绍基于Netlink机制的实现。Netlink

5、在linux的内核与用户空间通信中用得很多,其最大优势是接口与网络编程中的socket相似,且内核要主动发信息给用户空间很方便。既然涉及到内核与用户空间两个空间,就应该在两个空间各有一套接口。用户空间的接口与一般的socket接口相似,标准的socketAPI的函数,socket(),bind(),sendmsg(),recvmsg()和close()很容易地应用netlinksocket;内核空间则稍为复杂:首先也是建立描述符,建立描述符时会注册一个回调函数,然后当用户空间有消息发过来时,函数将被调用;当内核要主动发消息给用户进程时,直接调用一个类send函数即可。Netlink套接字

6、的最大特点是对中断过程的支持,它在内核空间接收用户空间数据时不再需要用户自行启动一个内核程,而是通过另一个软中断调用用户事先指定的接收函数。如图1所示,这里使用了软中断而不是内核线程来接收数据,这样就可以保证数据接收的实时性。图1Netlink通过软中断调用用户进程当Netlink套接字用于内核空间与用户空间的通信时,在用户空间的创建方法和一般套接字使用类似,但内核空间的创建方法则不同,图2是Netlink套接字实现此类通信时创建的过程。图2用Netlink套接字实现内核态与用户态的通信5基于Netlink的共享内存5.1工作流程内核部分首先用get_order获取页数,接着调用get_

7、free_page分配连续的物理内存页,这时返回的是虚拟地址,然后调用SetPageReserved,相当于告诉系统,这个页面已经占了。对于每一个申请到的页面,应该都要这样做,同样地,释放内存时,需要对每一页调用ClearPageReserved。如果用户空间通过Netlink要求获取共享内存的起始物理地址,将_get_free_pages返回的地址_pa下发给用户空间。用户空间调用open/dev/shm进行物理内存设备的读写,发

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。