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

隨筆-80  評論-24  文章-0  trackbacks-0
初始化進程控制塊數組的操作是在init_proc_list()內完成的,它只被cbegin()函數調用,其實它的工作很簡單,就是將進程控制塊中的各個項初始化成初始值。并且將相應進程的LDT在GDT中的描述符初始化。這樣當啟動一個進程的時候,只需要在進程自己的LDT和TSS中填入適當的值即可,不需要理會LDT和TSS在GDT中的描述符內容。

  1 //初始化init和sys進程
  2 //主要包括進程pid、進程名、ldt、tss以及init進程在gdt中對應的項的初始化
  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); //內核態堆棧頂
 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); //內核態堆棧頂
 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()函數。
它的作用是在proc_list[0]和proc_list[1]中填入適當的值,以為啟動進程init(0號進程)和sys(1號進程)做準備。
我們只研究init進程控制塊的填入過程:
進程id為0,父進程id為-1(因為它是所有進程的父進程,它沒有父進程),優先級為15,因此初始時間片為15。仔細研究ldt_temp[]發現ldt中的cs段描述符屬性為:地址空間為0-4G,DPL=3,說明是用戶級別進程代碼段;ds段描述符屬性為:地址空間為0-4G,DPL=3,說明是用戶級別數據段。再看tss中各字段的填入過程,重要的幾個字段分別是:esp0、ss0、cr3、eip、eflags、esp、ebp、以及es、cs、ss、ds、fs、gs以及ldt,對于init進程,由于我們會在后面手工啟動,所以有些字段可以不填,但是對于其他進程的初始化,這些字段都是必須填寫合適并完整的。

最后看手工啟動進程init的函數,該函數非常重要,啟動init之后我們的操作系統便有了質的飛躍。

 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      * 下面調試了很久!!!!!!!!!!!!!!!!!
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進程對應的tss
22     //加載init進程對應的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中的數據段描述符
31     sti();                    //打開中斷,從現在開始內核態將允許中斷
32     iretd();                //iretd這條指令之后第一個進程init進程便開始運行了
33 }
34 

