一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

論述不同的搶占模型如何影響用戶和系統(tǒng)的行為

Linux閱碼場 ? 來源:Linuxer ? 2020-06-03 16:03 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

當(dāng)配置Linux內(nèi)核的時(shí)候,我們可以選擇一些參數(shù),這些參數(shù)能影響系統(tǒng)的行為。你可以用不同的優(yōu)先級、調(diào)度類和搶占模型來工作。正確地選擇這些參數(shù)是非常重要的。

本文將論述不同的搶占模型如何影響用戶和系統(tǒng)的行為。

當(dāng)你使用 make menuconfig配置內(nèi)核的時(shí)候,你能看到這樣的菜單:

為了深入理解這三個(gè)搶占模型的區(qū)別,我們將寫一個(gè)案例:

2個(gè)線程,一個(gè)高優(yōu)先級RT(50),一個(gè)低優(yōu)先級RT(30)

高優(yōu)先級的線程要睡眠3秒

低優(yōu)先級的線程用CPU來做計(jì)算

3秒后高優(yōu)先級線程喚醒。

如果低優(yōu)先級的線程陷入系統(tǒng)調(diào)用,高優(yōu)先級的線程睡眠到期,究竟會發(fā)生什么?下面我們來一種模型一種模型地看。

No Forced Preemption

這種情況下,上下文切換發(fā)生在系統(tǒng)調(diào)用返回用戶空間的點(diǎn)。案例如下:

2個(gè)線程,一個(gè)高優(yōu)先級RT(50),一個(gè)低優(yōu)先級RT(30)

高優(yōu)先級的線程要睡眠3秒

低優(yōu)先級的線程進(jìn)入系統(tǒng)調(diào)用計(jì)算5秒

5秒后低優(yōu)先級線程從內(nèi)核系統(tǒng)調(diào)用返回

高優(yōu)先級線程將醒來(但是比預(yù)期遲了2秒)。

內(nèi)核代碼,簡單的字符設(shè)備:

#include #include #include #include #include #include #include #include #include #include #include #include static dev_t my_dev;static struct cdev *my_cdev; // callback for read system call on the devicestatic ssize_t my_read(struct file *file, char __user *buf,size_t count,loff_t *ppos){ int len=5; if(*ppos > 0) { return 0; } mdelay(5000); // busy-wait for 5 seconds if (copy_to_user(buf , "hello" , len)) { return -EFAULT; } else { *ppos +=len; return len; }} static struct file_operations my_fops ={ .owner = THIS_MODULE, .read = my_read,}; static int hello_init (void){ my_dev = MKDEV(400,0); register_chrdev_region(my_dev,1,"demo"); my_cdev=cdev_alloc(); if(!my_cdev) { printk (KERN_INFO "cdev alloc error. "); return -1; } my_cdev->ops = &my_fops; my_cdev->owner = THIS_MODULE; if(cdev_add(my_cdev,my_dev,1)) { printk (KERN_INFO "cdev add error. "); return -1; } return 0; } static voidhello_cleanup (void){ cdev_del(my_cdev); unregister_chrdev_region(my_dev, 1);} module_init (hello_init);module_exit (hello_cleanup);MODULE_LICENSE("GPL");

讀里面delay了5秒, 注意mdelay是一個(gè)計(jì)算型的busy-loop。

用戶空間代碼如下:

#include#include#include#include #include #include void *hi_prio(void *p){ printf("thread1 start time=%ld ",time(NULL)); sleep(3); printf("thread1 stop time=%ld ",time(NULL)); return NULL;} void *low_prio(void *p){ char buf[20]; sleep(1); int fd=open("/dev/demo",O_RDWR); // #mknod /dev/demo c 400 0 puts("thread2 start"); read(fd,buf,20); puts("thread2 stop"); return NULL;} int main(){ pthread_t t1,t2,t3; pthread_attr_t attr; struct sched_param param; pthread_attr_init(&attr); pthread_attr_setschedpolicy(&attr, SCHED_RR); param.sched_priority = 50; pthread_attr_setschedparam(&attr, ¶m); pthread_create(&t1,&attr,hi_prio,NULL); param.sched_priority = 30; pthread_attr_setschedparam(&attr, ¶m); pthread_create(&t2,&attr,low_prio,NULL); sleep(10); puts("end test"); return 0;}

