亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
12下一頁
最近訪問板塊 發(fā)新帖
查看: 5259 | 回復: 13
打印 上一主題 下一主題

vfree為什么會引起睡眠? [復制鏈接]

論壇徽章:
0
跳轉(zhuǎn)到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2008-12-19 11:43 |只看該作者 |倒序瀏覽
在vfree內(nèi)核源碼里找不到引起睡眠的地方啊,懇請高人告知。

論壇徽章:
36
IT運維版塊每日發(fā)帖之星
日期:2016-04-10 06:20:00IT運維版塊每日發(fā)帖之星
日期:2016-04-16 06:20:0015-16賽季CBA聯(lián)賽之廣東
日期:2016-04-16 19:59:32IT運維版塊每日發(fā)帖之星
日期:2016-04-18 06:20:00IT運維版塊每日發(fā)帖之星
日期:2016-04-19 06:20:00每日論壇發(fā)貼之星
日期:2016-04-19 06:20:00IT運維版塊每日發(fā)帖之星
日期:2016-04-25 06:20:00IT運維版塊每日發(fā)帖之星
日期:2016-05-06 06:20:00IT運維版塊每日發(fā)帖之星
日期:2016-05-08 06:20:00IT運維版塊每日發(fā)帖之星
日期:2016-05-13 06:20:00IT運維版塊每日發(fā)帖之星
日期:2016-05-28 06:20:00每日論壇發(fā)貼之星
日期:2016-05-28 06:20:00
2 [報告]
發(fā)表于 2008-12-19 12:04 |只看該作者
LDD2上說vmalloc可能睡眠

論壇徽章:
0
3 [報告]
發(fā)表于 2008-12-19 14:44 |只看該作者
LKD2 上也說 vmalloc 和 vfree 可能會睡眠,不能在中斷上下文中調(diào)用,我也想知道是為什么

所以看了一下代碼,發(fā)現(xiàn) 在 mm/vmalloc.c 中,vfree 是這樣實現(xiàn)的:


void vfree(const void *addr)
{
        BUG_ON(in_interrupt());
        __vunmap(addr, 1);
}
EXPORT_SYMBOL(vfree);


再看 __vunmap , 它是這樣的:
static void __vunmap(const void *addr, int deallocate_pages)
{
        struct vm_struct *area;

        if (!addr)
                return;

        if ((PAGE_SIZE-1) & (unsigned long)addr) {
                WARN(1, KERN_ERR "Trying to vfree() bad address (%p)\n", addr);
                return;
        }

        area = remove_vm_area(addr);
        if (unlikely(!area)) {
                WARN(1, KERN_ERR "Trying to vfree() nonexistent vm area (%p)\n",
                addr);
                return;
        }

        debug_check_no_locks_freed(addr, area->size);
        debug_check_no_obj_freed(addr, area->size);

        if (deallocate_pages) {
                int i;

                for (i = 0; i < area->nr_pages; i++) {
                        struct page *page = area->pages[i];

                        BUG_ON(!page);
                        __free_page(page);
                }

                if (area->flags & VM_VPAGES)
                        vfree(area->pages);
                else
                        kfree(area->pages);
        }

        kfree(area);
        return;
}


接著看 area = remove_vm_area(addr); 這一句, remove_vm_area():

struct vm_struct *remove_vm_area(const void *addr)
{
        struct vm_struct *v;
        write_lock(&vmlist_lock);
        v = __remove_vm_area(addr);
        write_unlock(&vmlist_lock);
        return v;
}


就是這個函數(shù)里,用了一個 write_lock,如果別人持有這把鎖的話,在進鎖的時候就會休眠了吧?


第一次在內(nèi)核版發(fā)貼,呵呵

論壇徽章:
0
4 [報告]
發(fā)表于 2008-12-19 15:22 |只看該作者

回復 #3 windaoo 的帖子

sorry ,上面的 write_lock() 鎖是自旋鎖,應該不會睡眠
我也很想知道這個問題的真正原因

論壇徽章:
0
5 [報告]
發(fā)表于 2008-12-19 15:47 |只看該作者
mail list中有一個這個,說vfree不會睡眠。

http://lkml.indiana.edu/hypermail/linux/kernel/0411.2/1955.html

論壇徽章:
0
6 [報告]
發(fā)表于 2008-12-19 18:07 |只看該作者

回復 #3 windaoo 的帖子

這位師兄貼出來的是2.6.26的內(nèi)核代碼吧。

2.6引入了很多更高效的數(shù)據(jù)結(jié)構(gòu),為什么vm空間的管理還是用鏈表,感覺還有待優(yōu)化。

[ 本帖最后由 NewCore 于 2008-12-19 18:11 編輯 ]

論壇徽章:
0
7 [報告]
發(fā)表于 2008-12-19 18:20 |只看該作者
原帖由 scutan 于 2008-12-19 15:47 發(fā)表
mail list中有一個這個,說vfree不會睡眠。

http://lkml.indiana.edu/hypermail/linux/kernel/0411.2/1955.html


可是書上說 vfree 會睡眠,而且我這份代碼的 vfree 前面的注釋這樣寫:

/**
*        vfree  -  release memory allocated by vmalloc()
*        @addr:                memory base address
*
*        Free the virtually continuous memory area starting at @addr, as
*        obtained from vmalloc(), vmalloc_32() or __vmalloc(). If @addr is
*        NULL, no operation is performed.
*
*        Must not be called in interrupt context.
*/
void vfree(const void *addr)
{
        BUG_ON(in_interrupt());
        __vunmap(addr, 1);
}
EXPORT_SYMBOL(vfree);

代碼注釋里說 不能 在中斷上下文中使用


原帖由 NewCore 于 2008-12-19 18:07 發(fā)表
這位師兄貼出來的是2.6.26的內(nèi)核代碼吧。

2.6引入了很多更高效的數(shù)據(jù)結(jié)構(gòu),為什么vm空間的管理還是用鏈表,感覺還有待優(yōu)化。



我這個是 2.6.27 的代碼

論壇徽章:
0
8 [報告]
發(fā)表于 2008-12-20 12:53 |只看該作者

回復 #7 windaoo 的帖子

突然想到,vfree 之所以不能在中斷上下文中使用,應該就是因為那個 write_lock() 了
假如在中斷上下文可以使用 vfree 的話,假設這樣一個情況:
一個線程正好持有了這把鎖,而這時候中斷到來了,也要調(diào) vfree ,想要得到這把鎖——因為中斷處理程序不能被重新調(diào)度,所以被中斷的、執(zhí)有這個鎖的線程也得不到釋放的機會——那么中斷處理程序就會一直等待下去,從而造成死鎖

不知道這樣分析對否?

論壇徽章:
0
9 [報告]
發(fā)表于 2008-12-20 14:57 |只看該作者
等vm多了之后會換成紅黑樹,6l不必擔心啦

論壇徽章:
0
10 [報告]
發(fā)表于 2008-12-20 15:02 |只看該作者
我想內(nèi)核代碼應該保證在中斷上下文不會被搶占吧,lss解釋似乎不合理
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復

  

北京盛拓優(yōu)訊信息技術有限公司. 版權(quán)所有 京ICP備16024965號-6 北京市公安局海淀分局網(wǎng)監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網(wǎng)協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關心和支持過ChinaUnix的朋友們 轉(zhuǎn)載本站內(nèi)容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP