作为用户空间和内核空间的区别之一是其地址空间的不同,具体来讲用户进程的虚拟地址空间范围是0-3G,而内核进程为3-4G(注:在较新的内核版本中,内核虚拟地址空间为0-4G)。这对于用户进程的正常运行没有问题,但当把用户进程放到内核模式运行的时候,问题产生了。当进程触发系统调用的时候,对于用户进程提供的指针,系统调用必须检查提供的缓存是否是一个有效的地址空间,一个位于用户地址空间的地址被认为是合法的,而处于内核地址空间的则不是,所以当一个在内核模式运行的进程试图触发系统调用时是无法通过这个检查的。
该方案采用了阻止这种错误检测的方法,通过get_fs和set_fs宏来重新定义虚拟范围,从而使进程在内核状态也可触发系统调用。对于其他代码,由于可动态加载模块是在内核模式运行的,故采用动态加载模块的方法将其放入内核模式运行。
文章来源于领测软件测试网 https://www.ltesting.net/