博客
关于我
宋宝华:在实时操作系统里面随便怎么写代码都能硬实时吗?
阅读量:96 次
发布时间:2019-02-25

本文共 935 字,大约阅读时间需要 3 分钟。

硬实时系统的概念并非追求速度最大化,而是强调在可重复、可预期的时间期限内提供响应。这意味着实时系统的正确性不仅依赖于计算逻辑的正确性,更取决于结果的生产时间。例如,汽车安全气囊在碰撞后必须在X时间内弹出,延迟将可能导致严重后果。

硬实时操作系统(如RT-Thread、FreeRTOS、VxWorks)与普通操作系统(如Linux)在性能上有显著差异。RT-Thread和FreeRTOS无需对Linux进行改造即可在微秒级延迟内完成任务,而Linux需要额外配置才能达到类似效果。

然而,Linux并不支持硬实时的核心原因在于以下几个方面:

  • Spinlock的广泛使用

    Spinlock在Linux内核和驱动层得到了广泛使用。尽管自旋锁能够避免多级锁竞争问题,但它会导致持有锁的CPU核禁止抢占调度,导致其他高优先级任务无法及时响应,造成确定性时延不可预期。

  • 中断处理机制的限制

    Linux内核默认禁用中断嵌套,所有中断执行时会禁止其他中断进入。这会导致高优先级中断被长时间阻塞,无法在预期时间内响应任务需求。

  • 软中断与上下文切换

    软中断虽然比用户模式上下文优先级高,但由于其执行时间不可预测,实时任务可能被迫等待软中断完成,导致确定性时延无法保证。

  • 锁机制的复杂性

    Linux内核中的锁机制(如spin_lock_irqsave)不仅屏蔽了抢占调度,还会禁止中断进入。由于这些锁是用户编写的,执行时间长短难以预测,严重影响实时性。

  • 用户空间内存管理

    Linux采用懒分配机制,部分内存可能位于磁盘上。实时任务可能因缺页中断而被频繁打断,导致确定性延迟无法满足。

  • 尽管如此,Preempt-RT补丁为Linux提供了一种实时任务调度的解决方案。该补丁允许用户空间线程在高优先级调度下运行,适合需要快速响应的实时应用场景。Preempt-RT的支持依赖于特定的处理器架构(ARCH_SUPPORTS_RT),这也是当前主流Linux内核的一个重要配置选项。

    总结来说,Linux虽然在用户空间实现了进程和线程的调度,但其中断机制和内核锁设计使其不适合硬实时应用。Preempt-RT等解决方案为Linux系统提供了实时任务的可行性,但仍需与内核设计理念和应用场景相结合。

    转载地址:http://eft.baihongyu.com/

    你可能感兴趣的文章
    openssh 加固
    查看>>
    OPENSSH升级为7.4
    查看>>
    ViewPager切换滑动速度修改
    查看>>
    OpenSSL 引入了新的治理模式和项目,来增强社区参与和决策
    查看>>
    openssl内存分配,查看内存泄露
    查看>>
    OpenSSL创建SSL证书
    查看>>
    openssl在cygwin下编译错误:CPU不支持x86_64(CPU you selected does not support x86-64 instruction set )
    查看>>
    openssl安装
    查看>>
    openssl安装
    查看>>
    OpenSSL生成root CA及签发证书
    查看>>
    openStack instance error 恢复
    查看>>
    openstack instance resize to
    查看>>
    Openstack REST API
    查看>>
    OpenStack ussuri 私有云平台搭建企业级实战
    查看>>
    OpenStack 上部署 Kubernetes 方案对比
    查看>>
    Openstack 之 网络设置静态IP地址
    查看>>
    OpenStack 存储服务详解
    查看>>
    openstack 导出镜像
    查看>>
    OpenStack 搭建私有云主机实战(附OpenStack实验环境)
    查看>>
    OpenStack 综合服务详解
    查看>>