当前位置: 首页 > news >正文

linux 4.14 kernel屏蔽arm arch timer的方法

在 ARMv7 架构的单核 CPU 系统中,完全禁用 coretime 时钟中断(通常是 ARM 私有定时器中断)需要谨慎操作,因为这会导致调度器无法工作,系统可能失去响应。以下是实现方法及注意事项:


方法 1:通过 GIC 屏蔽中断(推荐)

ARM 的时钟中断(通常是 PPI 中断号 30)通过 GIC(Generic Interrupt Controller)管理:


#include <linux/irq.h>// 获取时钟中断号(通常是30)
#define TIMER_IRQ 30// 屏蔽中断
void disable_timer_irq(void)
{struct irq_desc *desc = irq_to_desc(TIMER_IRQ);if (desc) {raw_spin_lock_irq(&desc->lock);irq_settings_set_disabled(desc);  // 标记为禁用desc->irq_data.chip->irq_mask(&desc->irq_data); // 硬件屏蔽raw_spin_unlock_irq(&desc->lock);}
}// 恢复中断
void enable_timer_irq(void)
{struct irq_desc *desc = irq_to_desc(TIMER_IRQ);if (desc) {raw_spin_lock_irq(&desc->lock);desc->irq_data.chip->irq_unmask(&desc->irq_data);irq_settings_clr_disabled(desc);raw_spin_unlock_irq(&desc->lock);}
}

方法 2:直接操作定时器寄存器

通过 ARM CP15 协处理器控制私有定时器:


// 禁用定时器中断
static void disable_arm_private_timer(void)
{u32 ctrl;// 读控制寄存器 (CP15 c14)asm volatile("mrc p15, 0, %0, c14, c3, 1" : "=r" (ctrl));ctrl &= ~(1 << 2);  // 清除中断使能位asm volatile("mcr p15, 0, %0, c14, c3, 1" : : "r" (ctrl));
}// 恢复定时器中断
static void enable_arm_private_timer(void)
{u32 ctrl;asm volatile("mrc p15, 0, %0, c14, c3, 1" : "=r" (ctrl));ctrl |= (1 << 2);  // 设置中断使能位asm volatile("mcr p15, 0, %0, c14, c3, 1" : : "r" (ctrl));
}

关键注意事项

  1. 系统稳定性风险

    • 禁用时钟中断后,调度器 (scheduler_tick()) 停止工作

    • 无抢占发生,当前任务将独占 CPU

    • 时间相关功能(jiffiesgettimeofday)停止更新

  2. 必要操作前准备

    
    local_irq_save(flags);    // 保存中断状态并禁用所有中断
    preempt_disable();        // 禁用内核抢占
    disable_timer_irq();      // 禁用时钟中断

  3. 恢复操作

    
    enable_timer_irq();       // 先恢复时钟中断
    preempt_enable();         // 启用抢占
    local_irq_restore(flags); // 恢复中断状态

  4. 最大禁用时间

    • 典型时钟中断周期 1-10ms

    • 禁用时间不应超过 100ms,否则可能触发看门狗或导致系统不稳定

  5. 替代方案建议

    
    // 临时禁用抢占(更安全)
    preempt_disable();
    // 执行关键操作
    preempt_enable();


典型使用场景

  1. 极短时延关键操作

    
    unsigned long flags;
    local_irq_save(flags);
    disable_timer_irq();// 执行时间敏感操作(< 100us)
    asm volatile("nop; nop; ...");enable_timer_irq();
    local_irq_restore(flags);

  2. 低功耗状态进入前

    
    disable_timer_irq();
    wfi();  // 进入WFI状态
    enable_timer_irq(); // 被其他中断唤醒后执行


调试与验证

  1. 检查中断状态:

    
    cat /proc/interrupts | grep arch_timer
    • 禁用后计数器应停止增长

  2. 监控系统状态:

    
    perf stat -e irq_vectors:local_timer_entry

  3. 内核日志确认:

    dmesg

    
    [  123.456] Disabled arch_timer interrupt


重要警告

  1. 避免在用户空间进程中使用 - 仅限内核模块或核心代码

  2. 禁用期间不可调用任何调度相关函数(如 schedule()msleep()

  3. 禁止在中断上下文中使用此操作

  4. 多核系统中需配合 get_cpu()/put_cpu() 处理 CPU 亲和性

如非必要,建议使用 preempt_disable() 或 local_irq_disable() 替代完全禁用时钟中断,以保持系统基本功能运作。

http://www.lryc.cn/news/584111.html

相关文章:

  • 防抖在vue中应用
  • Vue前端面试常问问题详解
  • Python-GEE遥感云大数据分析与可视化(如何建立基于云计算的森林监测预警系统)
  • 多元函数的切平面与线性近似:几何直观与计算方法
  • 在指定conda 环境里安装 jupyter 和 python kernel的方法
  • django中如何使用Django REST Framework
  • 网络安全基础概念以及虚拟环境的搭建
  • 快速将照片从三星手机传输到电脑
  • 保姆级搭建harbor私有仓库与docker-ce教程与使用教程
  • JAVA面试宝典 -《Spring IOC核心:Bean生命周期全解析》
  • [论文阅读]LLMZip: Lossless Text Compression using Large Language Models
  • 【论文阅读】Defensive Few-shot Learning
  • RocksDB 与 ZenFS:原理、特性及在科研与工程中的应用初步探索
  • 微调性能赶不上提示工程怎么办?Can Gradient Descent Simulate Prompting?——论文阅读笔记
  • [论文阅读]Text Compression for Efficient Language Generation
  • FreeRTOS移植
  • 零成本获取 SSL 证书攻略?
  • 【论文笔记】A Deep Reinforcement Learning Based Real-Time Solution Policy for the TSP
  • 如何处理mocking is already registered in the current thread
  • VILA-M3: Enhancing Vision-Language Models with Medical Expert Knowledge
  • 探索Alibaba-NLP/WebAgent:迈向智能信息搜索新时代
  • C++每日刷题day2025.7.10
  • Python正则表达式实战指南
  • 文件系统----底层架构
  • 【三维生成】FlashDreamer:基于扩散模型的单目图像到3D场景
  • [特殊字符] LLM(大型语言模型):智能时代的语言引擎与通用推理基座
  • pigz 快速压缩与解压缩
  • Windows 与 Linux 内核安全及 Metasploit/LinEnum 在渗透测试中的综合应用
  • 710 Mybatis实战
  • 【JavaScript 中 null 的本质与原型链终点探析】