• <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>

            Jiwu Bu

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              32 隨筆 :: 0 文章 :: 25 評論 :: 0 Trackbacks
            對linux-2.6.34源碼rootfs文件系統加載學習筆記

            1.內核啟動調用start_kernel函數進行初始化。
            asmlinkage void __init start_kernel(void//init\Main.c:528
            {
                buffer_init();
                key_init();
                security_init();
                vfs_caches_init(totalram_pages);
            //678行,vfs初始化
                signals_init();
            }
            2.start_kernel調用vfs_caches_init對vfs進行初始化。
            //fs\Dcach.c:2354行
            void __init vfs_caches_init(unsigned long mempages)
            {
               
            .......
                dcache_init();
                inode_init();
                files_init(mempages);
                mnt_init(); 
            //mnt初始化
                bdev_cache_init();
                chrdev_init();
            }

            3.在vfs_caches_init調用fs\namespace.c 2321行的mnt_init函數
            void __init mnt_init(void)
            {
                
                init_rootfs();    
            //初始化rootfs文件系統
                init_mount_tree(); //初始化加載樹
            }
            4. fs\ramfs第308行的init_rootfs函數初始化rootfs文件系統
            int __init init_rootfs(void)
            {
                
            int err;

                err 
            = bdi_init(&ramfs_backing_dev_info);
                
            if (err)
                    
            return err;

                err 
            = register_filesystem(&rootfs_fs_type);//注冊rootfs文件系統
                if (err)
                    bdi_destroy(
            &ramfs_backing_dev_info);

                
            return err;
            }
            rootfs文件系統信息fs\ramfs第289行
            static struct file_system_type rootfs_fs_type = {
                .name        
            = "rootfs",
                .get_sb        
            = rootfs_get_sb,
                .kill_sb    
            = kill_litter_super,
            };

            5.調用register_filesystem函數將rootfs注冊到file_systems文件系統中。
            //fs\Filesystem.c第69行。
            int
             register_filesystem(struct file_system_type * fs)
            {
                
            int res = 0;
                
            struct file_system_type ** p;

                BUG_ON(strchr(fs
            ->name, '.'));
                
            if (fs->next)
                    
            return -EBUSY;
                INIT_LIST_HEAD(
            &fs->fs_supers);
                write_lock(
            &file_systems_lock);
                p 
            = find_filesystem(fs->name, strlen(fs->name));//查找到文件系統加載位置
                
            if (*p)
                    res 
            = -EBUSY;
                
            else
                    
            *= fs;
                write_unlock(
            &file_systems_lock);
                
            return res;
            }
            file_systems變量是所有文件系統鏈表的頭指針。通過以上過程rootfs_fs_type就加入到了file_systems鏈表頭的file_system_type類型的鏈表中。可以通過file_systems指針遍歷這個鏈表,得到特定的文件系統file_system_type 指針。
            posted on 2010-07-04 16:58 bujiwu 閱讀(3564) 評論(0)  編輯 收藏 引用 所屬分類: Linux內核VFS
            亚洲AV乱码久久精品蜜桃| 99国产欧美精品久久久蜜芽 | 久久婷婷色综合一区二区| 天天做夜夜做久久做狠狠| 一本色道久久综合亚洲精品| 蜜臀久久99精品久久久久久小说 | 三级片免费观看久久| 97久久婷婷五月综合色d啪蜜芽 | 久久婷婷五月综合成人D啪| 精品国产乱码久久久久久呢| 色偷偷888欧美精品久久久| 无码人妻少妇久久中文字幕| 国产精品一久久香蕉国产线看观看| 激情综合色综合久久综合| 久久发布国产伦子伦精品| 香蕉aa三级久久毛片| 99久久精品免费观看国产| 久久综合久久自在自线精品自| 91久久精品电影| 狠狠干狠狠久久| 国产精品美女久久久久 | 97精品依人久久久大香线蕉97| 99久久中文字幕| 97久久国产综合精品女不卡| 久久香蕉国产线看观看猫咪?v| 久久99国产精品久久| 国产三级久久久精品麻豆三级| 久久香蕉国产线看观看99| 国产综合免费精品久久久| 久久精品国产亚洲αv忘忧草| 亚洲精品无码久久久久久| 国内精品久久久久久久影视麻豆| 久久精品一区二区三区中文字幕| 97久久精品午夜一区二区| 久久精品夜夜夜夜夜久久| 久久天天躁狠狠躁夜夜不卡 | 日韩久久无码免费毛片软件| 人人狠狠综合久久亚洲88| 精品久久久久久| 久久国产精品-国产精品| 久久成人精品视频|