• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            linux 強制刪除內核模塊(由于初始化錯誤導致rmmod不能刪除)

            /Files/csjiaxin/force_rmmod.rar
            在內核模塊的插入過程中,如果初始化函數發生錯誤,比如內核崩潰,則使用rmmod 會提示
            ERROR: Module export is in use
             
            解決方法如下:
             
            struct module{
            enum module_state state;
            /* Reference counts */
             struct module_ref ref[NR_CPUS];
            }
             
            enum module_state
            {
             MODULE_STATE_LIVE,
             MODULE_STATE_COMING,
             MODULE_STATE_GOING,
            };
             
            在執行初始化函數前,內核會將為此插入模塊新分配的module結構的引用計數初始化為1,狀態state設置為MODULE_STATE_COMING,由于初始化失敗,所以module結構的引用計數和狀態就停留于此。
            為在rmmod->delete_module->sys_delete_module中有以下的判斷語句:
            /* Doing init or already dying? */
             if (mod->state != MODULE_STATE_LIVE) {
              /* FIXME: if (force), slam module count and wake up
                               waiter --RR */
              DEBUGP("%s already dying\n", mod->name);
              ret = -EBUSY;
              goto out;
             }
            if (!forced && module_refcount(mod) != 0)
              wait_for_zero_refcount(mod);
            則可以看出只能卸載狀態state為MODULE_STATE_LIVE,ref數組中所有CPU引用計數之和為0的模塊,這就導致rmmod無法卸載由于初始化函數崩潰的模塊。
             
            明白了原理,具體的實現就比較容易了:
            1 root@lstar-desktop:~/force_rmmod# cat /proc/kallsyms | grep modules
            c069b9a0 d modules
            2 編寫另外一個內核模塊,去操作內核所有module組成的鏈表(表頭變量即為modules,我們在第一步已看到他的地址) 其中module_name,是傳遞過來的需要卸載的內核模塊的名稱

                    struct list_head *modules=(struct list_head *)0xc069b9a0;
                    struct module *mod=0;
                    struct module *list_mod;
                    int i;
                    int zero=0;
                 
                    list_for_each_entry(list_mod,modules,list){
                            if(strcmp(list_mod->name,module_name) == 0)
                              mod=list_mod;
                    }
               
               
                    mod->state=MODULE_STATE_LIVE;
                    for (i = 0; i < NR_CPUS; i++){
                                                  mod->ref[i].count=*(local_t *)&zero;
                    }
              
             
            將這個內核模塊使用insmod插入,執行到初始化函數的時候,搜索modules鏈表,找到所要操作的module對象,修改其引用計數及狀態,結束之后就可以使用rmmod命令,卸載之前的模塊了。
             
            ***********************
            今天在寫內核模塊時,又發現了一個由于卸載過程module_exit指定的函數失敗導致內核模塊不能卸載,則需要多修改幾個條件,需要將module的init和exit修改為NULL,則可以完成卸載。
            1 mod->init=0;
            2 mod->exit=0;
             
            實驗環境 ubuntu9.04 kernel2.6.28-19,源碼見附件
             
            可以完善的地方,
            1 內核模塊直接從/proc/kallsyms中讀取modules地址
            2 在將狀態設置為MODULE_STATE_LIVE和清空引用計數后,可以直接通過
            /* Free a module, remove from lists, etc (must hold module_mutex). */
            static void free_module(struct module *mod)
            函數刪除內核模塊,則無需調用 rmmod刪除。

            posted on 2010-12-14 16:00 lstar 閱讀(13861) 評論(1)  編輯 收藏 引用

            評論

            # re: linux 強制刪除內核模塊(由于初始化錯誤導致rmmod不能刪除) 2012-06-06 17:42 cat1579

            如果編譯的時候加了 -f 選項,刪除的時候 可以用 rmmod modname -f 來刪除  回復  更多評論   

            導航

            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            統計

            常用鏈接

            留言簿

            文章檔案

            搜索

            最新評論

            久久久久免费视频| 久久天天躁狠狠躁夜夜躁2O2O| 久久99精品国产99久久6男男| 久久精品草草草| 久久九色综合九色99伊人| 亚洲精品国产第一综合99久久 | 精品久久一区二区三区| 国产福利电影一区二区三区,免费久久久久久久精 | 久久精品国产久精国产思思| 成人久久精品一区二区三区| 久久久久综合中文字幕| 国产情侣久久久久aⅴ免费| 久久久噜噜噜久久| 亚洲综合久久综合激情久久 | 国产精品九九久久免费视频 | 精品人妻久久久久久888| 欧美大战日韩91综合一区婷婷久久青草| 亚洲伊人久久精品影院| 狠狠综合久久综合中文88| 久久久久99精品成人片试看 | 一本久道久久综合狠狠躁AV| 一本大道久久a久久精品综合| 久久伊人精品一区二区三区| 久久精品国产亚洲AV不卡| 青青热久久综合网伊人| 久久久久久国产精品免费无码| 热久久最新网站获取| 久久青青草原精品国产软件| 欧美久久综合性欧美| 国产精品99久久99久久久| 无码人妻精品一区二区三区久久 | 久久国产精品一国产精品金尊| 国产精品久久婷婷六月丁香| 久久人人爽人人澡人人高潮AV| 精品国产91久久久久久久a| 国产激情久久久久影院老熟女| 国产精品久久久久久久久鸭| 99久久精品费精品国产一区二区| 97久久超碰成人精品网站| 国产精品久久久久久搜索| 一本大道加勒比久久综合|