青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-80  評論-24  文章-0  trackbacks-0
初始化進程控制塊數(shù)組的操作是在init_proc_list()內(nèi)完成的,它只被cbegin()函數(shù)調(diào)用,其實它的工作很簡單,就是將進程控制塊中的各個項初始化成初始值。并且將相應(yīng)進程的LDT在GDT中的描述符初始化。這樣當啟動一個進程的時候,只需要在進程自己的LDT和TSS中填入適當?shù)闹导纯桑恍枰頃﨤DT和TSS在GDT中的描述符內(nèi)容。

  1 //初始化init和sys進程
  2 //主要包括進程pid、進程名、ldt、tss以及init進程在gdt中對應(yīng)的項的初始化
  3 static void init_proc01()
  4 {
  5     struct seg_struct ldt_temp[3= {{0x00000x00000x000x000x000x00}, 
  6                                      {0xffff0x00000x000xfa0xcf0x00}, 
  7                                      {0xffff0x00000x000xf20xcf0x00}};
  8 
  9     //pid為0
 10     //進程名為"init"
 11     proc_list[0].pid                = 0;
 12     proc_list[0].ppid                = -1;
 13     proc_list[0].state                = PROC_RUNNING;
 14     proc_list[0].priority            = 15;
 15     proc_list[0].time_slices        = proc_list[0].priority;
 16     proc_list[0].running_time        = 0;
 17     strcpy(proc_list[0].name, "init");
 18     //ldt共包括三項,0->空,1->cs,2->ds&ss
 19     proc_list[0].ldt[0]                = ldt_temp[0];
 20     proc_list[0].ldt[1]                = ldt_temp[1];
 21     proc_list[0].ldt[2]                = ldt_temp[2];
 22     proc_list[0].tss.back_link        = 0;
 23     proc_list[0].tss.esp0            = KSTACKTOP(0); //內(nèi)核態(tài)堆棧頂
 24     proc_list[0].tss.ss0            = KERNEL_SS_SELECTOR;
 25     proc_list[0].tss.esp1            = 0;
 26     proc_list[0].tss.ss1            = 0;
 27     proc_list[0].tss.esp2            = 0;
 28     proc_list[0].tss.ss2            = 0;
 29     proc_list[0].tss.cr3            = (uint32)page_dir; //頁目錄表地址
 30     proc_list[0].tss.eip            = 0;
 31     proc_list[0].tss.eflags            = 0;
 32     proc_list[0].tss.eax            = 0;
 33     proc_list[0].tss.ecx            = 0;
 34     proc_list[0].tss.edx            = 0;
 35     proc_list[0].tss.ebx            = 0;
 36     proc_list[0].tss.esp            = 0;
 37     proc_list[0].tss.ebp            = 0;
 38     proc_list[0].tss.esi            = 0;
 39     proc_list[0].tss.edi            = 0;
 40     proc_list[0].tss.es                = 0x17//指向ldt中的選擇子
 41     proc_list[0].tss.cs                = 0x0f//指向ldt中的選擇子
 42     proc_list[0].tss.ss                = 0x17//指向ldt中的選擇子
 43     proc_list[0].tss.ds                = 0x17//指向ldt中的選擇子
 44     proc_list[0].tss.fs                = 0x17//指向ldt中的選擇子
 45     proc_list[0].tss.gs                = 0x17//指向ldt中的選擇子
 46     proc_list[0].tss.ldt            = LDT_SELECTOR(0);
 47     proc_list[0].tss.trace_bitmap    = 0x80000000;
 48 
 49     set_tss_seg(FIRST_TSS_INDEX, &(proc_list[0].tss));
 50     set_ldt_seg(FIRST_LDT_INDEX, proc_list[0].ldt);
 51 
 52     //pid為1
 53     //進程名為"sys"
 54     proc_list[1].pid                = 1;
 55     proc_list[1].ppid                = 0;
 56     proc_list[1].state                = PROC_RUNNING;
 57     proc_list[1].priority            = 15;
 58     proc_list[1].time_slices        = proc_list[1].priority;
 59     proc_list[1].running_time        = 0;
 60     strcpy(proc_list[1].name, "sys");
 61     //ldt共包括三項,0->空,1->cs,2->ds&ss
 62     proc_list[1].ldt[0]                = ldt_temp[0];
 63     proc_list[1].ldt[1]                = ldt_temp[1];
 64     proc_list[1].ldt[2]                = ldt_temp[2];
 65     proc_list[1].tss.back_link        = 0;
 66     proc_list[1].tss.esp0            = KSTACKTOP(1); //內(nèi)核態(tài)堆棧頂
 67     proc_list[1].tss.ss0            = KERNEL_SS_SELECTOR;
 68     proc_list[1].tss.esp1            = 0;
 69     proc_list[1].tss.ss1            = 0;
 70     proc_list[1].tss.esp2            = 0;
 71     proc_list[1].tss.ss2            = 0;
 72     proc_list[1].tss.cr3            = (uint32)page_dir; //頁目錄表地址
 73     proc_list[1].tss.eip            = (uint32)sys;
 74     proc_list[1].tss.eflags            = 0x1202;
 75     proc_list[1].tss.eax            = 0;
 76     proc_list[1].tss.ecx            = 0;
 77     proc_list[1].tss.edx            = 0;
 78     proc_list[1].tss.ebx            = 0;
 79     proc_list[1].tss.esp            = USTACKTOP(1);
 80     proc_list[1].tss.ebp            = USTACKTOP(1);
 81     proc_list[1].tss.esi            = 0;
 82     proc_list[1].tss.edi            = 0;
 83     proc_list[1].tss.es                = 0x17//指向ldt中的選擇子
 84     proc_list[1].tss.cs                = 0x0f//指向ldt中的選擇子
 85     proc_list[1].tss.ss                = 0x17//指向ldt中的選擇子
 86     proc_list[1].tss.ds                = 0x17//指向ldt中的選擇子
 87     proc_list[1].tss.fs                = 0x17//指向ldt中的選擇子
 88     proc_list[1].tss.gs                = 0x17//指向ldt中的選擇子
 89     proc_list[1].tss.ldt            = LDT_SELECTOR(1);
 90     proc_list[1].tss.trace_bitmap    = 0x80000000;
 91 
 92     set_tss_seg(FIRST_TSS_INDEX + 2&(proc_list[1].tss));
 93     set_ldt_seg(FIRST_LDT_INDEX + 2, proc_list[1].ldt);
 94 }
 95 
 96 void init_proc_list()
 97 {
 98     int i;
 99     for (i = 0; i < NR_PROCS; ++i)
100     {
101         proc_list[i].pid            = -1;
102         proc_list[i].ppid            = -1;
103         proc_list[i].state            = PROC_STOPPED;
104         proc_list[i].priority        = 0;
105         proc_list[i].time_slices    = 0;
106         proc_list[i].running_time    = 0;
107         memset(proc_list[i].name, 0, PROC_NAME_LEN);
108         memset(proc_list[i].ldt, 03 * sizeof(struct seg_struct));
109         memset(&(proc_list[i].tss), 0sizeof(TSS));
110         set_tss_seg(FIRST_TSS_INDEX + i * 2&(proc_list[i].tss));
111         set_ldt_seg(FIRST_LDT_INDEX + i * 2, proc_list[i].ldt);
112     }
113 
114     //啟動的第一個進程是進程鏈表proc_list中第一個進程,為init進程
115     current    = proc_list;
116 }
117 

注意到在process.c文件中有一個current變量,它是proc_struct類型指針,是全局變量,這從linux借鑒過來,用于指向當前正在運行的進程。
下面著重看init_proc01()函數(shù)。
它的作用是在proc_list[0]和proc_list[1]中填入適當?shù)闹担詾閱舆M程init(0號進程)和sys(1號進程)做準備。
我們只研究init進程控制塊的填入過程:
進程id為0,父進程id為-1(因為它是所有進程的父進程,它沒有父進程),優(yōu)先級為15,因此初始時間片為15。仔細研究ldt_temp[]發(fā)現(xiàn)ldt中的cs段描述符屬性為:地址空間為0-4G,DPL=3,說明是用戶級別進程代碼段;ds段描述符屬性為:地址空間為0-4G,DPL=3,說明是用戶級別數(shù)據(jù)段。再看tss中各字段的填入過程,重要的幾個字段分別是:esp0、ss0、cr3、eip、eflags、esp、ebp、以及es、cs、ss、ds、fs、gs以及l(fā)dt,對于init進程,由于我們會在后面手工啟動,所以有些字段可以不填,但是對于其他進程的初始化,這些字段都是必須填寫合適并完整的。

