• <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 強(qiáng)制刪除內(nèi)核模塊(由于初始化錯(cuò)誤導(dǎo)致rmmod不能刪除)

            /Files/csjiaxin/force_rmmod.rar
            在內(nèi)核模塊的插入過(guò)程中,如果初始化函數(shù)發(fā)生錯(cuò)誤,比如內(nèi)核崩潰,則使用rmmod 會(huì)提示
            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,
            };
             
            在執(zhí)行初始化函數(shù)前,內(nèi)核會(huì)將為此插入模塊新分配的module結(jié)構(gòu)的引用計(jì)數(shù)初始化為1,狀態(tài)state設(shè)置為MODULE_STATE_COMING,由于初始化失敗,所以module結(jié)構(gòu)的引用計(jì)數(shù)和狀態(tài)就停留于此。
            為在rmmod->delete_module->sys_delete_module中有以下的判斷語(yǔ)句:
            /* 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);
            則可以看出只能卸載狀態(tài)state為MODULE_STATE_LIVE,ref數(shù)組中所有CPU引用計(jì)數(shù)之和為0的模塊,這就導(dǎo)致rmmod無(wú)法卸載由于初始化函數(shù)崩潰的模塊。
             
            明白了原理,具體的實(shí)現(xiàn)就比較容易了:
            1 root@lstar-desktop:~/force_rmmod# cat /proc/kallsyms | grep modules
            c069b9a0 d modules
            2 編寫另外一個(gè)內(nèi)核模塊,去操作內(nèi)核所有module組成的鏈表(表頭變量即為modules,我們?cè)诘谝徊揭芽吹剿牡刂? 其中module_name,是傳遞過(guò)來(lái)的需要卸載的內(nèi)核模塊的名稱

                    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;
                    }
              
             
            將這個(gè)內(nèi)核模塊使用insmod插入,執(zhí)行到初始化函數(shù)的時(shí)候,搜索modules鏈表,找到所要操作的module對(duì)象,修改其引用計(jì)數(shù)及狀態(tài),結(jié)束之后就可以使用rmmod命令,卸載之前的模塊了。
             
            ***********************
            今天在寫內(nèi)核模塊時(shí),又發(fā)現(xiàn)了一個(gè)由于卸載過(guò)程module_exit指定的函數(shù)失敗導(dǎo)致內(nèi)核模塊不能卸載,則需要多修改幾個(gè)條件,需要將module的init和exit修改為NULL,則可以完成卸載。
            1 mod->init=0;
            2 mod->exit=0;
             
            實(shí)驗(yàn)環(huán)境 ubuntu9.04 kernel2.6.28-19,源碼見(jiàn)附件
             
            可以完善的地方,
            1 內(nèi)核模塊直接從/proc/kallsyms中讀取modules地址
            2 在將狀態(tài)設(shè)置為MODULE_STATE_LIVE和清空引用計(jì)數(shù)后,可以直接通過(guò)
            /* Free a module, remove from lists, etc (must hold module_mutex). */
            static void free_module(struct module *mod)
            函數(shù)刪除內(nèi)核模塊,則無(wú)需調(diào)用 rmmod刪除。

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

            評(píng)論

            # re: linux 強(qiáng)制刪除內(nèi)核模塊(由于初始化錯(cuò)誤導(dǎo)致rmmod不能刪除) 2012-06-06 17:42 cat1579

            如果編譯的時(shí)候加了 -f 選項(xiàng),刪除的時(shí)候 可以用 rmmod modname -f 來(lái)刪除  回復(fù)  更多評(píng)論   


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            導(dǎo)航

            <2025年5月>
            27282930123
            45678910
            11121314151617
            18192021222324
            25262728293031
            1234567

            統(tǒng)計(jì)

            常用鏈接

            留言簿

            文章檔案

            搜索

            最新評(píng)論

            91精品国产综合久久香蕉| 99国产欧美久久久精品蜜芽 | 久久精品视频91| 色综合合久久天天给综看| 久久99久国产麻精品66| 久久香蕉综合色一综合色88| 久久精品亚洲福利| AV无码久久久久不卡蜜桃| 国内精品久久久久久99蜜桃| 久久久久亚洲爆乳少妇无| 中文字幕无码精品亚洲资源网久久| 欧美熟妇另类久久久久久不卡| 国产精品激情综合久久| 久久亚洲精品无码aⅴ大香| 久久久久一区二区三区| 色婷婷综合久久久久中文一区二区 | 久久精品国产精品亜洲毛片| 久久国产亚洲精品| 久久精品无码一区二区app| 久久精品国产亚洲AV无码娇色 | 久久涩综合| 国内精品久久久久久久涩爱| 久久亚洲私人国产精品vA | 久久免费小视频| 婷婷久久久亚洲欧洲日产国码AV | 久久久久这里只有精品| 久久精品免费一区二区三区| 亚洲国产精品无码成人片久久| 99热热久久这里只有精品68| 99久久人妻无码精品系列| 国内精品久久久久久久久电影网 | 91久久精一区二区三区大全| 亚洲精品国产美女久久久| 久久夜色精品国产亚洲| 无码人妻少妇久久中文字幕| 久久精品人妻一区二区三区| 狠狠综合久久综合中文88| 9999国产精品欧美久久久久久| 久久午夜电影网| 精品水蜜桃久久久久久久| 日日狠狠久久偷偷色综合免费 |