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

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

  1 //初始化init和sys進(jìn)程
  2 //主要包括進(jìn)程pid、進(jìn)程名、ldt、tss以及init進(jìn)程在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     //進(jìn)程名為"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     //進(jìn)程名為"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     //啟動的第一個進(jìn)程是進(jìn)程鏈表proc_list中第一個進(jìn)程,為init進(jìn)程
115     current    = proc_list;
116 }
117 

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

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

 1 void start_proc0()
 2 {
 3     //初始化init進(jìn)程
 4     init_proc01();
 5 
 6     uint32 ss        = 0x17;
 7     uint32 esp        = USTACKTOP(0);
 8     uint32 eflags    = 0x1202//init進(jìn)程可以使用I/O命令,同時要求init進(jìn)程允許中斷
 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進(jìn)去的ss、esp、eflags、cs、eip
17      * 給覆蓋掉!!!!!!!!!!!!!!!!!!!!!!
18      * 將enable_hwint()放到init_clock()里面
19      **********************************************************/
20 
21     //加載init進(jìn)程對應(yīng)的tss
22     //加載init進(jìn)程對應(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這條指令之后第一個進(jìn)程init進(jìn)程便開始運行了
33 }
34 

手工啟動進(jìn)程的過程我們采用minix的做法,在內(nèi)核棧中我們偽造一個現(xiàn)場,使得其看似是正在運行進(jìn)程init然后發(fā)生時鐘中斷后的現(xiàn)場,這樣的現(xiàn)場應(yīng)該是這樣的:
進(jìn)程init的ss、esp、eflags、cs、eip應(yīng)該已經(jīng)被壓入棧中,寄存器tr應(yīng)該存有進(jìn)程init在GDT中的tss選擇子,寄存器ldtr應(yīng)該存有進(jìn)程init在GDT中的ldt選擇子,各個段寄存器應(yīng)該是指向ldt中的選擇子。如果這些都準(zhǔn)備好了那就和時鐘中斷處理程序返回前沒什么兩樣了,這樣就可以打開中斷,然后使用一條iret指令就可以了。iret指令會依次從堆棧中彈出eip、cs、eflags、esp、ss,然后切換到進(jìn)程init的用戶態(tài)繼續(xù)執(zhí)行代碼,這樣我們的第一個init進(jìn)程就啟動起來了!!!
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>
            欧美黄网免费在线观看| 亚洲精品国产精品乱码不99按摩| 亚洲欧美一级二级三级| 久久av一区二区三区亚洲| 国产亚洲欧美另类一区二区三区| 午夜影视日本亚洲欧洲精品| 久久免费视频这里只有精品| 极品尤物av久久免费看| 欧美激情免费观看| 亚洲午夜在线视频| 麻豆91精品| 99精品视频免费观看| 国产精品萝li| 久久久久高清| 亚洲精品在线免费| 久久激情五月丁香伊人| 亚洲国产精品视频| 国产精品久久国产精品99gif| 欧美在线精品一区| 亚洲国产高清视频| 亚洲一区精彩视频| 欲色影视综合吧| 欧美视频中文字幕| 久久久夜精品| 亚洲网在线观看| 欧美黄色大片网站| 性欧美长视频| 亚洲精品乱码久久久久久久久| 国产精品久久久999| 久久亚洲精品一区二区| 中文一区二区| 亚洲福利视频二区| 久久精品视频网| 正在播放日韩| 在线看视频不卡| 国产精品揄拍500视频| 免费观看成人网| 午夜精品久久久久影视 | 欧美精品网站| 欧美中文在线字幕| 一区二区高清视频在线观看| 免费日韩成人| 久久精品亚洲精品| 亚洲视频免费看| 亚洲国产精品v| 狠狠色狠狠色综合人人| 欧美色大人视频| 欧美成人精品激情在线观看| 久久se精品一区精品二区| 亚洲无限乱码一二三四麻| 亚洲国产精品毛片| 欧美成人中文字幕| 久久久噜噜噜久久人人看| 亚洲男同1069视频| 亚洲天堂成人在线观看| 亚洲精品国产品国语在线app| 极品av少妇一区二区| 国产日本欧洲亚洲| 国产精品日日摸夜夜摸av| 欧美日韩综合久久| 欧美黄色免费| 欧美福利视频在线观看| 久久久噜噜噜久久| 久久大逼视频| 欧美在线日韩在线| 欧美一区二区三区在线观看视频| 亚洲欧美激情四射在线日 | 久久性色av| 久久久91精品国产一区二区三区 | 亚洲午夜久久久久久久久电影院 | 免费人成网站在线观看欧美高清| 久久精品国产亚洲高清剧情介绍| 亚洲欧美日韩在线不卡| 亚洲女人av| 性色av一区二区三区在线观看| 亚洲性夜色噜噜噜7777| 亚洲在线视频观看| 亚洲在线视频网站| 西西人体一区二区| 久久精品综合一区| 免费在线看一区| 欧美日韩国产成人精品| 欧美日韩一区二区三区在线视频| 欧美先锋影音| 国产欧美 在线欧美| 国内免费精品永久在线视频| 一区二区亚洲精品| 亚洲国产一区二区三区在线播| 亚洲精品乱码久久久久久按摩观 | 国产日韩欧美在线观看| 国产日韩欧美一区| 亚洲电影免费| 夜夜狂射影院欧美极品| 亚洲免费一区二区| 久久久久国产一区二区| 欧美成人综合一区| 99在线|亚洲一区二区| 午夜精品久久久久久久| 久久一区视频| 欧美日韩中文另类| 国产亚洲一本大道中文在线| 亚洲国产精品一区| 亚洲永久免费| 你懂的亚洲视频| 一区二区三区欧美在线| 久久精品在线| 欧美美女日韩| 国产夜色精品一区二区av| 亚洲精品视频在线观看免费| 亚洲欧美日本国产专区一区| 免费久久精品视频| 一区二区冒白浆视频| 久久久www成人免费无遮挡大片| 欧美电影免费| 国产欧美精品在线| 亚洲免费电影在线| 久久精品国产一区二区三区免费看| 欧美大片在线观看一区| 亚洲一区二区精品| 麻豆九一精品爱看视频在线观看免费| 欧美视频一区二| 在线观看亚洲一区| 午夜免费久久久久| 亚洲国产日韩欧美| 欧美在线高清视频| 欧美性色综合| 亚洲精品久久久久久下一站| 久久九九国产精品| 一本一本大道香蕉久在线精品| 久久精品国产清自在天天线| 国产精品久久久久国产a级| 亚洲欧洲精品一区二区三区不卡 | 最新热久久免费视频| 久久成人av少妇免费| 一本久道久久综合婷婷鲸鱼| 裸体歌舞表演一区二区| 国产一区二区三区黄视频| 亚洲视屏一区| 91久久久久久久久久久久久| 久久久高清一区二区三区| 国产乱人伦精品一区二区 | 一区二区三区偷拍| 欧美激情免费在线| 久久精品在线播放| 国产亚洲网站| 欧美在线二区| 亚洲免费人成在线视频观看| 欧美日韩在线三级| av成人免费在线观看| 91久久精品久久国产性色也91| 鲁鲁狠狠狠7777一区二区| 一区免费观看| 久久一二三区| 久久天堂精品| 亚洲国产精品久久久久秋霞影院| 久久久国产午夜精品| 亚洲欧美日韩在线观看a三区| 国产精品高清一区二区三区| 亚洲午夜久久久| 99伊人成综合| 国产精品美女一区二区在线观看| 亚洲视频每日更新| 一区二区精品国产| 国产精品爽爽ⅴa在线观看| 午夜视频一区二区| 亚洲一区日韩在线| 国产精品午夜av在线| 欧美一区二区三区视频免费| 性欧美超级视频| 激情成人亚洲| 亚洲风情在线资源站| 欧美久久一级| 亚洲中字黄色| 欧美在线日韩精品| 亚洲国产精品视频一区| 亚洲国产片色| 国产精品成人一区二区网站软件| 翔田千里一区二区| 久久九九精品99国产精品| 亚洲国产91| 亚洲精选久久| 国产精品尤物福利片在线观看| 久久久精品动漫| 久久综合久久综合久久| 日韩一区二区免费看| 亚洲亚洲精品三区日韩精品在线视频| 国产精品中文字幕欧美| 久久久久久久久岛国免费| 免费观看欧美在线视频的网站| av不卡在线看| 新片速递亚洲合集欧美合集 | 亚洲美女av电影| 亚洲网站在线观看| 一区视频在线| 亚洲精品一二三| 国产欧美在线播放| 亚洲国产精品电影| 国产精品久久久久久久久借妻| 玖玖综合伊人| 欧美日韩在线播放|