最后看手工啟動進程init的函數(shù),該函數(shù)非常重要,啟動init之后我們的操作系統(tǒng)便有了質(zhì)的飛躍。

 1 void start_proc0()
 2 {
 3     //初始化init進程
 4     init_proc01();
 5 
 6     uint32 ss        = 0x17;
 7     uint32 esp        = USTACKTOP(0);
 8     uint32 eflags    = 0x1202//init進程可以使用I/O命令,同時要求init進程允許中斷
 9     uint32 cs        = 0x0f;
10     uint32 eip        = (uint32)init;
11 
12     /**********************************************************
13      * 下面調(diào)試了很久!!!!!!!!!!!!!!!!!
14      * 不能將enable_hwint(CLOCK_IV);語句放到緊挨sti()的前面
15      * 因為enable_hwint(CLOCK_IV)是c語句宏,展開之后會
16      * 用到堆棧,就會把剛push進去的ss、esp、eflags、cs、eip
17      * 給覆蓋掉!!!!!!!!!!!!!!!!!!!!!!
18      * 將enable_hwint()放到init_clock()里面
19      **********************************************************/
20 
21     //加載init進程對應(yīng)的tss
22     //加載init進程對應(yīng)的ldt
23     ltr(TSS_SELECTOR(0));
24     lldt(LDT_SELECTOR(0));
25     push(ss);                //push ss
26     push(esp);                //push esp
27     push(eflags);            //push eflags
28     push(cs);                //push cs
29     push(eip);                //push eip
30     init_segr();            //初始化ds、es、gs、fs四個段寄存器, 使其指向ldt中的數(shù)據(jù)段描述符
31     sti();                    //打開中斷,從現(xiàn)在開始內(nèi)核態(tài)將允許中斷
32     iretd();                //iretd這條指令之后第一個進程init進程便開始運行了
33 }
34 

