- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
MemManage培训讲义
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * Chapter 7 Memory Management get_vm_area() For every vm_struct tmp in vmlist, Check if :(size + addr = tmp-addr) Then goto found; Else addr = tmp-size + tmp-addr VMALLOC_START addr tmp-addr * Chapter 7 Memory Management get_vm_area() When we found a suitable one addr tmp-addr vm_area descriptor area-flag = flag area-addr = addr area-size = size * Chapter 7 Memory Management get_vm_area() found: area-next = *p; *p = area; area-flags = flags; area-addr = (void *)addr; area-size = size; area-pages = NULL; area-nr_pages = 0; area-phys_addr = 0; write_unlock(vmlist_lock); return area; * Chapter 7 Memory Management remove_vm_area() Search vmlist for vm_area descriptor by addr Call unmap_vm_area(vm_struct) In unmap_vm_area(), calculate correspond PGD entries and call unmap_area_pmd() to unmap each of them Unmap_vm_area() Unmap_area_pmd() Unmap_area_pte() * Chapter 7 Memory Management remove_vm_area() Flow of unmap_vm_area() vm_area 4MB+8KB Page Directory Virtual memory Page Table unmap_area_pte Clear page table entries * Chapter 7 Memory Management remove_vm_area() void unmap_vm_area(struct vm_struct *area) { unsigned long address = (unsigned long) area-addr; unsigned long end = (address + area-size); pgd_t *dir; dir = pgd_offset_k(address); do { unmap_area_pmd(dir, address, end - address); // unmap addr space of PGD entry address = (address + PGDIR_SIZE) PGDIR_MASK; dir++; } while (address (address end)); } * Chapter 7 Memory Management remove_vm_area() static void unmap_area_pte(pmd_t *pmd, unsigned long address, unsigned long size) { unsigned long end; pte_t *pte; pte = pte_offset_kernel(pmd, address); address = ~PMD_MASK; end = address + size; if (end PMD_SIZE) end = PMD_SIZE; do { pte_t page; page = ptep_get_and_clear(pte); // set page table entry t
文档评论(0)