手工啟動進程的過程我們采用minix的做法,在內核棧中我們偽造一個現場,使得其看似是正在運行進程init然后發生時鐘中斷后的現場,這樣的現場應該是這樣的:
進程init的ss、esp、eflags、cs、eip應該已經被壓入棧中,寄存器tr應該存有進程init在GDT中的tss選擇子,寄存器ldtr應該存有進程init在GDT中的ldt選擇子,各個段寄存器應該是指向ldt中的選擇子。如果這些都準備好了那就和時鐘中斷處理程序返回前沒什么兩樣了,這樣就可以打開中斷,然后使用一條iret指令就可以了。iret指令會依次從堆棧中彈出eip、cs、eflags、esp、ss,然后切換到進程init的用戶態繼續執行代碼,這樣我們的第一個init進程就啟動起來了!!!
posted on 2012-02-14 19:34 myjfm 閱讀(354) 評論(0)  編輯 收藏 引用 所屬分類: 操作系統
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美一区二区三区四区视频 | 免费在线观看日韩欧美| 中文国产成人精品久久一| 亚洲精品国产拍免费91在线| 另类专区欧美制服同性| 蜜桃久久精品乱码一区二区| 免费视频亚洲| 亚洲精品美女91| 亚洲网站视频福利| 欧美中文字幕| 欧美激情精品久久久久久久变态| 欧美片在线播放| 国产亚洲电影| 亚洲欧洲一区二区三区久久| av成人激情| 久久福利影视| 老牛国产精品一区的观看方式| 欧美大片在线观看| 免费一级欧美在线大片| 亚洲欧美激情视频在线观看一区二区三区| 亚洲欧美日韩在线观看a三区 | 亚洲激情av| 亚洲精品一区二区三区四区高清| 99riav久久精品riav| 香蕉亚洲视频| 亚洲欧洲日本国产| 亚洲欧美日韩国产| 欧美国产日韩精品免费观看| 国产精品视频一| 亚洲国产精品va| 欧美亚洲自偷自偷| 亚洲精选成人| 久久午夜精品| 国产精品视频最多的网站| 亚洲激精日韩激精欧美精品| 午夜欧美精品| 日韩一级在线| 免费欧美视频| 国产一区二区三区精品久久久| 亚洲免费观看在线视频| 久久综合五月| 亚欧成人在线| 国产精品久久久久久五月尺| 亚洲精品一区久久久久久| 久久精品72免费观看| 亚洲视频免费在线| 欧美性片在线观看| 亚洲免费精彩视频| 欧美激情一区二区三区| 久久精品理论片| 国产一区美女| 久久免费高清| 欧美一区影院| 国产亚洲永久域名| 欧美在线免费视频| 亚洲欧美综合网| 国产香蕉久久精品综合网| 午夜精品一区二区三区在线视| 亚洲国产欧美国产综合一区 | 国产精品久久久久av免费| 日韩视频久久| 亚洲日本va午夜在线影院| 欧美a一区二区| 亚洲人精品午夜| 欧美1区2区| 欧美激情a∨在线视频播放| 亚洲精品久久久久中文字幕欢迎你| 美女主播一区| 久久综合国产精品台湾中文娱乐网| 黄色影院成人| 欧美成人免费小视频| 欧美 日韩 国产 一区| 亚洲精品免费在线播放| 亚洲免费成人av电影| 国产精品xxxxx| 洋洋av久久久久久久一区| 亚洲视频免费看| 国产精品久久二区| 亚洲少妇在线| 亚洲先锋成人| 狠狠色伊人亚洲综合成人| 蜜臀a∨国产成人精品| 蜜桃久久精品乱码一区二区| 日韩一级网站| 午夜精品美女久久久久av福利| 禁断一区二区三区在线| 亚洲第一区中文99精品| 欧美日韩精品在线| 久久精品视频免费| 欧美激情视频一区二区三区在线播放| 欧美精品七区| 欧美在线黄色| 男女精品网站| 午夜日韩在线观看| 久久久久一区| 亚洲你懂的在线视频| 久久福利毛片| 亚洲少妇一区| 久久香蕉国产线看观看av| 一区二区三区日韩在线观看| 欧美一区二区三区视频免费播放| 日韩视频专区| 欧美一区国产一区| 99精品99| 久久久亚洲影院你懂的| 亚洲天堂成人在线视频| 久久国产精彩视频| 亚洲视频电影图片偷拍一区| 久久精品天堂| 性欧美8khd高清极品| 免费欧美在线| 久久精品国产第一区二区三区| 欧美国产乱视频| 免费成人在线观看视频| 国产精品亚洲综合久久| 亚洲免费大片| 日韩亚洲欧美在线观看| 久久免费国产精品1| 亚洲欧美日韩在线| 欧美日韩www| 欧美丰满高潮xxxx喷水动漫| 国产亚洲精品v| 亚洲伊人第一页| 亚洲一区二区毛片| 欧美日本韩国一区| 亚洲人体偷拍| 99国产精品久久久久老师| 欧美a级在线| 亚洲高清网站| 亚洲精品一区二区三区四区高清| 久久亚洲不卡| 欧美高清在线观看| 亚洲高清免费| 美日韩免费视频| 免费亚洲电影| 亚洲高清视频一区二区| 快射av在线播放一区| 欧美不卡在线视频| 亚洲国内自拍| 欧美国产日韩免费| 亚洲毛片在线看| 亚洲一区中文| 亚洲一区二区三区四区五区午夜| 欧美成人精品影院| 欧美高清成人| 夜夜嗨av色综合久久久综合网| 欧美成人四级电影| 91久久黄色| 99精品久久久| 国产精品每日更新在线播放网址| 一本久久a久久免费精品不卡| 亚洲无线视频| 国产精品久久午夜夜伦鲁鲁| 亚洲一区二区三区欧美| 欧美在线观看视频一区二区三区 | 欧美日韩国产精品自在自线| 亚洲人久久久| 亚洲欧美综合国产精品一区| 国产婷婷色一区二区三区在线| 久久精品女人| 亚洲国产欧美在线人成| 在线综合+亚洲+欧美中文字幕| 国产精品theporn| 欧美一级片一区| 欧美大片在线影院| 亚洲午夜久久久| 黑人一区二区三区四区五区| 蜜臀久久99精品久久久久久9| 亚洲高清视频在线| 亚洲免费在线观看视频| 禁断一区二区三区在线| 欧美伦理一区二区| 午夜亚洲影视| 亚洲日本成人| 久久久久国产精品厨房| 日韩午夜中文字幕| 国际精品欧美精品| 欧美日韩一区在线视频| 久久精品99无色码中文字幕 | 99精品免费视频| 免费一级欧美片在线观看| 亚洲欧美成人在线| 亚洲精品裸体| 黄色成人免费网站| 欧美日韩在线观看一区二区三区 | 久久日韩粉嫩一区二区三区| 99综合在线| 亚洲第一网站免费视频| 国产精品毛片大码女人| 欧美精品一区二区三区视频| 久久精品国产91精品亚洲| aa级大片欧美| 亚洲人成人77777线观看| 免费人成精品欧美精品| 久久国产高清| 亚洲在线观看视频| 99精品视频免费观看| 91久久在线| 一区二区在线视频| 国产亚洲观看|