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

    文章

    1376

    浏览量

    40319
  • Linux
    +关注

    关注

    87

    文章

    11320

    浏览量

    209842

原文标题:理解Linux内核抢占模型(最透彻一篇)

文章出处:【微信号:LinuxDev,微信公众号:Linux阅码场】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    【「大模型启示录」阅读体验】营销领域大模型的应用

    今天跟随「大模型启示录」这本书,学习在营销领域应用大模型。 大模型通过分析大量的消费者数据,包括购买历史、浏览记录、社交媒体互动等,能够识别消费者的偏好和行为模式。这种分析能力有助于企
    发表于 12-24 12:48

    【「大模型启示录」阅读体验】如何在客服领域应用大模型

    内为企业带来效益。在选择模型时,需要评估其性能表现。这包括模型的准确性、响应速度、对话流畅性、情感理解能力等方面。可以通过对比不同模型的测试结果、查看用户反馈和评分等方式来评估
    发表于 12-17 16:53

    SPICE模型系列的半导体器件

    半导体器件模型是指描述半导体器件的电、热、光、磁等器件行为的数学模型。其中,SPICE(Simulation Program with Integrated Circuit Emphasis)
    的头像 发表于 10-31 18:11 673次阅读
    SPICE<b class='flag-5'>模型</b>系列的半导体器件

    浅析用户行为的V2G模式下电动汽车有序充电控制负荷预测研究

    摘要:针对电动汽车充电负荷与运营经济收益的矛盾问题,以用户侧为研究对象,用户行为习惯为约束条件,建立粒子群控制策略模型。在保证电动汽车正常使用的情况下,利用粒子群算法计算出的充放电功率
    的头像 发表于 10-11 16:16 533次阅读
    浅析<b class='flag-5'>用户</b><b class='flag-5'>行为</b>的V2G模式下电动汽车有序充电控制负荷预测研究

    基于Simscape Battery模型的电池系统建模与仿真

    Simscape Battery™ 以模块库和 API的方式帮助我们对电池以及储能系统进行建模。我们可以用它来实现电芯电热耦合模型、配置和测试电池架构、设计电池管理系统,继而评估电池系统
    的头像 发表于 09-05 09:45 1004次阅读
    基于Simscape Battery<b class='flag-5'>模型</b>的电池<b class='flag-5'>系统</b>建模与仿真

    AI行为识别视频监控系统 Python

    AI行为识别视频监控系统来自机器视觉技术的革新。机器视觉技术应用是人工智能技术分析的一个支系。它可以在图形和图象具体内容叙述中间创建投射关联,使电脑可以根据图像处理和剖析比较,进而熟悉视频图象中
    的头像 发表于 07-06 10:36 557次阅读
    AI<b class='flag-5'>行为</b>识别视频监控<b class='flag-5'>系统</b> Python

    鸿蒙Ability Kit(程序框架服务)【组件启动规则(Stage模型)】

    总体规则 为了保证用户具有更好的使用体验,对以下几种易影响用户体验与系统安全的行为做了限制: 后台应用任意弹框,如各种广
    的头像 发表于 06-10 18:47 950次阅读
    鸿蒙Ability Kit(程序框架服务)【组件启动规则(Stage<b class='flag-5'>模型</b>)】

    视频AI行为监测系统在高速公路中应用

    在高速公路的监控中,视频AI行为监测系统扮演着至关重要的角色。它利用先进的AI技术,对高速公路上的监控视频进行实时分析,为交通管理部门提供准确、及时的信息,从而提升道路的通行效率,保障交通安全
    的头像 发表于 06-05 18:06 847次阅读

    系统中的latency是如何产生的

    在当今数字时代,手机已成为人们日常生活中不可或缺,多任务处理和实时响应对于用户体验越来越重要,抢占(preemption)机制在提升系统性能和用户体验方面发挥了至关重要的作用。内核
    的头像 发表于 06-04 09:18 664次阅读
    <b class='flag-5'>系统</b>中的latency是如何产生的

    Anthropic修改服务政策:允未成年人使用AI模型,禁AI用于非法行为

    据报道,Anthropic于上周对其服务政策进行了调整,决定自6月6日起允许未成年人使用旗下AI模型的服务,并进一步明确了不得将此AI用于侵犯用户隐私等不当行为
    的头像 发表于 05-13 14:23 569次阅读

    【大语言模型:原理与工程实践】大语言模型的应用

    ,它通过抽象思考和逻辑推理,协助我们应对复杂的决策。 相应地,我们设计了两类任务来检验大语言模型的能力。一类是感性的、无需理性能力的任务,类似于人类的系统1,如情感分析和抽取式问答等。大语言模型在这
    发表于 05-07 17:21

    模型在战略评估系统中的应用有哪些

    体现在以下几个方面: 数据整合与分析:大模型具有处理大规模数据的能力,可以整合来自不同来源、不同格式的战略数据,如市场趋势、竞争情报、用户行为等。 战略预测与模拟:大模型通过学习和理解
    的头像 发表于 04-24 13:48 295次阅读

    RTTnano的用户main函数中的优先级是多少?

    RTTnano 的用户main函数中的优先级是多少?为什么会出现创建新的task之后,main函数会抢占掉低优先级的task,例如RT_THREAD_PRIORITY_MAX设置为8 ,低于3
    发表于 02-26 08:01

    SPICE中的热模型介绍

    SPICE模型中的热模型是指用于模拟和预测电子元件在工作时的热行为特性的模型。这些模型通常与电路仿真软件一起使用,以便在设计阶段评估和优化电
    的头像 发表于 02-06 11:28 1157次阅读
    SPICE中的热<b class='flag-5'>模型</b>介绍

    跨电感电压调节器(TLVR)的瞬态行为

    电压调节器(TLVR)。TLVR的原理图来自耦合电感模型,但物理行为不同。事实上,耦合电感的简单模型通常是可以轻松用于仿真以实现正确波形的东西,但它与实际物理行为并不对应。另一方面,T
    的头像 发表于 01-24 09:13 3083次阅读
    跨电感电压调节器(TLVR)的瞬态<b class='flag-5'>行为</b>