<dfn id="is4kg"></dfn>
  • <ul id="is4kg"></ul>
  • <abbr id="is4kg"></abbr>
  • <ul id="is4kg"></ul>
    <bdo id="is4kg"></bdo>

    曙海教育集團(tuán)論壇ARM專(zhuān)區(qū) → ARM Linux進(jìn)程創(chuàng)建源代碼分析


      共有6871人關(guān)注過(guò)本帖樹(shù)形打印

    主題:ARM Linux進(jìn)程創(chuàng)建源代碼分析

    美女呀,離線,留言給我吧!
    wangxinxin
      1樓 個(gè)性首頁(yè) | 博客 | 信息 | 搜索 | 郵箱 | 主頁(yè) | UC


    加好友 發(fā)短信
    等級(jí):青蜂俠 帖子:1393 積分:14038 威望:0 精華:0 注冊(cè):2010-11-12 11:08:23
    ARM Linux進(jìn)程創(chuàng)建源代碼分析  發(fā)帖心情 Post By:2010-11-18 13:43:15

    創(chuàng)建進(jìn)程需要使用系統(tǒng)調(diào)用,一共有三個(gè),分別是:sys_fork,sys_vfork,sys_clone
    ?所有的這三個(gè)系統(tǒng)調(diào)用都要使用do_fork函數(shù),它是創(chuàng)建進(jìn)程的主體,我們將在下面重點(diǎn)介紹
    ?原型分別如下:
    /* Fork a new task - this creates a new program thread.
    * This is called indirectly via a small wrapper
    */
    asmlinkage int sys_fork(struct pt_regs *regs)
    {
    return do_fork(SIGCHLD, regs->ARM_sp, regs, 0);
    }
    /* Clone a task - this clones the calling program thread.
    * This is called indirectly via a small wrapper
    */
    asmlinkage int sys_clone(unsigned long clone_flags, unsigned long newsp, struct pt_regs *regs)
    {
    if (!newsp)
    newsp = regs->ARM_sp;
    return do_fork(clone_flags, newsp, regs, 0);
    }
    asmlinkage int sys_vfork(struct pt_regs *regs)
    {
    return do_fork(CLONE_VFORK | CLONE_VM | SIGCHLD, regs->ARM_sp, regs, 0);
    }?這三個(gè)系統(tǒng)調(diào)用的區(qū)別是:
    sys_fork是完整的從父進(jìn)程派生出一個(gè)子進(jìn)程;sys_clone可以通過(guò)參數(shù)clone_flags決定需要復(fù)制給子進(jìn)程的資源;而sys_vfork則只是產(chǎn)生了一個(gè)新的task_struct,它還是和父進(jìn)程共享其余的所有的資源,所以它不是真正的進(jìn)程,只能算是線程,他將組塞父進(jìn)程的運(yùn)行直到自己運(yùn)行結(jié)束為止。
    ?有一個(gè)信號(hào)叫做SIGCHLD,當(dāng)子進(jìn)程停止或結(jié)束,父進(jìn)程將收到一個(gè)SIGCHLD信號(hào),默認(rèn)動(dòng)作是忽略。 ?也就是說(shuō)fork才是真正的clone。?背景知識(shí):進(jìn)程和進(jìn)程的狀態(tài)
    #define TASK_RUNNING 0
    #define TASK_INTERRUPTIBLE 1
    #define TASK_UNINTERRUPTIBLE 2
    #define TASK_ZOMBIE 4
    #define TASK_STOPPED 8?1) TASK_RUNNING:含義是假定任務(wù)已經(jīng)處于運(yùn)行隊(duì)列中。至于不是已經(jīng)處于運(yùn)行狀態(tài)的原因是由于將一個(gè)任務(wù)標(biāo)識(shí)為T(mén)ASK_RUNNING和將該任務(wù)移動(dòng)到運(yùn)行隊(duì)列不是一個(gè)原子操作。
    ?2) TASK_INTERRUPTIBLE:含義是任務(wù)處于休眠狀態(tài)但可以通過(guò)一個(gè)信號(hào)或者休眠中止時(shí)鐘喚醒。
    ?3) TASK_UNINTERRUPTIBLE:含義類(lèi)似于TASK_INTERRUPTIBLE,但任務(wù)不能被喚醒。
    ?4) TASK_ZOMBIE:含義是任務(wù)已經(jīng)被中止但它的狀態(tài)還沒(méi)被父進(jìn)程獲取。
    ?5) TASK_STOPPED:含義是由于任務(wù)控制信號(hào)或者ptrace系統(tǒng)調(diào)用,任務(wù)已經(jīng)被停止。
    ?int do_fork(unsigned long clone_flags, unsigned long stack_start,
    ? struct pt_regs *regs, unsigned long stack_size)
    ?{
    ? int retval;
    ? struct task_struct *p;
    ? struct completion vfork;
    ?? retval = -EPERM;
    if (clone_flags & CLONE_PID) {
    ? if (current->pid)
    ? goto fork_out;
    ? }
    ?? retval = -ENOMEM;
    ?上面這段代碼的意思是: 如果clone_flags的CLONE_PID置位,則除非是0號(hào)進(jìn)程
    否則將返回錯(cuò)誤信息EPERM. clone_flags的定義將在后面介紹,0號(hào)進(jìn)程就是操作
    系統(tǒng)啟動(dòng)時(shí)創(chuàng)建的第一個(gè)進(jìn)程.上面的代碼中if(current->pid)要成立,除非是0號(hào)
    進(jìn)程.其中pid是進(jìn)程標(biāo)志符
    ?p = alloc_task_struct(); /* franc: we will alloc one page space as task_struct */
    ? if (!p)
    ? goto fork_out;
    ?? *p = *current; /* franc: just copy all the info of its parent to this new process */
    ?? retval = -EAGAIN;
    ?上面代碼的意思是: 申請(qǐng)一個(gè)新的內(nèi)存控制塊,其中alloc_task_struct是在/arch
    /arm/kernel/process.c中定義:
    struct task_struct *alloc_task_struct(void)其中:
    ll_alloc_task_struct() 在/include/asm-arm/proc-armv/processor.h中定義:
    #define ll_alloc_task_struct() ((struct task_struct *) __get_free_pages(GFP_KERNEL,1))
    ?_get_free_pages是要申請(qǐng)兩個(gè)頁(yè)面,頁(yè)面是內(nèi)存管理的有關(guān)內(nèi)容,這兒大家只要一個(gè)頁(yè)面占4K個(gè)字節(jié)就可以了.兩個(gè)頁(yè)面就是8K個(gè)字節(jié),而大家查一下進(jìn)程控制塊的大小就可以知道它只有1600B左右,也就是說(shuō)它只有1.5K左右,那么還剩下將近6.5K的空間去有什么用呢?其實(shí)剩余的空間是作為內(nèi)核?臻g.如果申請(qǐng)內(nèi)存空間失敗則直接棧道fork_out處執(zhí)行,fork_out在后面有定義
    ?然后就將父進(jìn)程的所有信息直接拷貝給它。
    ?if (atomic_read(&p->user->processes) >= p->rlim[RLIMIT_NPROC].rlim_cur
    ? && !capable(CAP_SYS_ADMIN) && !capable(CAP_SYS_RESOURCE)) /* franc: check if we have spawned too many processes */
    ? goto bad_fork_free;
    ?? atomic_inc(&p->user->__count); /* make the process number tracable */
    ? atomic_inc(&p->user->processes);
    ?上面代碼的意思: 如果父進(jìn)程已經(jīng)用了用戶進(jìn)程,則修改p->user->_count和
    p->user->processes,將其數(shù)目加1,當(dāng)然除非用戶進(jìn)程的 RLIMIT_NPROC
    已經(jīng)超過(guò)額定數(shù)目。

    支持(0中立(0反對(duì)(0單帖管理 | 引用 | 回復(fù) 回到頂部

    返回版面帖子列表

    ARM Linux進(jìn)程創(chuàng)建源代碼分析








    簽名
    主站蜘蛛池模板: 色哟哟在线网站| 91大神精品在线观看| 在线你懂的网站| 欧美第一页草草影院浮力| 高级别墅贵妇交换俱乐部小说| 你懂的视频在线播放| 四虎www成人影院| 加勒比一本大道香蕉在线视频| 国产精品k频道在线看| 天天夜碰日日摸日日澡| 无码A级毛片免费视频内谢| 精品国产国产综合精品| 中文字幕一区二区三区久久网站 | 最近免费中文字幕大全高清10 | 久久久无码精品亚洲日韩按摩| 亚洲人成日本在线观看| 亚洲国产成人精品电影| 亚洲国产成+人+综合| 加勒比色综合久久久久久久久 | 亚洲AV成人片色在线观看高潮 | 在线观看中文字幕码2023| 成年免费视频黄网站在线观看| 性xxxxfreexxxxx国产| 在线观看国产欧美| 国产精品久久久久9999| 国产三级第一页| 国产主播福利精品一区二区| 厨房切底征服岳| 亚洲第一页在线| 亚洲欧美视频一区| 亚洲av永久无码精品天堂久久| 久久激情综合网| 久久精品国内一区二区三区| 七仙女欲春3一级裸片在线播放| 一区二区三区在线观看视频| 麻豆精品一区二区三区免费| 视频二区在线观看| 肥大bbwbbw高潮喷水| 欧美日韩黄色片| 成人短视频完整版在线播放| 官场猎艳警花美乳美妇|