免费注册 查看新帖 |

Chinaunix

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

linux内核page_address函数有疑问,请教! [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-11-02 10:54 |只看该作者 |倒序浏览
void *page_address(struct page *page)
{
        unsigned long flags;
        void *ret;
        struct page_address_slot *pas;

        if (!PageHighMem(page))
                return lowmem_page_address(page);

        pas = page_slot(page);
        ret = NULL;
        spin_lock_irqsave(&pas->lock, flags);
        if (!list_empty(&pas->lh)) {
                struct page_address_map *pam;

                list_for_each_entry(pam, &pas->lh, list) {
                        if (pam->page == page) {
                                ret = pam->virtual;
                                goto done;
                        }
                }
        }
done:
        spin_unlock_irqrestore(&pas->lock, flags);
        return ret;
}

大虾们,请问函数中既然已经用HASH表找到了page_address_map ,那么此时其对应的PAGE FRAME也就找到了,继而virtual ADDRESS也就有了!既然如此,为何还要list_for_each_entry这样遍历双链表LIST,这不是没必要了吗?

呵呵,可能还没搞清楚一些东西,不过还是希望DX们解释一下,谢谢!

论坛徽章:
0
2 [报告]
发表于 2006-11-02 18:26 |只看该作者

说明一下,

pas = page_slot(page);从HASH表找到PAGE对应的page_address_slot ,所以我说下面的list_for_each_entry就显的"多余"了,因为从page_address_slot 已经可以得到PAGE对应的virtual ADDRESS了!看一下page_address_slot 数据结构的组织就知道.

没有人注意过这部分吗,这可是内存管理部分的关键代码呀!

论坛徽章:
0
3 [报告]
发表于 2006-11-04 14:35 |只看该作者
你说得是没有错,是得到了,但是是解决了进程本身的问题啊。要和其他进程联系起来的吧,这就是用双链表的作用。联系什么哦。你用ps命令后看到的那个东西就是放在双链表里的啊。本身没有什么错,加上去有利于大局嘛。程序本身要和其他程序联系的,自己没有事情也要考虑和别人的关系的。废话一堆了。说两句有用的什么父子进程如何识别好象也在双链表的。

论坛徽章:
0
4 [报告]
发表于 2006-11-06 09:12 |只看该作者

谢谢

赫赫,"和其他进程联系"我也考虑过,不过在此查询好象不需要,于效率不合.
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP