新聞中心

        EEPW首頁 > 嵌入式系統 > 設計應用 > 嵌入式Linux實時技術改進與實現

        嵌入式Linux實時技術改進與實現

        作者: 時間:2009-04-23 來源:網絡 收藏

        1、簡介

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

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

        2、低延遲

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

        鎖分解前:

        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()將判斷是否有進程需要搶占當前進程,如果是將立即發生調度,這就是增加的搶占點,它支持四種搶占模式:

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

        上一頁 1 2 3 下一頁

        評論


        相關推薦

        技術專區

        關閉
        主站蜘蛛池模板: 武城县| 吴堡县| 五峰| 旌德县| 客服| 普格县| 吴忠市| 开原市| 安阳市| 古蔺县| 噶尔县| 乃东县| 禄丰县| 广东省| 大化| 小金县| 拉孜县| 乐至县| 苍溪县| 新野县| 石楼县| 子长县| 苍山县| 彭泽县| 抚宁县| 鄂州市| 原平市| 株洲县| 柯坪县| 东宁县| 九龙城区| 上犹县| 大姚县| 清河县| 盘山县| 洮南市| 巴东县| 石棉县| 万宁市| 红河县| 电白县|