新聞中心

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

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

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

1、簡介

本文引用地址:http://2s4d.com/article/152524.htm

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

2、低延遲

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

鎖分解前:

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

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

上一頁 1 2 3 下一頁

評論


相關推薦

技術專區(qū)

關閉