新聞中心

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

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

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

1、簡介

本文引用地址:http://m.butianyuan.cn/article/152524.htm

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

另一種是增加搶占點(diǎn),即自愿被搶占。增加搶占點(diǎn)之后:

/* 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)度,這就是增加的搶占點(diǎn),它支持四種搶占模式:

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

上一頁 1 2 3 下一頁

評論


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

關(guān)閉