實(shí)驗(yàn)步驟:

高優(yōu)先級線程開始睡眠3秒

低優(yōu)先級線程睡眠1秒然后做系統(tǒng)調(diào)用

高優(yōu)先級線程6秒后醒來(stop和start的時(shí)間差)

# insmod demo.ko # ./appthread1 start time=182thread2 startthread1 stop time=188thread2 stopend test

Preemptible Kernel

這種情況內(nèi)核里面也可以搶占,意味著上述程序里面的高優(yōu)先級線程3秒后可醒來。

這種情況下,系統(tǒng)會有更多的上下文切換,但是實(shí)時(shí)性更加好。對于要求軟實(shí)時(shí)的嵌入式系統(tǒng)而言,這個(gè)選項(xiàng)是最佳的。但是對于服務(wù)器而言,通常第一個(gè)選項(xiàng)更好——更少的上下文切換,更多的CPU時(shí)間用作有用功。

運(yùn)行結(jié)果(stop、start時(shí)間差3秒):

# insmod ./demo.ko#./appthread1 start time=234thread2 startthread1 stop time=237thread2 stopend test

Voluntary Kernel Preemption

這種情況和第一種情況"no forced preemption"類似,但是內(nèi)核開發(fā)者可以在進(jìn)行復(fù)雜操作的時(shí)候,時(shí)不時(shí)檢查一下是否可以reschedule。他們可以調(diào)用might_resched()函數(shù)。

在下面的代碼中,我們添加了一些檢查點(diǎn)(check point)

// callback for read system call on the devicestatic ssize_t my_read(struct file *file, char __user *buf,size_t count,loff_t *ppos){ int len=5; if(*ppos > 0) { return 0; } mdelay(4000); // busy-wait for 4 seconds might_resched(); delay(3000); // busy wait for 3 seconds if (copy_to_user(buf , "hello" , len)) { return -EFAULT; } else { *ppos +=len; return len; }}

如果我們把might_resched()注釋掉,它會delay 7秒。

添加cond_resched()調(diào)用將導(dǎo)致系統(tǒng)檢查是否有高優(yōu)先級的任務(wù)被喚醒,這樣高優(yōu)先級任務(wù)5秒可以醒來(其中1秒在systemcall之前,另外4秒在kernel)。

運(yùn)行結(jié)果:

#insmod./demo.ko#./appthread1 start time=320thread2 startthread1 stop time=325thread2 stopend test

Full Real Time Preemption

如果我們使能RT補(bǔ)丁,我們會得到一個(gè)硬實(shí)時(shí)的kernel。這意味著任何代碼可以搶占任何人。比如一個(gè)更加緊急的任務(wù)可以搶占中斷服務(wù)程序ISR。這個(gè)patch進(jìn)行了如下改動(dòng):

把中斷服務(wù)程序轉(zhuǎn)化為優(yōu)先級是50的RT線程

把softIRQ轉(zhuǎn)化為優(yōu)先級是49的RT線程

把所有的spinlock變成mutex

高精度定時(shí)器

其他的細(xì)小改動(dòng)

打補(bǔ)丁后會看到2個(gè)新增的菜單:

其中“Preemptible Kernel (Basic RT)” 是為了調(diào)試目的的,為了全面使用RT補(bǔ)丁的功能,我們應(yīng)該選擇最后一項(xiàng) – Fully Preemptible Kernel。這樣我們會有更多的上下文切換,但是可以滿足RT的實(shí)時(shí)要求。

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • 內(nèi)核
    +關(guān)注

    關(guān)注

    3

    文章

    1416

    瀏覽量

    41354
  • Linux
    +關(guān)注

    關(guān)注

    87

    文章

    11508

    瀏覽量

    213549

