zoukankan      html  css  js  c++  java
  • linux 禁止所有中断

    如果你需要禁止所有中断如何? 在 2.6 内核, 可能关闭在当前处理器上所有中断处理, 使用任一个下面 2 个函数(定义在 <asm/system.h>):

    void local_irq_save(unsigned long flags); void local_irq_disable(void);

    一个对 local_irq_save 的调用在当前处理器上禁止中断递交, 在保存当前中断状态到 flags 之后. 注意, flags 是直接传递, 不是通过指针. local_irq_disable 关闭本地中 断递交而不保存状态; 你应当使用这个版本只在你知道中断没有在别处被禁止.

    完成打开中断, 使用:

    void local_irq_restore(unsigned long flags); void local_irq_enable(void);

    第一个版本恢复由 local_irq_save 存储于 flags 的状态, 而 local_irq_enable 无条 件打开中断. 不象 disable_irq, local_irq_disable 不跟踪多次调用. 如果调用链中有 多于一个函数可能需要禁止中断, 应该使用 local_irq_save.

    在 2.6 内核, 没有方法全局性地跨整个系统禁止所有的中断. 内核开发者决定, 关闭所 有中断的开销太高, 并且在任何情况下没有必要有这个能力. 如果你在使用一个旧版本驱 动, 它调用诸如 cli 和 sti, 你需要在它在 2.6 下工作前更新它为使用正确的加锁

    [37] 尽管, 一些大系统明确使用中断平衡机制来在系统间分散中断负载.

    [38] 这个 shortint 设备完成它的任务, 通过交替地写入 0x00 和 0xff 到并口.

  • 相关阅读:
    openswitch db files
    openstack中虚拟机和其网络的联系方法 instance and network
    python操作db2和mysql ,ibm_db
    yum安装mariadb
    python 连接 db2
    db2操作 连接、备份、恢复db2
    su su
    linux 后台运行进程 fg bg ctrl+z nohup
    mysql 命令行
    IDEA-使用技巧
  • 原文地址:https://www.cnblogs.com/fanweisheng/p/11142317.html
Copyright © 2011-2022 走看看