remap_pfn_range函数(用于mmap调用驱动程序)可用于将内核内存映射到用户空间.怎么做任何人都可以解释精确步骤内核模式是特权模式(PM),而用户空间是非特权的(NPM).在PM cpu中可以访问所有内存,而在NPM中,某些内存受限制 – cpu无法访问.当调用remap_pfn_range时,用户空间现在是否可以访问仅限于PM的内存范围?
看看remap_pfn_range代码有pgprot_t结构.这是保护映射相关的结构.什么是保护映射?这是上述问题的答案吗?
解决方法
真的很简单,内核内存(通常)只是具有一个具有架构特定位的页表项,它表示:“此页表条目仅在cpu处于内核模式时有效”.
什么remap_pfn_range是创建另一个页表项,具有不同的虚拟地址到相同的物理内存页,没有设置该位.
通常,这是一个坏主意btw