从零开始操作系统-07:APIC

news2025/1/12 21:47:54

这一节主要主要是APIC。

所需要的文件在Github:https://github.com/yongkangluo/Ubuntu20.04OS/tree/main/Files/Lec7-ExternalInterrupt

历史方法:PIC(Programmable Interrupt Controller)
Intel 8259:

在这里插入图片描述

APIC(Advanced Programmable Interrupt Controller)

APIC是为了多核渠道而规划的。它由两个部分组成IOAPIC和LAPIC,其间IOAPIC一般坐落南桥中用于处理桥上的设备所发生的各种中止,LAPIC则是每个CPU都会有一个。IOAPIC经过APICBUS(现在都是经过FSB/QPI)将中止信息分派给每颗CPU的LAPIC。CPU上的LAPIC可以智能的决议是否承受体系总线上传递过来的中止信息,并且它还可以处理Local端中止的pending、nesting、masking,以及IOAPIC于Local CPU的交互处理。
在这里插入图片描述1. LVT与寄存器
LVT (Local Vector Table)是一组APIC内置寄存器,定义APIC的本地中断至CPU中断向量号的映射。
在这里插入图片描述
2. 初始化AIPC

  • 禁用中断
  • 禁用8259PIC
  • 硬启用LAPIC
  • 初始化LAPIC
  • 设置中断优先级
  • 初始化LVT
  • 软启用LAPIC
  • 初始化I/O APIC
  • 映射IRQ至中断
  • 打开中断

硬启用Local APIC
在这里插入图片描述

movl $0x1B, %ecx
rdmsr
orl $0x800, %eax
wdmsr

中断优先级
在这里插入图片描述
只执行 中断号大于 16 * Process-Priority Class + Process-Priority Sub Class 的中断。

初始化LVT

伪中断 :告诉CPU这个中断时误触发的,是噪声。

软启动LVT APIC
在这里插入图片描述
初始化I/O APIC
Local APIC 的所有寄存器都是映射在内存 0xFFE00000。

使用ACPI来获取 I/O APIC 的地址。

ACPI(Advanced Configuration and Power Management Interface)

过程是: 通过字头签名找到(Root Description Pointer RSDP),通过RSDP找到RSDT表,找到MADT表,找到I/OAPIC Structure的寄存器地址。

Code Time

init_apic()
{
	//关闭外部中断
    cpu_disable_interrupt();
    assert_msg(cpu_has_apic(), "No APIC detected!");
    //关闭PIC
    pic_disable();
    //全局启用APIC
    asm volatile (
        "movl %0, %%ecx\n"
        "rdmsr\n"
        "orl %1, %%eax\n"
        "wrmsr\n"
        ::"i"(IA32_APIC_BASE_MSR), "i"(IA32_APIC_ENABLE)
        : "eax", "ecx", "edx"
    );
    uint32_t apic_id = apic_read_reg(APIC_IDR) >> 24;
    uint32_t apic_ver = apic_read_reg(APIC_VER);
    kprintf(KINFO "ID: %x, Version: %x, Max LVT: %u\n",
           apic_id,
           apic_ver & 0xff,
           (apic_ver >> 16) & 0xff);
    //设置LVT表
    apic_setup_lvts();
    //设置等级
    apic_write_reg(APIC_TPR, APIC_PRIORITY(2, 0));
    uint32_t spiv = apic_read_reg(APIC_SPIVR);
    spiv = (spiv & ~0xff) | APIC_SPIV_APIC_ENABLE  | APIC_SPIV_IV;
    apic_write_reg(APIC_SPIVR, spiv);
    apic_setup_timer();
}

具体的代码都在github上。
在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

小侃设计模式(十三)-策略模式

1.概述 策略模式(Strategy Pattern)是一种比较简单的模式,它定义了算法家族,分别封装起来,让它们之间可以互相替换,此模式让算法的变化,不会影响到使用算法的客户。策略模式具有较强的实用性&a…

ARM学习扫盲篇(一):CPSRSPSR、LcacheDcache、w/parityw/ECC

1、CPSR&SPSR CPSR—程序状态寄存器(current program status register) SPSR—程序状态保存寄存器(saved program status register) Icache&Dcache icache用来缓存指令; dcache用来缓存数据,dcache用的前提是mmu要启动…

(续)SSM整合之SSM整合笔记(ContextLoaderListener)(P177-178)

目录 ContextLoaderListener 一 ContextLoaderListener 二 测试ContextLoaderListener 1 新建模块spring_listener com.atguigu 2. 导入依赖 3 .转web 4 .web.xml 5 springmvc.xml 6 .spring.xml 7 首页index.html 8 控制层 HelloController 9 service接口…

【24计算机考研】备考前必须了解的避坑小知识,建议收藏

前言 我们可能已经了解到最近两三年的考研趋势,疫情的原因,不断增加的二战三战考生,导致每年考研人数持续增长,那么,如何在相同的时间里,赶超你的竞争对手,避坑 绝对是很重要的。 考研将是一场…

【Spring】——9、如何指定初始化和销毁的方法?

📫作者简介:zhz小白 公众号:小白的Java进阶之路 专业技能: 1、Java基础,并精通多线程的开发,熟悉JVM原理 2、熟悉Java基础,并精通多线程的开发,熟悉JVM原理,具备⼀定的线…