手工啟動進程的過程我們采用minix的做法,在內(nèi)核棧中我們偽造一個現(xiàn)場,使得其看似是正在運行進程init然后發(fā)生時鐘中斷后的現(xiàn)場,這樣的現(xiàn)場應(yīng)該是這樣的:
進程init的ss、esp、eflags、cs、eip應(yīng)該已經(jīng)被壓入棧中,寄存器tr應(yīng)該存有進程init在GDT中的tss選擇子,寄存器ldtr應(yīng)該存有進程init在GDT中的ldt選擇子,各個段寄存器應(yīng)該是指向ldt中的選擇子。如果這些都準備好了那就和時鐘中斷處理程序返回前沒什么兩樣了,這樣就可以打開中斷,然后使用一條iret指令就可以了。iret指令會依次從堆棧中彈出eip、cs、eflags、esp、ss,然后切換到進程init的用戶態(tài)繼續(xù)執(zhí)行代碼,這樣我們的第一個init進程就啟動起來了!!!
posted on 2012-02-14 19:34 myjfm 閱讀(355) 評論(0)  編輯 收藏 引用 所屬分類: 操作系統(tǒng)
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            亚洲欧美电影在线观看| 久久影视精品| 欧美好骚综合网| 亚洲精品麻豆| 亚洲精品在线视频观看| 国产精品国产三级国产a| 香蕉久久夜色精品国产使用方法| 国产精品日本| 蜜桃av一区二区| 欧美日韩精品一区二区天天拍小说| 亚洲男人的天堂在线| 中文日韩在线| 国产精品女主播一区二区三区| 久久久久九九视频| 美女精品网站| 久久精品国产77777蜜臀| 欧美日韩三级在线| 久久在线视频在线| 欧美三级第一页| 欧美在线不卡视频| 国产精品久久久久久久久久妞妞| 在线观看欧美| 欧美国产乱视频| 欧美啪啪成人vr| 在线一区二区日韩| 亚洲国产一区视频| 欧美日韩国产一级| 麻豆国产精品一区二区三区 | 久久在线免费| 狂野欧美激情性xxxx欧美| 亚洲国产精品一区二区www在线| 亚洲国产精品va在线看黑人| 久久久久久自在自线| 亚洲黄色三级| 国产美女诱惑一区二区| 亚洲精品一二三| 亚洲视频中文字幕| 亚洲国产成人久久综合| 久久亚洲精品一区二区| 久久久久久亚洲综合影院红桃| 一本到12不卡视频在线dvd| 亚洲在线播放电影| 亚洲午夜精品视频| 久久久伊人欧美| 久久精品国产久精国产一老狼| 老司机午夜精品视频在线观看| 国产精品嫩草影院一区二区| 亚洲网站在线看| 亚洲女爱视频在线| 在线欧美日韩国产| 亚洲一区在线视频| 亚洲国产色一区| 久久爱www久久做| 亚洲自拍偷拍网址| 欧美色视频日本高清在线观看| 久热精品视频在线观看一区| 国产精品综合不卡av| 亚洲人人精品| 亚洲久久一区二区| 亚洲主播在线播放| 欧美揉bbbbb揉bbbbb| 亚洲国产精品一区| 国产毛片久久| 亚洲欧美日韩国产综合在线| 亚洲国产成人在线播放| 欧美国产精品日韩| 亚洲综合国产精品| 日韩视频免费观看高清完整版| 亚洲国产精品久久久久婷婷老年| 欧美成人午夜77777| 日韩一级视频免费观看在线| 久久久精品久久久久| 久热精品在线视频| 午夜一区不卡| 亚洲午夜一区二区| 亚洲欧美日韩视频二区| 99综合在线| 国产精品资源| 欧美二区在线| 国产精品美女久久福利网站| 午夜精品福利一区二区三区av| 亚洲欧美一区二区三区在线| 日韩网站在线| 99精品视频免费观看| 性做久久久久久久免费看| 欧美亚洲综合久久| 麻豆久久婷婷| 欧美国产一区在线| 亚洲福利视频专区| 亚洲另类一区二区| 99精品视频免费观看视频| 美女日韩欧美| 一本色道久久综合亚洲精品小说 | 欧美三区美女| 国产日韩欧美在线视频观看| 一片黄亚洲嫩模| 久久精品99国产精品| 亚洲人成网站999久久久综合| 9l视频自拍蝌蚪9l视频成人| 欧美在线亚洲在线| 99re6热在线精品视频播放速度| 欧美激情第3页| 欧美国产精品劲爆| 亚洲一区不卡| 欧美系列一区| 激情综合久久| 久久爱91午夜羞羞| 亚洲国产一区二区精品专区| 亚洲小视频在线观看| 亚洲在线免费视频| 猫咪成人在线观看| 国内精品久久久久久影视8| 一区二区欧美激情| 亚洲欧美在线网| 欧美综合国产精品久久丁香| 国产精品成人免费精品自在线观看| 国产一区二区三区在线观看网站 | 麻豆久久久9性大片| 久久蜜桃精品| 国产精品视频一二三| 一本色道久久综合亚洲精品婷婷| 欧美大片网址| 亚洲精品美女免费| 日韩视频在线免费| 9人人澡人人爽人人精品| 欧美电影在线观看| 亚洲精品孕妇| 亚洲在线1234| 国产亚洲精品v| 久久美女艺术照精彩视频福利播放| 久久久国产成人精品| 在线日韩一区二区| 欧美成人免费全部| 午夜精品美女自拍福到在线| 久久中文字幕导航| 亚洲免费不卡| 亚洲高清不卡在线| 久久久中精品2020中文| 亚洲激情偷拍| 亚洲欧美另类中文字幕| 欧美日韩一区二区在线| 亚洲精品你懂的| 亚洲电影在线| 欧美福利网址| 亚洲免费播放| 久久久久久综合| 雨宫琴音一区二区在线| 欧美国产日产韩国视频| 亚洲欧洲另类国产综合| 在线视频精品| 国产欧美日韩综合| 欧美精品在线免费| 亚洲免费观看在线视频| 久久亚洲私人国产精品va| 亚洲视频电影图片偷拍一区| 尤物九九久久国产精品的分类| 欧美日韩高清不卡| 久久久噜噜噜久久狠狠50岁| 一区二区三区欧美成人| 久久久伊人欧美| 亚洲一区二区三区四区在线观看 | 国产欧美一区二区三区在线看蜜臀| 午夜亚洲视频| 亚洲一区二区三区777| 日韩一级视频免费观看在线| 欧美国产日韩一区二区三区| 麻豆成人精品| 亚洲综合欧美日韩| 亚洲综合色自拍一区| 最新成人av网站| 狠狠色香婷婷久久亚洲精品| 国产欧美日韩综合| 国产精品一区久久| 国产女主播一区二区三区| 国产日韩欧美一区在线 | 国产日产欧产精品推荐色| 亚洲日本欧美| 精品成人一区二区三区| 欧美不卡视频一区发布| 欧美激情黄色片| 亚洲国语精品自产拍在线观看| 欧美日韩国产综合视频在线| 性欧美在线看片a免费观看| 久久国产天堂福利天堂| 国产主播精品| 欧美视频免费在线| 欧美~级网站不卡| 亚洲成人自拍视频| 亚洲电影自拍| 国产精品一区一区| 一区二区激情| 欧美国产亚洲精品久久久8v| 中文国产成人精品久久一| 欧美高清视频在线播放| 亚洲高清自拍| 亚洲高清视频中文字幕| 久久精品视频99| 在线播放中文字幕一区| 噜噜噜久久亚洲精品国产品小说| 亚洲欧美国产精品va在线观看 |