chipset: MSM8X25Q
Codebase: Android4.1
Kernel: 3.4.0
基本概念:
当你需要将高端页面长期映射到内核空间的时候,就要使用Kmap函数来实现,即高端内存永久映射。这样避免页表和TLB的更新而导致资源的占用。
使用的时候一般先通过alloc_page(__GFP_HIGHMEM)申请一个page,然后将这个page传给kmap,kmap会建立这个page的页表项,并返回一个虚拟地址供操作。
Pkmap_count是一个长度为LAST_PKMAP的数组,长度为512,,每个元素对应一个永久映射的页,所以可以映射512*4k = 2M页大小。
static int pkmap_count[LAST_PKMAP];
#define LAST_PKMAP PTRS_PER_PTE
#define PTRS_PER_PTE 512
Pkmap_count元素的值不同时的意义对应如下:
0:相关也还没使用
1:表示页已经被映射,但是由于TLB没被更新而无法使用。
>=2:为2时,表示内核有一处使用该映射页。为n时,表示有n-1处使用该页。
另外,内核使用struct page_address_map来保存页和虚拟地址之前的关系。
本文介绍了高端内存永久映射的概念,特别是在Android4.1系统和3.4.0内核上的应用。Kmap用于将高端页面长期映射到内核空间,避免资源占用。通过alloc_page获取page,然后调用kmap建立页表项。Pkmap_count数组管理映射页,其值反映映射状态。此外,page_address_htable变量借助哈希表管理这些映射,系统启动时进行初始化,映射过程涉及kmap_high和flush_all_zero_pkmaps等函数。
最低0.47元/天 解锁文章
1489