(STM32)从零开始的RT-Thread之旅--SPI驱动ST7735(3)使用DMA

上一篇: (STM32)从零开始的RT-Thread之旅--SPI驱动ST7735(2) 上一篇完成了ST7735驱动的移植,并已经可以通过SPI在屏幕上显示字符了,这一章会把SPI修改为DMA的传输方式。由于RTT对于STM32H7的SPI的DMA传输方式目前支持的并不好,这…

Vuex3使用教程(待续)

Vuex定义 以下是Vue官网对于Vuex的定义: Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式 库。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。 从官方定义上看: Vuex提供了一个全部组件…

Java注释:单行、多行和文档注释

注释是对程序语言的说明,有助于开发者和用户之间的交流,方便理解程序。注释不是编程语句,因此被编译器忽略。 Java入门基础视频教程,java零基础自学就选黑马程序员Java入门教程(含Java项目和Java真题) Ja…

【Django】Django4.1.2使用xadmin避坑指南(二)

上一篇【Django】Django4.1.2使用xadmin避坑指南调完后,还是继续有问题,没事,咱们继续,必须啃下硬骨头~ 文章目录环境问题一:if not ContentType._meta.installed:这一句报错:AttributeError: Options obje…

《深度学习进阶 自然语言处理》第八章:Attention介绍

文章目录8.1 Attention结构8.1.1 seq2seq存在的问题8.1.2 编码器的改进8.1.3 解码器的改进8.2 Attention的应用8.3 总结之前文章链接: 开篇介绍:《深度学习进阶 自然语言处理》书籍介绍 第一章:《深度学习进阶 自然语言处理》第一章&#xf…

SSH连接WSL2踩坑记录与增加端口转换规则,实现外网与WSL2的连接

SSH连接WSL2踩坑记录 文章目录SSH连接WSL2踩坑记录1. 在WSL里的操作2. ssh连接3. 可能出现的错误4. 再配置端口转发到WSL1. 在WSL里的操作 1.1 重装openssh-server sudo remove openssh-server # 如果已经安装了,建设先卸载 sudo apt install openssh-server…

Ansys Lumerical | 行波 Mach-Zehnder 调制器仿真分析

前言 本示例描述了行波 Mach-Zehnder 调制器的完整多物理场(电气、光学、射频)仿真,最后在INTERCONNECT中进行了紧凑模型电路仿真。计算了相对相移、光学传输、传输线带宽和眼图等关键结果。 综述 此示例中5毫米长的Si波导由5毫米长的Al共面…

SpringBoot SpringBoot 开发实用篇 5 整合第三方技术 5.24 SpringBoot 整合 RabbitMQ(topic 模式)

SpringBoot 【黑马程序员SpringBoot2全套视频教程,springboot零基础到项目实战(spring boot2完整版)】 SpringBoot 开发实用篇 文章目录SpringBootSpringBoot 开发实用篇5 整合第三方技术5.24 SpringBoot 整合 RabbitMQ(topic 模式)5.24.1 …

FL Studio2023水果编曲软件最新版安装教程

FL Studio中文版是知名的音乐制作软件,让你的计算机就像是全功能的录音室,软件包含13种虚拟音源,可同时录制64轨音频轨,FL Studio中文版拥有的漂亮的大混音盘,先进的创作工具,让你的音乐突破想象力的限制&a…

智能化油田建设规划

一、数字化油田-技术现状 数字化油田实现了设备的远程生产过程监控,使井场实现无人值守。所以目前的设备运行维护管理系统只能实现数据统计管理,并不能实现设备状态监控及远程维护及故障诊断。 1、数字化油田— 存在的问题 缺少设备状态在线监测系统&a…

第三章. 业务功能开发--用户登录安全退出

第三章. 业务功能开发--用户登录安全退出 1. 用户登录 需求: 用户在登录页面,输入用户名和密码,点击"登录"按钮或者回车,完成用户登录的功能.*用户名和密码不能为空*用户名或者密码错误,用户已过期,用户状态被锁定,ip受限 都不能登录成功*登录成功之后,所…

Android Jetpack之Lifecycle的使用及源码分析

Lifecycle生命周期感知型组件可执行操作来响应另一个组件(如 Activity 和 Fragment)的生命周期状态的变化。这些组件有助于您编写出更有条理且往往更精简的代码,此类代码更易于维护。 尤其是在Activity和Fragment在已经默认支持LifeCycle的情…

【第五部分 | JS WebAPI】3:DOM 节点操作

目录 | 节点操作 1-1 概述 2-1 获取父节点 3-1 获取子节点(获取所有子对象 不推荐) 3-2 获取子节点(获取所有子【元素节点】) 3-3 获取首尾子节点 4-1 获取兄弟节点 5-1 动态创建、添加节点 5-2 案例:评论区 …

性能测试_JMeter_connection timed out :connect

jmeter报错:failed:connection timed out :connect/java.net.BindException: Address already in use: connect java.net.BindException: Address already in use: connectat java.net.DualStackPlainSocketImpl.connect0(Native Method)at java.net.DualStackPlainSocketImpl…

Linux系统上安装软件

安装jdk,安装tomcat,安装Mysql 四种安装方式: 安装jdk 1.去这个网站上下载linux版本的jdk Java Archive Downloads - Java SE 8 2.在虚拟机中的服务器终端中输入ifconfig(注意不是ipconfig,而是ifconfig…