【linux】【操作系统】内核之traps.c源码阅读

在这里插入图片描述

C 文件·traps.c 是 Linux 内核的一部分,主要处理硬件陷阱和故障。文件中包含多个函数来处理不同类型的异常和错误。下面是详细的解析:

概览

  • 目的:此文件负责处理各种硬件异常和故障。它包括了处理特定类型错误以及初始化异常处理器的函数。
  • 文件结构:文件以描述目的和版权信息的注释开头,接着包含了必要的头文件,并定义了一些用于访问内存段的宏。

关键函数

1. die

  • 描述:一个辅助函数,用于打印关于异常的诊断信息并退出进程。
  • 使用:
    打印错误类型、寄存器和其他相关信息。
    调用 do_exit 并传入状态码 11 来终止进程。

2. 异常处理函数

这些函数在发生特定的硬件异常时被调用。它们通常会调用 die 函数来打印诊断信息并终止进程。

  • do_double_fault
    • 描述:处理双故障异常。
    • 参数:esp(指向栈的指针),error_code
  • do_general_protection
    • 描述:处理一般保护故障。
    • 参数:esp(指向栈的指针),error_code
  • do_divide_error
    • 描述:处理除零错误。
    • 参数:esp(指向栈的指针),error_code。
  • do_int3
    • 描述:处理 INT3 指令(软件断点)。
    • 参数:寄存器和段描述符。
  • do_nmi, do_debug, do_overflow, do_bounds, do_invalid_op, do_device_not_available, do_coprocessor_segment_overrun, do_invalid_TSS, do_segment_not_present, do_stack_segment, do_coprocessor_error, **

这些函数分别处理非屏蔽中断、调试异常、溢出、边界越界、无效操作、设备不可用、协处理器段越界、无效的任务状态段、段不存在、堆栈段错误以及协处理器错误等异常情况。每个函数都会根据具体的异常类型采取相应的处理措施,通常是调用 die 函数来打印错误信息并终止进程。

3. trap_init

  • 详细解释
    trap_init() 函数负责初始化一个计算机系统的中断和异常处理程序。它通过设置不同类型的门(gate)来指定对于特定类型的中断或异常应调用哪个处理函数。

  • (Gate)说明

    • Trap Gate: 用于处理异常(如除法错误、非法指令等)。
    • System Gate: 用于处理软件中断(如 INT 3 指令)。
  • 具体设置

    • 设置 Trap Gates

      • 0: Divide Error (&divide_error): 处理除法错误。
      • 1: Debug (&debug): 调试异常处理。
      • 2: NMI (&nmi): 非屏蔽中断处理。
      • 6: Invalid Opcode (&invalid_op): 非法操作码处理。
      • 7: Device Not Available (&device_not_available): 设备不可用处理。
      • 8: Double Fault (&double_fault): 双重故障处理。
      • 9: Coprocessor Segment Overrun (&coprocessor_segment_overrun): 协处理器段越界处理。
      • 10: Invalid TSS (&invalid_TSS): 无效任务状态段处理。
      • 11: Segment Not Present (&segment_not_present): 段不存在处理。
      • 12: Stack Segment (&stack_segment): 栈段错误处理。
      • 13: General Protection (&general_protection): 一般保护错误处理。
      • 14: Page Fault (&page_fault): 页面错误处理。
      • 15: Reserved (&reserved): 预留处理。
      • 16: Coprocessor Error (&coprocessor_error): 协处理器错误处理。
      • 17-47: Reserved (&reserved): 这些中断号被预留未使用。
      • 45: IRQ13 (&irq13): IRQ13 中断处理。
    • 设置 System Gates

      • 3: INT 3 (&int3): 处理 INT 3 指令触发的中断。
      • 4: Overflow (&overflow): 处理溢出异常。
      • 5: Bounds (&bounds): 处理越界异常。
    • 并口中断设置

      • 39: Parallel Interrupt (&parallel_interrupt): 并口中断处理。
        关闭 PIC 中断
    • 使用 outb_p inb_p 函数控制可编程中断控制器 (PIC) 的寄存器以禁用某些中断。

      • 0x21: 禁用 IRQ2 (从8259B)。
      • 0xA1: 禁用 IRQ2 (主8259A)。
  • 总结
    该函数通过设置 Trap Gates System Gates 来初始化中断和异常处理程序。
    它确保了操作系统能够响应各种硬件和软件异常,并且能够处理特定的中断请求。
    此外,还通过控制 PIC 寄存器来管理部分中断的启用或禁用。

源码

