免费注册 查看新帖 |

Chinaunix

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

[内存管理] 如何对中断处理函数进行线性映射? [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2014-04-19 17:36 |只看该作者 |倒序浏览
  1. vmalloc_fault:
  2.         {
  3.                
  4.                 int index = pgd_index(address);
  5.                 unsigned long pgd_paddr;
  6.                 pgd_t *pgd, *pgd_k;
  7.                 pud_t *pud, *pud_k;
  8.                 pmd_t *pmd, *pmd_k;
  9.                 pte_t *pte_k;

  10.                 asm("movl %%cr3,%0":"=r" (pgd_paddr));
  11.                 pgd = index + (pgd_t *)__va(pgd_paddr);
  12.                 pgd_k = init_mm.pgd + index;

  13.                 if (!pgd_present(*pgd_k))
  14.                         goto no_context;

  15.                 pud = pud_offset(pgd, address);
  16.                 pud_k = pud_offset(pgd_k, address);
  17.                 if (!pud_present(*pud_k))
  18.                         goto no_context;
  19.                
  20.                 pmd = pmd_offset(pud, address);
  21.                 pmd_k = pmd_offset(pud_k, address);
  22.                 if (!pmd_present(*pmd_k))
  23.                         goto no_context;
  24.                 set_pmd(pmd, *pmd_k);

  25.                 pte_k = pte_offset_kernel(pmd_k, address);
  26.                 if (!pte_present(*pte_k))
  27.                         goto no_context;
  28.                 return;
  29.         }
复制代码
用户态的程序通过中断进入内核态后会执行中断处理函数,那么中断处理函数的线性地址如何转换成物理地址呢?
我在缺页异常中找到如上程序,看程序似乎是把主内核表中pmd项拷贝到用户程序的pmd中。假设这里使用了4级映射,代码pud = pud_offset(pgd, address);是查找线性地址address对应的pud项的线性地址,那么会不会出现pud表根本没有建立的情况呢?与此类似的还有pmd表。如果pud表与pmd表没有建立,这段代码就无法执行了。

论坛徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辞旧岁徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亚洲杯之卡塔尔
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08处女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技术图书徽章
日期:2014-03-25 09:00:29
2 [报告]
发表于 2014-04-21 09:13 |只看该作者
不会出现pud和pmd没有建立的情况,vmalloc区缺页异常发生时,只会缺页表项。
另外,这个函数的作用是从内核主页表同步内核页表。

论坛徽章:
17
水瓶座
日期:2013-08-29 12:09:27白羊座
日期:2014-08-07 12:36:42丑牛
日期:2014-07-24 12:44:41寅虎
日期:2014-04-16 16:15:33寅虎
日期:2014-03-12 09:28:43摩羯座
日期:2014-03-06 13:22:04技术图书徽章
日期:2014-03-06 11:34:50天蝎座
日期:2014-01-09 11:31:44寅虎
日期:2013-12-27 17:01:44双子座
日期:2013-12-27 12:32:29双子座
日期:2013-12-25 09:03:33丑牛
日期:2013-12-24 16:18:44
3 [报告]
发表于 2014-04-21 09:51 |只看该作者
回复 1# stuman

据我所知,中断向量是存放在固定的物理地址上,应该不会走用户进程的页表转换这一过程!

论坛徽章:
0
4 [报告]
发表于 2014-04-25 20:56 |只看该作者
中断向量是存放在固定的物理地址上,这不错,可是对于调用中断处理程序还是要进行线性映射呀,这里的线性映射怎么处理呢?

论坛徽章:
15
射手座
日期:2014-02-26 13:45:082015年迎新春徽章
日期:2015-03-04 09:54:452015年辞旧岁徽章
日期:2015-03-03 16:54:15羊年新春福章
日期:2015-02-26 08:47:552015年亚洲杯之卡塔尔
日期:2015-02-03 08:33:45射手座
日期:2014-12-31 08:36:51水瓶座
日期:2014-06-04 08:33:52天蝎座
日期:2014-05-14 14:30:41天秤座
日期:2014-04-21 08:37:08处女座
日期:2014-04-18 16:57:05戌狗
日期:2014-04-04 12:21:33技术图书徽章
日期:2014-03-25 09:00:29
5 [报告]
发表于 2014-04-28 13:45 |只看该作者
中断处理程序运行在内核态,照内核通用处理方法就行了吧~~

论坛徽章:
1
2015年迎新春徽章
日期:2015-03-04 09:58:11
6 [报告]
发表于 2014-04-28 16:53 |只看该作者
本帖最后由 arm-linux-gcc 于 2014-04-28 16:54 编辑

向量的映射,我只清楚ARM的

paging_init
        devicemaps_init
                vectors = early_alloc(PAGE_SIZE * 2);
                early_trap_init(vectors);                           将向量处理相关的代码(地址无关的)拷贝到刚才分配的内存中
                map.pfn = __phys_to_pfn(virt_to_phys(vectors));
                map.virtual = 0xffff0000;                           将刚才分配的页映射到虚拟地址0xffff0000——ARM的向量基地址
                create_mapping(&map);

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP