免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2356 | 回复: 6
打印 上一主题 下一主题

[内存管理] 临时内核映射kmap_atomic [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-08-15 19:52 |只看该作者 |倒序浏览
  1. void * kmap_atomic(struct page * page, enum km_type type)
  2. {
  3. enum fixed_addresses idx;
  4. unsigned long vaddr;
  5. current_thread_info( )->preempt_count++;
  6. if (!PageHighMem(page))
  7. return page_address(page);
  8. idx = type + KM_TYPE_NR * smp_processor_id( );
  9. vaddr = fix_to_virt(FIX_KMAP_BEGIN + idx);
  10. set_pte(kmap_pte-idx, mk_pte(page, 0x063));
  11. _ _flush_tlb_single(vaddr);
  12. return (void *) vaddr;
  13. }
复制代码
以上是临时内核映射的代码,我的问题是变量kmap_pte是什么?代码vaddr = fix_to_virt(FIX_KMAP_BEGIN + idx);得

到的值是什么?为什么设置pte表项的值与vaddr毫无关系?

论坛徽章:
0
2 [报告]
发表于 2013-08-16 12:28 |只看该作者
vaddr 对应的页表项就是kmap_pte-idx

论坛徽章:
0
3 [报告]
发表于 2013-08-16 12:40 |只看该作者
fix的意思,估计就是,一旦确定了type,页表项和虚拟地址就都确定了。
而计算公式如函数所示:
虚拟地址:
idx = type + KM_TYPE_NR * smp_processor_id( );
vaddr = fix_to_virt(FIX_KMAP_BEGIN + idx);

页表项指针:
kmap_pte-idx
指向的是init_mm中的页表项,当前进程访问是通过缺页异常将页表项拷贝过来就能正常访问了

论坛徽章:
0
4 [报告]
发表于 2013-08-16 12:41 |只看该作者
当然,由于禁用了抢占,所以do_page_fault后是不会调度的,这也是atomic的含义。

论坛徽章:
0
5 [报告]
发表于 2013-08-16 12:42 |只看该作者
本帖最后由 stuman 于 2013-08-16 14:03 编辑

vaddr是一个线性地址,kmap_pte-idx为某个pte表项的物理地址,mk_pte(page, 0x063)为这个pte表项指向的最终物理页的地址,如果vaddr 对应的页表项就是kmap_pte-idx,那么vaddr 与kmap_pte-idx是怎么对应起来的呢?还有变量kmap_pte到底是什么?这段代码中没有这个变量的定义

论坛徽章:
1
双子座
日期:2014-05-02 22:43:41
6 [报告]
发表于 2014-05-02 21:57 |只看该作者
#define kmap_pte ______kmap_pte_in_TLB
Define here as a macro.
I think <<_____kmap_pte_in_TLB>> constants  are determined during the compilation of the kernel.

kmap_pte is the pte table.
as someone say, The pte table is special,  this grows from top to down .
The meaning of Set_pte() is apperant.

论坛徽章:
13
15-16赛季CBA联赛之八一
日期:2016-07-08 21:00:1415-16赛季CBA联赛之同曦
日期:2017-02-15 14:26:1515-16赛季CBA联赛之佛山
日期:2017-02-20 14:19:2615-16赛季CBA联赛之青岛
日期:2017-05-07 16:49:1115-16赛季CBA联赛之广夏
日期:2017-07-30 09:13:1215-16赛季CBA联赛之广东
日期:2018-07-05 22:34:3615-16赛季CBA联赛之江苏
日期:2018-09-03 12:10:2115-16赛季CBA联赛之上海
日期:2018-09-25 03:49:2215-16赛季CBA联赛之广东
日期:2018-09-25 04:09:12
7 [报告]
发表于 2016-04-13 16:57 |只看该作者
不太懂英文,但感觉这段注释就是答案:

/*
* NOTE: pagetable_init alloc all the fixmap pagetables contiguous on the
* physical space so we can cache the place of the first one and move
* around without checking the pgd every time.
*/
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP