新聞中心

        EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 嵌入式Linux實時技術(shù)改進(jìn)與實現(xiàn)

        嵌入式Linux實時技術(shù)改進(jìn)與實現(xiàn)

        作者: 時間:2009-04-23 來源:網(wǎng)絡(luò) 收藏

        1、簡介

        本文引用地址:http://www.104case.com/article/152524.htm

        隨著微處理器的發(fā)展,系統(tǒng)已經(jīng)成為計算機(jī)應(yīng)用領(lǐng)域的一個重要的組成部分。雖然為分時操作系統(tǒng),但由于其功能強(qiáng)大、源代碼開放以及可移植性強(qiáng)等優(yōu)勢,已成為日益流行的操作系統(tǒng)的解決方案,然而,在方面它還不能很好地滿足系統(tǒng)方面的需要,其本身僅僅提供了一些實時處理的支持。為使滿足實時應(yīng)用的要求,常用的方法是通過對的內(nèi)核進(jìn)行裁減和修改,使其能夠滿足的要求。目前,我們根據(jù)實際需要對于Linux采用以下方法進(jìn)行

        2、低延遲

        使用兩種方法來低延遲:一種就是鎖分解,即把大循環(huán)中保持的鎖分解為每一輪循環(huán)中都獲得鎖和釋放鎖,典型的代碼結(jié)構(gòu)示例如下:

        鎖分解前:

        spin_lock(x_lock);

        for (…) {some operations;

        …}

        spin_unlock(x_lock);

        鎖分解后:

        for (…) { spin_lock(x_lock);

        some operations;

        spin_unlock(x_lock);}

        另一種是增加搶占點,即自愿被搶占。增加搶占點之后:

        /* Do the write .. */

        for (;;) {

        size_t size = count;

        if (size > chunk)

        size = chunk;

        ret = -EFAULT;

        if (copy_from_user(tty->write_buf, buf, size))

        break;

        lock_kernel();

        ret = write(tty, file, tty->write_buf, size);

        unlock_kernel();

        if (ret = 0)

        break;

        written += ret;

        buf += ret;

        count -= ret;

        if (!count)

        break;

        ret = -ERESTARTSYS;

        if (signal_pending(current))

        break;

        cond_resched();

        }

        語句cond_resched()將判斷是否有進(jìn)程需要搶占當(dāng)前進(jìn)程,如果是將立即發(fā)生調(diào)度,這就是增加的搶占點,它支持四種搶占模式:

        linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)

        上一頁 1 2 3 下一頁

        評論


        技術(shù)專區(qū)

        關(guān)閉
        主站蜘蛛池模板: 吕梁市| 唐河县| 焉耆| 丹棱县| 乐陵市| 麻栗坡县| 涞源县| 博罗县| 桂阳县| 安图县| 绵竹市| 谷城县| 洛浦县| 东平县| 青神县| 搜索| 瓦房店市| 兴国县| 重庆市| 肃北| 苏尼特左旗| 四川省| 玛沁县| 绿春县| 临潭县| 尖扎县| 延安市| 古丈县| 高唐县| 奉贤区| 涞源县| 类乌齐县| 洪湖市| 桐庐县| 腾冲县| 高安市| 宁陕县| 平邑县| 都匀市| 通河县| 荆门市|