首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Linux内核中断 中断的原理和实现

(3)中断嵌套 Linux下硬中断是可以嵌套的,但是没有优先级的概念,也就是说任何一个新的中断都可以打断正在执行的中断,但同种中断除外。中断不能嵌套,但相同类型的中断可以在不同CPU上并行执行。...__softirq_pending) 唤醒ksoftirqd内核线程处理中断。...在ksoftirqd内核线程中 c. 在那些显示检查和执行待处理的中断的代码中,如网络子系统中 而不管是用什么方法唤起,中断都要在do_softirq()中执行。...内核不会立即处理重新触发的中断。...当大量中断出现的时候,内核会唤醒一组内核线程来处理。这些线程的优先级最低(nice值为19),这能避免它们跟其它重要的任务抢夺资源。

21.3K21

Linux内核22-中断和tasklet

这对于时间苛刻的应用来说,这是一个很重要的属性,尤其是那些要求中断请求必须在毫秒级别响应的应用。 Linux2.6内核使用两种手段满足这项挑战:中断和tasklet,还有工作队列。...2 中断 Linux2.6内核中,中断的数量比较少。对于多数目的,这些tasklet足够了。因为不需要考虑重入,所以简单易用。...这在Linux内核中是禁止的,因为其可延时函数的执行都是串行的。所以,在此需要禁止中断。 清除正在执行的中断对应掩码位。 执行local_irq_enable()使能中断。...更重要的是,外部事件,比如网卡上的数据包泛滥也可以频繁地激活中断。 连续大量的中断会造成潜在的问题,引入内核线程也是为了解决这个问题。如果没有这个内核线程,开发者只能使用两种替代策略。...迭代一些次数后,如果还有中断挂起,函数就会唤醒内核线程,自身终止,交给内核线程去处理后续的中断内核线程的优先级比较低,用户程序的执行不会受到影响。

1.3K30
您找到你想要的搜索结果了吗?
是的
没有找到

Linux 中断机制分析

中断分析最近工作繁忙,没有时间总结内核相关的一些东西。上次更新博客到了linux内核中断子系统。这次总结一下中断,也就是softirq。之后还会总结一些tasklet、工作队列机制。...这样的后果会造成有可能丢失外部中断。于是,linux内核设计出了一种架构,中断函数需要处理的任务分为两部分,一部分在中断处理函数中执行,这时系统关闭中断。...Linux内核中断方面就必须考虑平衡这三个方面的问题。而下面我要分析的__do_softirq函数就恰似在这三者之间打太极,游刃有余,面面俱到!...处理中断内核线程 之前我说到不能让CPU长时间来处理中断事务,这样会影响系统的响应时间,严重影响用户和系统之间的交互式体验。...系统将唤醒一个软件中断处理的内核进程,在内核进程中处理pending中的软件中断。这里要注意,之前我们分析的触发软件中断的位置其实是中断上下文中,而在中断内核线程中实际已经是进程的上下文。

8.6K91

linux内核缺页中断处理