原文標(biāo)題:理解Linux內(nèi)核搶占模型(最透徹一篇)

文章出處:【微信號:LinuxDev,微信公眾號:Linux閱碼場】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    無人機(jī)AI視覺行為識別系統(tǒng)

    無人機(jī)AI視覺行為識別系統(tǒng) 隨著無人機(jī)技術(shù)的快速發(fā)展和計(jì)算機(jī)視覺領(lǐng)域的突破性進(jìn)展,無人機(jī)AI視覺行為識別系統(tǒng)應(yīng)運(yùn)而生。傳統(tǒng)監(jiān)控系統(tǒng)受限于固定
    的頭像 發(fā)表于 07-04 16:53 ?158次閱讀

    工地AI行為識別系統(tǒng)作用

    工地AI行為識別系統(tǒng)作用 工地AI行為識別系統(tǒng)是什么? 工地AI行為識別系統(tǒng)是一種基于人工智能技
    的頭像 發(fā)表于 05-08 12:00 ?249次閱讀

    景區(qū)AI行為識別系統(tǒng)作用

    景區(qū)AI行為識別系統(tǒng)作用 景區(qū)AI行為識別系統(tǒng)是什么? 景區(qū)AI行為識別系統(tǒng)是利用人工智能技術(shù)(
    的頭像 發(fā)表于 05-07 15:32 ?282次閱讀
    景區(qū)AI<b class='flag-5'>行為</b>識別<b class='flag-5'>系統(tǒng)</b>作用

    工廠園區(qū)AI行為識別系統(tǒng)作用

    工廠園區(qū)AI行為識別系統(tǒng)作用 工廠園區(qū)AI行為識別系統(tǒng)是什么? 工廠園區(qū)AI行為識別系統(tǒng)是基于人
    的頭像 發(fā)表于 05-06 17:49 ?225次閱讀

    KaihongOS操作系統(tǒng)FA模型與Stage模型介紹

    FA模型與Stage模型介紹 KaihongOS操作系統(tǒng)中,F(xiàn)A模型(Feature Ability)和Stage模型是兩種不同的應(yīng)用
    發(fā)表于 04-24 07:27

    自媒體推廣實(shí)時(shí)監(jiān)控從服務(wù)器帶寬到用戶行為解決方法

    自媒體推廣的實(shí)時(shí)監(jiān)控需要從底層基礎(chǔ)設(shè)施到前端用戶行為進(jìn)行全鏈路覆蓋,確保推廣活動(dòng)的穩(wěn)定性和效果可追蹤。以下是系統(tǒng)性解決方案,主機(jī)推薦小編為您整理發(fā)布自媒體推廣實(shí)時(shí)監(jiān)控從服務(wù)器帶寬到用戶
    的頭像 發(fā)表于 04-09 10:47 ?246次閱讀

    基于液壓系統(tǒng)模型的電機(jī)控制

    、多個(gè)階段的響應(yīng)問題以及難以調(diào)整的問題上表現(xiàn)得并不理想。因此,我們發(fā)現(xiàn)在某些情況下,甚至比開環(huán)控制更差。而如果單純使用開環(huán)控制就要求液壓系統(tǒng)非常精確地控制模型,這在工程上是很難做到的。本研究基于直流無刷
    發(fā)表于 03-07 14:52

    NVIDIA大語言模型在推薦系統(tǒng)中的應(yīng)用實(shí)踐

    推薦系統(tǒng)的主要任務(wù)在于根據(jù)用戶的過往行為預(yù)測其潛在興趣點(diǎn),并據(jù)此推薦相應(yīng)的商品。在傳統(tǒng)的推薦系統(tǒng)中,當(dāng)處理用戶請求時(shí),會觸發(fā)多個(gè)召回模塊,例
    的頭像 發(fā)表于 03-05 09:30 ?781次閱讀
    NVIDIA大語言<b class='flag-5'>模型</b>在推薦<b class='flag-5'>系統(tǒng)</b>中的應(yīng)用實(shí)踐

    【「大模型啟示錄」閱讀體驗(yàn)】營銷領(lǐng)域大模型的應(yīng)用

    今天跟隨「大模型啟示錄」這本書,學(xué)習(xí)在營銷領(lǐng)域應(yīng)用大模型。 大模型通過分析大量的消費(fèi)者數(shù)據(jù),包括購買歷史、瀏覽記錄、社交媒體互動(dòng)等,能夠識別消費(fèi)者的偏好和行為模式。這種分析能力有助于企
    發(fā)表于 12-24 12:48

    【「大模型啟示錄」閱讀體驗(yàn)】如何在客服領(lǐng)域應(yīng)用大模型

    內(nèi)為企業(yè)帶來效益。在選擇模型時(shí),需要評估其性能表現(xiàn)。這包括模型的準(zhǔn)確性、響應(yīng)速度、對話流暢性、情感理解能力等方面??梢酝ㄟ^對比不同模型的測試結(jié)果、查看用戶反饋和評分等方式來評估
    發(fā)表于 12-17 16:53

    TDP0604 IBIS-AMI模型用戶指南

    電子發(fā)燒友網(wǎng)站提供《TDP0604 IBIS-AMI模型用戶指南.pdf》資料免費(fèi)下載
    發(fā)表于 11-21 15:55 ?0次下載
    TDP0604 IBIS-AMI<b class='flag-5'>模型</b><b class='flag-5'>用戶</b>指南

    以太網(wǎng)物理模型和仿真用戶指南

    電子發(fā)燒友網(wǎng)站提供《以太網(wǎng)物理模型和仿真用戶指南.pdf》資料免費(fèi)下載
    發(fā)表于 11-20 11:38 ?1次下載
    以太網(wǎng)物理<b class='flag-5'>模型</b>和仿真<b class='flag-5'>用戶</b>指南

    SPICE模型系列的半導(dǎo)體器件

    半導(dǎo)體器件模型是指描述半導(dǎo)體器件的電、熱、光、磁等器件行為的數(shù)學(xué)模型。其中,SPICE(Simulation Program with Integrated Circuit Emphasis)
    的頭像 發(fā)表于 10-31 18:11 ?1660次閱讀
    SPICE<b class='flag-5'>模型</b>系列的半導(dǎo)體器件

    淺析用戶行為的V2G模式下電動(dòng)汽車有序充電控制負(fù)荷預(yù)測研究

    摘要:針對電動(dòng)汽車充電負(fù)荷與運(yùn)營經(jīng)濟(jì)收益的矛盾問題,以用戶側(cè)為研究對象,用戶行為習(xí)慣為約束條件,建立粒子群控制策略模型。在保證電動(dòng)汽車正常使用的情況下,利用粒子群算法計(jì)算出的充放電功率
    的頭像 發(fā)表于 10-11 16:16 ?1099次閱讀
    淺析<b class='flag-5'>用戶</b><b class='flag-5'>行為</b>的V2G模式下電動(dòng)汽車有序充電控制負(fù)荷預(yù)測研究

    基于Simscape Battery模型的電池系統(tǒng)建模與仿真

    Simscape Battery? 以模塊庫和 API的方式幫助我們對電池以及儲能系統(tǒng)進(jìn)行建模。我們可以用它來實(shí)現(xiàn)電芯電熱耦合模型、配置和測試電池架構(gòu)、設(shè)計(jì)電池管理系統(tǒng),繼而評估電池系統(tǒng)
    的頭像 發(fā)表于 09-05 09:45 ?2753次閱讀
    基于Simscape Battery<b class='flag-5'>模型</b>的電池<b class='flag-5'>系統(tǒng)</b>建模與仿真