/**  linux/kernel/traps.c**  (C) 1991  Linus Torvalds*//** 'Traps.c' handles hardware traps and faults after we have saved some* state in 'asm.s'. Currently mostly a debugging-aid, will be extended* to mainly kill the offending process (probably by giving it a signal,* but possibly by killing it outright if necessary).*/
#include <string.h>#include <linux/head.h>
#include <linux/sched.h>
#include <linux/kernel.h>
#include <asm/system.h>
#include <asm/segment.h>
#include <asm/io.h>#define get_seg_byte(seg,addr) ({ \
register char __res; \
__asm__("push %%fs;mov %%ax,%%fs;movb %%fs:%2,%%al;pop %%fs" \:"=a" (__res):"0" (seg),"m" (*(addr))); \
__res;})#define get_seg_long(seg,addr) ({ \
register unsigned long __res; \
__asm__("push %%fs;mov %%ax,%%fs;movl %%fs:%2,%%eax;pop %%fs" \:"=a" (__res):"0" (seg),"m" (*(addr))); \
__res;})#define _fs() ({ \
register unsigned short __res; \
__asm__("mov %%fs,%%ax":"=a" (__res):); \
__res;})int do_exit(long code);void page_exception(void);void divide_error(void);
void debug(void);
void nmi(void);
void int3(void);
void overflow(void);
void bounds(void);
void invalid_op(void);
void device_not_available(void);
void double_fault(void);
void coprocessor_segment_overrun(void);
void invalid_TSS(void);
void segment_not_present(void);
void stack_segment(void);
void general_protection(void);
void page_fault(void);
void coprocessor_error(void);
void reserved(void);
void parallel_interrupt(void);
void irq13(void);static void die(char * str,long esp_ptr,long nr)
{long * esp = (long *) esp_ptr;int i;printk("%s: %04x\n\r",str,nr&0xffff);printk("EIP:\t%04x:%p\nEFLAGS:\t%p\nESP:\t%04x:%p\n",esp[1],esp[0],esp[2],esp[4],esp[3]);printk("fs: %04x\n",_fs());printk("base: %p, limit: %p\n",get_base(current->ldt[1]),get_limit(0x17));if (esp[4] == 0x17) {printk("Stack: ");for (i=0;i<4;i++)printk("%p ",get_seg_long(0x17,i+(long *)esp[3]));printk("\n");}str(i);printk("Pid: %d, process nr: %d\n\r",current->pid,0xffff & i);for(i=0;i<10;i++)printk("%02x ",0xff & get_seg_byte(esp[1],(i+(char *)esp[0])));printk("\n\r");do_exit(11);		/* play segment exception */
}void do_double_fault(long esp, long error_code)
{die("double fault",esp,error_code);
}void do_general_protection(long esp, long error_code)
{die("general protection",esp,error_code);
}void do_divide_error(long esp, long error_code)
{die("divide error",esp,error_code);
}void do_int3(long * esp, long error_code,long fs,long es,long ds,long ebp,long esi,long edi,long edx,long ecx,long ebx,long eax)
{int tr;__asm__("str %%ax":"=a" (tr):"0" (0));printk("eax\t\tebx\t\tecx\t\tedx\n\r%8x\t%8x\t%8x\t%8x\n\r",eax,ebx,ecx,edx);printk("esi\t\tedi\t\tebp\t\tesp\n\r%8x\t%8x\t%8x\t%8x\n\r",esi,edi,ebp,(long) esp);printk("\n\rds\tes\tfs\ttr\n\r%4x\t%4x\t%4x\t%4x\n\r",ds,es,fs,tr);printk("EIP: %8x   CS: %4x  EFLAGS: %8x\n\r",esp[0],esp[1],esp[2]);
}void do_nmi(long esp, long error_code)
{die("nmi",esp,error_code);
}void do_debug(long esp, long error_code)
{die("debug",esp,error_code);
}void do_overflow(long esp, long error_code)
{die("overflow",esp,error_code);
}void do_bounds(long esp, long error_code)
{die("bounds",esp,error_code);
}void do_invalid_op(long esp, long error_code)
{die("invalid operand",esp,error_code);
}void do_device_not_available(long esp, long error_code)
{die("device not available",esp,error_code);
}void do_coprocessor_segment_overrun(long esp, long error_code)
{die("coprocessor segment overrun",esp,error_code);
}void do_invalid_TSS(long esp,long error_code)
{die("invalid TSS",esp,error_code);
}void do_segment_not_present(long esp,long error_code)
{die("segment not present",esp,error_code);
}void do_stack_segment(long esp,long error_code)
{die("stack segment",esp,error_code);
}void do_coprocessor_error(long esp, long error_code)
{if (last_task_used_math != current)return;die("coprocessor error",esp,error_code);
}void do_reserved(long esp, long error_code)
{die("reserved (15,17-47) error",esp,error_code);
}void trap_init(void)
{int i;set_trap_gate(0,&divide_error);set_trap_gate(1,&debug);set_trap_gate(2,&nmi);set_system_gate(3,&int3);	/* int3-5 can be called from all */set_system_gate(4,&overflow);set_system_gate(5,&bounds);set_trap_gate(6,&invalid_op);set_trap_gate(7,&device_not_available);set_trap_gate(8,&double_fault);set_trap_gate(9,&coprocessor_segment_overrun);set_trap_gate(10,&invalid_TSS);set_trap_gate(11,&segment_not_present);set_trap_gate(12,&stack_segment);set_trap_gate(13,&general_protection);set_trap_gate(14,&page_fault);set_trap_gate(15,&reserved);set_trap_gate(16,&coprocessor_error);for (i=17;i<48;i++)set_trap_gate(i,&reserved);set_trap_gate(45,&irq13);outb_p(inb_p(0x21)&0xfb,0x21);outb(inb_p(0xA1)&0xdf,0xA1);set_trap_gate(39,&parallel_interrupt);
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/390134.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

前端的学习-CSS(弹性布局-flex)

一&#xff1a;什么是弹性布局-Flex flex 是 Flexible Box 的缩写&#xff0c;意为"弹性布局"&#xff0c;用来为盒状模型提供最大的灵活性。 语法&#xff1a; .box{display: flex; } .box{display: inline-flex; } 注意&#xff0c;设为 Flex 布局以后&#xff0…

SpringBoot整合Knife4j接口文档

1. 在项目入口模块pom文件导入依赖 <!-- knife4j&#xff08;API 文档工具&#xff09; --><dependency><groupId>com.github.xiaoymin</groupId><artifactId>knife4j-openapi2-spring-boot-starter</artifactId><version>${knife4j…

新款奔驰S450升级动态按摩座椅有哪些功能

奔驰 S450 升级前排动态按摩座椅通常具有以下功能&#xff1a; 1. 多种按摩模式和强度选择&#xff1a;通过精心设计的气囊和机械装置&#xff0c;能够模拟如揉捏、敲击、推拿等不同的按摩手法&#xff0c;为驾驶者和前排乘客舒缓肌肉疲劳&#xff0c;放松身心。 2. 广泛的按…

6.C基础_输入输出函数

putchar 功能&#xff1a;输出一个字符 函数声明&#xff1a; int putchar(int c);返回值&#xff1a;参数c的ASCLL码值 c&#xff1a;要输出的字符&#xff0c;可以为字符常量、字符变量或表达式 注意点&#xff1a;输出的结果不带\n getchar 功能&#xff1a;从键盘读…

SpringCache集成Redis

1. 添加config配置类 配置SpringCache 与 redis 的集成 配置类 2. 在service层中加注解 在Service层中增加注解 CacheConfig() 里面的CacheNmes是redis的nameSpace命名空间 方法上的Cacheable是key的值 请求结果 第一次会查数据库&#xff0c;后面相同的查询会直接走redis&am…

LBS 开发微课堂|Polyline绘制优化:效果更丰富,性能更佳!

为了让广大的开发者 更深入地了解 百度地图开放平台的技术能力 轻松掌握满满的技术干货 更加简单地接入 开放平台的服务 我们特别推出了 “位置服务&#xff08;LBS&#xff09;开发微课堂” 系列技术案例 第一期的主题是 《Polyline 绘制优化升级》 你还想了解哪些…

vulhub:Apache解析漏洞CVE-2017-15715

Apache HTTPD是一款HTTP服务器&#xff0c;它可以通过mod_php来运行PHP网页。其2.4.0~2.4.29版本中存在一个换行解析漏洞&#xff0c;在解析PHP时&#xff0c;1.php\x0A将被按照PHP后缀进行解析&#xff0c;导致绕过一些服务器的安全策略。 #启动靶机 cd /Vulnhub/vulhub-mast…

程序员的魔法石!

本文由 ChatMoney团队出品 AI自己写代码&#xff0c;这只是传说&#xff1f;还是摸鱼新指南&#xff1f; AI出现之前&#xff0c;从来都是老板或产品经理提需求&#xff0c;程序员熬夜加班吭哧吭哧写代码或者是从Github&#xff0c;Stackoverflow上controlc&#xff0c;control…

JavaFX布局-GridPane

JavaFX布局-GridPane 常用实行alignmenthgapvgappaddinggridLinesVisible 实现方式Java实现fxml实现 使用行和列来组织其子节点将节点放置在二维网格中的任何单元格&#xff0c;同时也可以设置跨越行、跨越列 常用实行 alignment 对齐方式&#xff0c;设置内容居中&#xff0…

数据库文件管理

数据库文件与普通文件区别: 1.普通文件对数据管理(增删改查)效率低 2.数据库对数据管理效率高,使用方便 常用数据库: 1.关系型数据库&#xff1a; 将复杂的数据结构简化为二维表格形式 大型:Oracle、DB2 中型:MySql、SQLServer 小型:Sqlite 2.非关…

第三十一天 chrome调试工具

打开调试工具 页面空白处右击 检查 或者F12 使用调试工具 ctrl滚轮改变代码大小 左边是html 右边是css css可以直接改动数值左右箭头或者直接输入 查看颜色 ctrl0 复原浏览器大小 点击元素右侧出现样式引入 没有的话 说明类名或者样式引用错误 这里的.new-left是存在的 如果类…

【Android Studio】UI 布局

文章目录 view布局LinearLayout view 在Android开发中&#xff0c;View是一个非常重要的概念&#xff0c;它是所有用户界面组件的基类。View类及其子类构成了Android应用中的用户界面。每个View都占用屏幕上的一个矩形区域&#xff0c;并可以响应用户输入&#xff08;如触摸、按…

鸿蒙(API 12 Beta2版)NDK开发【JSVM-API使用规范】

JSVM-API使用规范 生命周期管理 【规则】 合理使用OH_JSVM_OpenHandleScope和OH_JSVM_CloseHandleScope管理JSVM_Value的生命周期&#xff0c;做到生命周期最小化&#xff0c;避免发生内存泄漏问题。 每个JSVM_Value属于特定的HandleScope&#xff0c;HandleScope通过OH_JSV…

MySQL精简笔记

基础类型 bit&#xff0c;tinyint&#xff0c;smallint&#xff0c;int&#xff0c;bigintfload&#xff0c;double&#xff08;M&#xff1a;整数小数的位数&#xff0c;D&#xff1a;小数的位数&#xff09;decimal&#xff0c;numeric&#xff08;M&#xff0c;D)&#xff0…

大模型分布式训练之DeepSpeed优化器并行(ZeRO)原理

由于大模型参数量非常庞大&#xff0c;所以我们常常需要用到分布式训练来解决训练过程中计算资源不足的问题&#xff0c;现在也出现了很多大模型相关的分布式训练框架&#xff0c;但是使用的比较多的还是deepspeed的数据并行&#xff0c;那么deepspeed是怎么实现数据并行的呢 文…

【Unity】web gl inputFied 中文输入,同时支持TextMeshInputFied,支持全屏

同时支持TextMeshInputFied&#xff0c;支持全屏。 使用github包【WebGLInput】&#xff1a;https://github.com/kou-yeung/WebGLInput 需要资源的在这里也可以下载 https://download.csdn.net/download/weixin_46472622/89600795 用于unity web gl 中文输入&#xff0c;只需…

【人工智能】边缘计算与 AI:实时智能的未来

&#x1f48e; 我的主页&#xff1a;2的n次方_ &#x1f48e;1. 引言 随着物联网设备数量的爆炸性增长和对实时处理需求的增加&#xff0c;边缘计算与人工智能&#xff08;Edge AI&#xff09;成为一个热门话题。Edge AI 通过在本地设备上运行 AI 算法&#xff0c;减少对云计…

大数据-61 Kafka 高级特性 消息消费02-主题与分区 自定义反序列化 拦截器 位移提交 位移管理 重平衡

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; 目前已经更新到了&#xff1a; Hadoop&#xff08;已更完&#xff09;HDFS&#xff08;已更完&#xff09;MapReduce&#xff08;已更完&am…

Python酷库之旅-第三方库Pandas(062)

目录 一、用法精讲 241、pandas.Series.view方法 241-1、语法 241-2、参数 241-3、功能 241-4、返回值 241-5、说明 241-6、用法 241-6-1、数据准备 241-6-2、代码示例 241-6-3、结果输出 242、pandas.Series.compare方法 242-1、语法 242-2、参数 242-3、功能 …

最新小猫咪PHP加密系统源码V1.4_本地API接口_带后台

简介&#xff1a; 最新小猫咪PHP加密系统源码V1.4_完全本地化加密API接口_带后台 小猫咪PHP加密系统历时半年&#xff0c;它再一次迎来更新&#xff0c;更新加密算法&#xff08;这应该是最后一次更新加密算法了&#xff0c;以后主要更新都在框架功能上面了&#xff09;&…