在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

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

Linux閱碼場 ? 來源:Linuxer ? 2020-06-03 16:03 ? 次閱讀

當配置Linux內核的時候,我們可以選擇一些參數,這些參數能影響系統的行為。你可以用不同的優先級、調度類和搶占模型來工作。正確地選擇這些參數是非常重要的。

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

當你使用 make menuconfig配置內核的時候,你能看到這樣的菜單:

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

2個線程,一個高優先級RT(50),一個低優先級RT(30)

高優先級的線程要睡眠3秒

低優先級的線程用CPU來做計算

3秒后高優先級線程喚醒。

如果低優先級的線程陷入系統調用,高優先級的線程睡眠到期,究竟會發生什么?下面我們來一種模型一種模型地看。

No Forced Preemption

這種情況下,上下文切換發生在系統調用返回用戶空間的點。案例如下:

2個線程,一個高優先級RT(50),一個低優先級RT(30)

高優先級的線程要睡眠3秒

低優先級的線程進入系統調用計算5秒

5秒后低優先級線程從內核系統調用返回

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

內核代碼,簡單的字符設備:

#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是一個計算型的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;}

實驗步驟:

高優先級線程開始睡眠3秒

低優先級線程睡眠1秒然后做系統調用

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

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

Preemptible Kernel

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

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

運行結果(stop、start時間差3秒):

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

Voluntary Kernel Preemption

這種情況和第一種情況"no forced preemption"類似,但是內核開發者可以在進行復雜操作的時候,時不時檢查一下是否可以reschedule。他們可以調用might_resched()函數。

