• <li id="00i08"><input id="00i08"></input></li>
  • <sup id="00i08"><tbody id="00i08"></tbody></sup>
    <abbr id="00i08"></abbr>
  • 新聞中心

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

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

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

    1、簡介

    本文引用地址:http://www.czjhyjcfj.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 下一頁

    評論


    相關推薦

    技術專區

    關閉
    主站蜘蛛池模板: 乌恰县| 伊川县| 衢州市| 田东县| 饶阳县| 洪洞县| 南阳市| 镇雄县| 阿鲁科尔沁旗| 东安县| 根河市| 繁昌县| 金华市| 岱山县| 吉首市| 建阳市| 萍乡市| 达尔| 鄂州市| 望奎县| 新河县| 右玉县| 筠连县| 桐梓县| 屏东市| 体育| 那坡县| 盐边县| 自治县| 惠安县| 扎赉特旗| 文化| 吉水县| 达孜县| 乐业县| 峡江县| 乌苏市| 刚察县| 马尔康县| 灵寿县| 腾冲县|