缺页中断处理一般流程: 1.硬件陷入内核,在堆栈中保存程序计数器,大多数当前指令的各种状态信息保存在特殊的cpu寄存器中。 2.启动一个汇编例程保存通用寄存器和其他易丢失信息,以免被操作系统破坏。...9.调度引发缺页中断的进程,操作系统返回调用他的汇编例程 10.该例程恢复寄存器和其他状态信息,返回到用户空间继续执行,就好像缺页中断没有发生过。...linux内核对缺页异常的处理流程很复杂,但是基本思想和上述流程差不多。...下面看linux的基本处理流程: 内核处理缺页异常的主函数就是do_page_fault: /* * 缺页异常处理函数 * pt_regs 各个寄存器的值 * error_code,由硬件产生:...,内核调用copy_from_user时发生缺页异常,内核会将regs->ip也就是中断返回地址设置 //为这个地址,退出中断后不会在执行1: mov"itype" %2,%"rtype"1\n",

10.6K21

Linux内核中的中断、tasklet和工作队列具体解释

[TOC] 本文基于Linux2.6.32内核版本号。...引言 中断、tasklet和工作队列并非Linux内核中一直存在的机制,而是由更早版本号的内核中的“下半部”(bottom half)演变而来。 下半部的机制实际上包含五种,但2.6版本号的内核中。...中断内核线程 之前我们分析的触发软件中断的位置事实上是中断上下文中,而在中断内核线程中实际已经是进程的上下文。...由于其能够利用timer延时(内核定时器实现)。 – 假设推后运行的任务须要在一个tick之内处理。则使用中断或tasklet。由于其能够抢占普通进程和内核线程。同一时候不可睡眠。...工作队列的本质就是将工作交给内核线程处理,因此其能够用内核线程替换。 可是内核线程的创建和销毁对编程者的要求较高,而工作队列实现了内核线程的封装,不易出错,所以我们也推荐使用工作队列。

1.7K30

Linux 内核如何处理中断

此外,键盘并不是导致中断的唯一组件。一般来说,有三种类型的事件会导致 CPU 发生中断:硬件中断、软件中断和异常。在具体介绍不同类型的中断前,我需要先定义一些术语。...接下来会调用在内核启动时设备驱动注册的对应的中断服务程序(ISR)。 软件中断 当你在播放一个视频时,音频和视频是同步播放是相当重要的,这样音乐的速度才不会变化。...当系统需要实时性时(例如在工业应用中),软件中断会变得重要。你可以在 Linux 基金会的文章中找到更多相关信息:面向嵌入式开发者的实时 Linux 介绍。...中断描述表(interrupt descriptor table)(IDT)中记录了中断请求(IRQ)和中断服务程序(ISR)的对应关系。Linux 中定义了从 0 到 256 的 IRQ 向量。...其中一些在 Linux 内核源树中的Linux IRQ 向量布局中指定。 如果要实时获取该表,请运行如下命令: watch -n1 "cat /proc/interrupts"

2.3K40

Linux内核21-Linux内核中断处理过程

对于这类操作一般使用中断和tasklet机制完成。 I/O中断处理的基本步骤是: 保存IRQ值和内核态堆栈中寄存器值->恢复进程的时候使用。...但是不幸的是,有时候硬件在分配中断时会发生错误(比如,基于奔腾4的SMP主板就有这样的问题)。因此,Linux2.6内核使用一个特定的内核线程叫kirqd进行纠正IRQ的自动分配(如果有必要的话)。...内核线程使用多APIC系统一个很棒的功能,叫做CPU的IRQ亲和力:通过修改I/O-APIC的中断重定向表,将中断信号指定到新的CPU上。...kirqd内核线程周期性地执行do_irq_balance()函数,追踪最近一段时间内,每个CPU上接收到的中断次数。...IRQ堆栈 处理可延时函数时使用。比如,中断或tasklet。每个CPU都有一个IRQ堆栈。 、硬IRQ堆栈分别使用hardirq_stack和softirq_stack两个数组存储。

2.2K20

中断中断_中断和硬中断的优先级

linux为了实现这个特点,当中断发生的时候,硬中断处理那些短时间 就可以完成的工作,而将那些处理事件比较长的工作,放到中断之后来完成,也就是中断(softirq)来完成。...__softirq_pending) 唤醒ksoftirqd内核线程处理中断。...在ksoftirqd内核线程中 3. 在那些显示检查和执行待处理的中断的代码中,如网络子系统中 而不管是用什么方法唤起,中断都要在do_softirq()中执行。...内核不会立即处理重新触发的中断。...当大量中断出现的时候,内核会唤醒一组内核线程来处理。 这些线程的优先级最低(nice值为19),这能避免它们跟其它重要的任务抢夺资源。

2.5K40

Linux内核36-内核同步之禁止中断

如果太长,会影响整个系统任务的调度,也有可能导致中断信号的丢失。 同样,Linux也不会放弃禁止中断这么好的同步机制。它保证内核控制路径可以继续执行,其访问的数据结构不会被中断处理程序破坏。...当内核代码进入临界代码段时,通过清除eflags寄存器中的IF标志实现禁止中断,从而保护临界代码段。但是,当内核离开临界代码段的时候,内核是否该恢复之前的IF标志呢?还是不做任何处理?...回忆do_softirq()函数,如果中断计数器(存储在当前线程thread_info描述符的preempt_count成员中)是正数,它就不会处理中断。...为了确保及时执行长时间等待的线程,local_bh_enable()对中断计数器执行减1操作之后,还有执行两个重要的操作: 检查preempt_count中的硬中断计数器和中断计数器。...3 总结 总之一句话,禁止中断包含禁止硬中断中断两种。禁止硬中断肯定就包含禁止中断;但禁止中断不会影响硬中断的响应。它们都有各自的使用场景。

1.3K20

Linux 中的各种栈:进程栈 线程内核中断

内核将栈分成四种: 进程栈 线程内核中断栈 一、进程栈 进程栈是属于用户态栈,和进程 虚拟地址空间 (Virtual Address Space) 密切相关。...二、线程栈 从 Linux 内核的角度来说,其实它并没有线程的概念。Linux 把所有线程都当做进程来实现,它将线程和进程不加区分的统一到了 task_struct 中。...线程仅仅被视为一个与其他进程共享某些资源的进程,而是否共享地址空间几乎是进程和 Linux 中所谓线程的唯一区别。...中断也是如此,当系统收到中断事件后,进行中断处理的时候,也需要中断栈来支持函数调用。由于系统中断的时候,系统当然是处于内核态的,所以中断栈是可以和内核栈共享的。...而 ARM 上中断栈和内核栈则是共享的;中断栈和内核栈共享有一个负面因素,如果中断发生嵌套,可能会造成栈溢出,从而可能会破坏到内核栈的一些重要数据,所以栈空间有时候难免会捉襟见肘。

2.8K50

Linux 中的各种栈:进程栈 线程内核中断

内核将栈分成四种: 进程栈 线程内核中断栈 一、进程栈 进程栈是属于用户态栈,和进程 虚拟地址空间 (Virtual Address Space) 密切相关。...二、线程栈 从 Linux 内核的角度来说,其实它并没有线程的概念。Linux 把所有线程都当做进程来实现,它将线程和进程不加区分的统一到了 task_struct 中。...线程仅仅被视为一个与其他进程共享某些资源的进程,而是否共享地址空间几乎是进程和 Linux 中所谓线程的唯一区别。...中断也是如此,当系统收到中断事件后,进行中断处理的时候,也需要中断栈来支持函数调用。由于系统中断的时候,系统当然是处于内核态的,所以中断栈是可以和内核栈共享的。...而 ARM 上中断栈和内核栈则是共享的;中断栈和内核栈共享有一个负面因素,如果中断发生嵌套,可能会造成栈溢出,从而可能会破坏到内核栈的一些重要数据,所以栈空间有时候难免会捉襟见肘。

3.3K20

【深入理解Linux内核锁】| 中断屏蔽

Linux内核锁】二、中断屏蔽 1、中断屏蔽思想 中断屏蔽,正如其名,屏蔽掉CPU的中断响应功能,解决并发引起的竞态问题。 在进入临界区前屏蔽中断,这么做有什么好处,以及有什么弊端?...弊端在于: Linux内核中,除了系统进程调度依赖中断,还有一些异步I/O等众多操作都依赖中断,因此长时间屏蔽中断是很危险的,会对系统造成严重影响,因此也要求临界区代码要简短。...关闭中断能够解决进程调度、中断引发的竞态,但是这些都是单CPU内部的,对于SMP对称多处理器,仍然不可避免的会收到其他CPU的中断。...因此,并不能解决SMP多CPU引发的竞态 因此,单独使用中断屏蔽通常不是一种值得推荐的避免竞态的方法 2、Linux内核中断屏蔽的实现 2.1 Linux内核提供的API接口 关于中断屏蔽,Linux内核所提供的接口如下...3、总结 该篇文章,主要了解以下几点: 中断屏蔽的思想 中断屏蔽的好处与不足 Linux内核提供的中断屏蔽接口 中断屏蔽的基本汇编实现

40820

linux内核线程「建议收藏」

)完成,内核线程是独立运行在内核空间的标准进程。...内核线程和普通的进程间的区别在于内核线程没有独立的地址空间,mm指针被设置为NULL;它只在内核空间运行,从来不切换到用户空间去;并且和普通进程一样,可以被调度,也可以被抢占。...实际上,内核线程只能由其他内核线程创建,linux驱动模块中可以用kernel_thread(),kthread_create()/kthread_run()两种方式创建内核线程,另外还可以用第三方库(...>书中说,内核线程内核态的标准进程。...但如果线程函数正在处理一个非常重要的任务,它不会被中断的。当然如果线程函数永远不返回并且不检查信号,它将永远都不会停止,因此,线程函数必须能让出CPU,以便能运行其他线程

1.1K30

线程中断

线程中断 线程中断线程运行过程中被其他线程给打断了,它与 stop 最大的区别是:stop 是由系统强制终止线程,而线程中断则是给目标线程发送一个中断信号 如果目标线程没有接收线程中断的信号并结束线程...* 线程中断失败, 因为目标线程收到中断信号并没有做出处理 */ public class T01_ThreadInterrupt_Failed { static int i = 10;...package com.starry.codeview.threads.P05_ThreadInterrupt; /** * 线程中断成功, 目标线程收到中断信号做出了处理 */ public...package com.starry.codeview.threads.P05_ThreadInterrupt; /** * 线程中断失败,Sleep遇到线程中断catch到异常会清除掉中断标记,...package com.starry.codeview.threads.P05_ThreadInterrupt; /** * 线程中断失败,Sleep遇到线程中断catch到异常会清除掉中断标记,

1.4K20

linux | 网络数据包softirq 中断与CPU

Linux 在每个 CPU 上会创建一个 ksoftirqd 内核线程。 softirqs 是在 Linux 内核编译时就确定好的,例如网络收包对应的 NET_RX_SOFTIRQ 中断。...如果想加一种新 softirq 类型,就需要修改并重新编译内核。...-5.15.4/net/core/dev.c 注册网卡收发包(RX/TX)中断处理函数 open_softirq(NET_TX_SOFTIRQ, net_tx_action); open_softirq...硬中断是昂贵的,因为它们不能被中断。即使有中断 合并(稍后详细描述),中断处理程序将独占一个 CPU 内核 完全地。NAPI 的设计允许驱动程序进入轮询模式而不是被 为每个需要的数据包接收硬中断。...完成后,内核将退出轮询例程并重新启动,然后整个过程将 重复自己。

2.6K20

中断和实时性

中断和实时性 翻译自:Software interrupts and realtime Linux内核中断("softirq")机制有些奇怪,在早期的Linux和处理机制下比较晦涩,且仅有极少的内核开发人员会直接接触中断...例如,当一个内核子系统调用tasklet_schedule()时,会在对应的CPU上设置TASKLET_SOFTIRQ 比特位,当中断处理完毕后(开中断),会运行微线程 (tasklet基于中断)。...作为回应,3.6.1-rt1对中断的处理又作了改动。现在,当一个线程触发一个中断时,内核会保存特定的中断(如处理接收到的网络报文时)。...一旦线程退出,内核会禁用该中断的上下文,并运行下一个中断,使用这种方式可以减小处理中断的延迟(由于会立即运行下一个中断)。同样重要的是,这种方式将中断和产生该中断的进程绑定到了一起。...参考: Linux中断 - softirq

2K20

有种中断

Workqueue 工作队列是利用内核线程来异步执行工作任务的通用机制,利用进程上下文来执行中断处理中耗时的任务,因此它允许睡眠。而 Softirq 和 Tasklet 在处理任务时不能睡眠。...CPU 都创建了一个中断处理内核线程 ksoftirqd。...什么是中断线程化处理?上面我们讲到 Linux 内核会为每个 CPU 都创建一个内核线程 ksoftirqd,当需要中断线程化处理的时候,会通过 wakeup_softirqd 唤醒内核线程来执行。...= TASK_RUNNING) //唤醒内核线程来处理中断,运行内核线程中的执行函数 run_ksoftirqd wake_up_process(tsk); } 通过 wake_up_process...在 Linux 内核中有两种 tasklet,一种是高优先级 tasklet,一种是普通 tasklet。

82140
领券