在下面的代碼中,我們添加了一些檢查點(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()調用將導致系統檢查是否有高優先級的任務被喚醒,這樣高優先級任務5秒可以醒來(其中1秒在systemcall之前,另外4秒在kernel)。

運行結果:

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

Full Real Time Preemption

如果我們使能RT補丁,我們會得到一個硬實時的kernel。這意味著任何代碼可以搶占任何人。比如一個更加緊急的任務可以搶占中斷服務程序ISR。這個patch進行了如下改動:

把中斷服務程序轉化為優先級是50的RT線程

把softIRQ轉化為優先級是49的RT線程

把所有的spinlock變成mutex

高精度定時器

其他的細小改動

打補丁后會看到2個新增的菜單:

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

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 內核
    +關注

    關注

    3

    文章

    1410

    瀏覽量

    41115
  • Linux
    +關注

    關注

    87

    文章

    11465

    瀏覽量

    212815

原文標題:理解Linux內核搶占模型(最透徹一篇)

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

收藏 人收藏

    評論

    相關推薦
    熱點推薦

    工地AI行為識別系統作用

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

    景區AI行為識別系統作用

    景區AI行為識別系統作用 景區AI行為識別系統是什么? 景區AI行為識別系統是利用人工智能技術(
    的頭像 發表于 05-07 15:32 ?180次閱讀
    景區AI<b class='flag-5'>行為</b>識別<b class='flag-5'>系統</b>作用

    工廠園區AI行為識別系統作用

    工廠園區AI行為識別系統作用 工廠園區AI行為識別系統是什么? 工廠園區AI行為識別系統是基于人
    的頭像 發表于 05-06 17:49 ?163次閱讀

    KaihongOS操作系統FA模型與Stage模型介紹

    FA模型與Stage模型介紹 KaihongOS操作系統中,FA模型(Feature Ability)和Stage模型是兩種不同的應用
    發表于 04-24 07:27

    自媒體推廣實時監控從服務器帶寬到用戶行為解決方法

    自媒體推廣的實時監控需要從底層基礎設施到前端用戶行為進行全鏈路覆蓋,確保推廣活動的穩定性和效果可追蹤。以下是系統性解決方案,主機推薦小編為您整理發布自媒體推廣實時監控從服務器帶寬到用戶
    的頭像 發表于 04-09 10:47 ?201次閱讀

    基于液壓系統模型的電機控制

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

    NVIDIA大語言模型在推薦系統中的應用實踐

    推薦系統的主要任務在于根據用戶的過往行為預測其潛在興趣點,并據此推薦相應的商品。在傳統的推薦系統中,當處理用戶請求時,會觸發多個召回模塊,例
    的頭像 發表于 03-05 09:30 ?674次閱讀
    NVIDIA大語言<b class='flag-5'>模型</b>在推薦<b class='flag-5'>系統</b>中的應用實踐

    【「大模型啟示錄」閱讀體驗】營銷領域大模型的應用

    今天跟隨「大模型啟示錄」這本書,學習在營銷領域應用大模型。 大模型通過分析大量的消費者數據,包括購買歷史、瀏覽記錄、社交媒體互動等,能夠識別消費者的偏好和行為模式。這種分析能力有助于企
    發表于 12-24 12:48

    【「大模型啟示錄」閱讀體驗】如何在客服領域應用大模型

    內為企業帶來效益。在選擇模型時,需要評估其性能表現。這包括模型的準確性、響應速度、對話流暢性、情感理解能力等方面。可以通過對比不同模型的測試結果、查看用戶反饋和評分等方式來評估
    發表于 12-17 16:53

    以太網物理模型和仿真用戶指南

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

    SPICE模型系列的半導體器件

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

    淺析用戶行為的V2G模式下電動汽車有序充電控制負荷預測研究

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

    基于Simscape Battery模型的電池系統建模與仿真

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

    AI行為識別視頻監控系統 Python

    AI行為識別視頻監控系統來自機器視覺技術的革新。機器視覺技術應用是人工智能技術分析的一個支系。它可以在圖形和圖象具體內容敘述中間創建投射關聯,使電腦可以根據圖像處理和剖析比較,進而熟悉視頻圖象中
    的頭像 發表于 07-06 10:36 ?882次閱讀
    AI<b class='flag-5'>行為</b>識別視頻監控<b class='flag-5'>系統</b> Python

    鴻蒙Ability Kit(程序框架服務)【組件啟動規則(Stage模型)】

    總體規則 為了保證用戶具有更好的使用體驗,對以下幾種易影響用戶體驗與系統安全的行為做了限制: 后臺應用任意彈框,如各種廣
    的頭像 發表于 06-10 18:47 ?1199次閱讀
    鴻蒙Ability Kit(程序框架服務)【組件啟動規則(Stage<b class='flag-5'>模型</b>)】
    主站蜘蛛池模板: 免费观看黄网站 | 免费看欧美理论片在线 | 韩国理论片在线看2828dy | 国产最好的精华液网站 | 男人一级片| 浓厚な接吻と肉体の交在线观看 | 天天色天天 | 天堂一区二区在线观看 | 1000部啪啪 | 久久久久久久国产免费看 | 在线观看三级网站 | 欧美午夜精品 | 色香蕉在线观看 | 免费观看四虎精品成人 | h视频在线观看视频观看 | 中文字幕一二三区乱码老 | 麦克斯奥特曼在线观看 | 女性一级全黄生活片 | 国产亚洲欧洲人人网 | 欧美巨大xxxx做受中文字幕 | 亚洲成人精品 | 天天干夜夜拍 | 国产性videostv另类极品 | 男人操女人免费网站 | 亚洲αv久久久噜噜噜噜噜 亚洲аv电影天堂网 | 亚洲网站在线看 | 色妞色综合久久夜夜 | 成年人污视频 | 77788色淫网站免费观看 | 加勒比一木道|视频在线看 加勒比在线免费视频 | 亚洲乱码中文字幕综合 | 午夜在线视频免费 | 亚洲一区日韩一区欧美一区a | 四虎院影永久在线观看 | 中文字幕在线一区 | 一区二区三区福利 | 午夜视频在线观看免费观看在线观看 | 成年网站在线 | 九九热精品视频 | 天天尻| 99久久99|