Xv6驱动(一):PLIC

2024-08-26 07:36
文章标签 驱动 xv6 plic

本文主要是介绍Xv6驱动(一):PLIC,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

PLIC内存布局

#define PLIC 0x0c000000L
#define PLIC_PRIORITY (PLIC + 0x0)
#define PLIC_PENDING (PLIC + 0x1000)
#define PLIC_SENABLE(hart) (PLIC + 0x2080 + (hart) * 0x100)
#define PLIC_SPRIORITY(hart) (PLIC + 0x201000 + (hart) * 0x2000)
#define PLIC_SCLAIM(hart) (PLIC + 0x201004 + (hart) * 0x2000)

Xv6外部中断

外部中断通常是指来自处理器外部设备的中断。

Xv6只支持两个外设:

  • uart0:中断号为10,映射到物理内存0x10000000
  • virtio disk:中断号为1,映射到物理内存0x10001000
// qemu puts UART registers here in physical memory.
#define UART0 0x10000000L
#define UART0_IRQ 10// virtio mmio interface
#define VIRTIO0 0x10001000
#define VIRTIO0_IRQ 1

 PLIC驱动

plicinit函数

同虚拟内存初始化,PLIC的初始化也是两阶段初始化。第一阶段的初始化由cpu0执行,也就是说该函数只执行一次。

该函数的任务是设置中断优先级。Xv6只支持两个外设:UARTvirtio mmio disk,该函数把这两个外设的中断优先级都设置为1。此外,RISC-V规定:如果两个相同优先级的中断同时触发,那么编号小的中断具有较高的优先级。

void plicinit(void)
{// set desired IRQ priorities non-zero (otherwise disabled).*(uint32 *)(PLIC + UART0_IRQ * 4) = 1;*(uint32 *)(PLIC + VIRTIO0_IRQ * 4) = 1;
}

plicinithart函数

该函数是PLIC的第二阶段初始化,每个核心初始化时都要执行这个函数。

该函数会使能S模式下的uart中断和virtio disk中断,并且设置S模式下中断阈值为0

这就说明了:

  1. 如果发生外部中断,那么每个核心都会收到外部中断的信号
  2. 只有一个核心会处理这次外部中断
void plicinithart(void)
{int hart = cpuid();// set enable bits for this hart's S-mode// for the uart and virtio disk.*(uint32 *)PLIC_SENABLE(hart) = (1 << UART0_IRQ) | (1 << VIRTIO0_IRQ);// set this hart's S-mode priority threshold to 0.*(uint32 *)PLIC_SPRIORITY(hart) = 0;
}

plic_claim函数

该函数由异常处理程序调用,用来返回异常号。如果同时有多个中断发生,PLIC硬件会根据之前的配置返回当前待定中断源中优先级最高的那个。其中只有一个核心会得到异常号,其他的核心的返回值是0

int plic_claim(void)
{int hart = cpuid();int irq = *(uint32 *)PLIC_SCLAIM(hart);return irq;
}

plic_complete函数 

中断请求寄存器和中断完成寄存器是同一个寄存器。中断处理程序处理完中断后,会调用该函数,同时将中断号写入该寄存器中

void plic_complete(int irq)
{int hart = cpuid();*(uint32 *)PLIC_SCLAIM(hart) = irq;
}

 参考资料

The xv6 Kernel-27 PLIC_Platform Level Interrupt Controller_哔哩哔哩_bilibili

Lecture 9 - Interrupts 中文版_哔哩哔哩_bilibili

这篇关于Xv6驱动(一):PLIC的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

如何在Ubuntu上安装NVIDIA显卡驱动? Ubuntu安装英伟达显卡驱动教程

《如何在Ubuntu上安装NVIDIA显卡驱动?Ubuntu安装英伟达显卡驱动教程》Windows系统不同,Linux系统通常不会自动安装专有显卡驱动,今天我们就来看看Ubuntu系统安装英伟达显卡... 对于使用NVIDIA显卡的Ubuntu用户来说,正确安装显卡驱动是获得最佳图形性能的关键。与Windo

嵌入式Linux之使用设备树驱动GPIO的实现方式

《嵌入式Linux之使用设备树驱动GPIO的实现方式》:本文主要介绍嵌入式Linux之使用设备树驱动GPIO的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、设备树配置1.1 添加 pinctrl 节点1.2 添加 LED 设备节点二、编写驱动程序2.1

嵌入式Linux驱动中的异步通知机制详解

《嵌入式Linux驱动中的异步通知机制详解》:本文主要介绍嵌入式Linux驱动中的异步通知机制,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、异步通知的核心概念1. 什么是异步通知2. 异步通知的关键组件二、异步通知的实现原理三、代码示例分析1. 设备结构

usb接口驱动异常问题常用解决方案

《usb接口驱动异常问题常用解决方案》当遇到USB接口驱动异常时,可以通过多种方法来解决,其中主要就包括重装USB控制器、禁用USB选择性暂停设置、更新或安装新的主板驱动等... usb接口驱动异常怎么办,USB接口驱动异常是常见问题,通常由驱动损坏、系统更新冲突、硬件故障或电源管理设置导致。以下是常用解决

Linux_kernel驱动开发11

一、改回nfs方式挂载根文件系统         在产品将要上线之前,需要制作不同类型格式的根文件系统         在产品研发阶段,我们还是需要使用nfs的方式挂载根文件系统         优点:可以直接在上位机中修改文件系统内容,延长EMMC的寿命         【1】重启上位机nfs服务         sudo service nfs-kernel-server resta

驱动(RK3588S)第七课时:单节点设备树

目录 需求一、设备树的概念1、设备树的后缀名:2、设备树的语法格式3、设备树的属性(重要)4、设备树格式举例 二、设备树所用函数1、如何在内核层种获取设备树节点:2、从设备树上获取 gpio 口的属性3、获取节点上的属性只针对于字符串属性的4、函数读取 np 结点中的 propname 属性的值,并将读取到的 u32 类型的值保存在 out_value 指向的内存中,函数的返回值表示读取到的

驱动安装注册表指令

HKCR: HKEY_CLASSES_ROOT HKCU: HKEY_CURRENT_USER HKLM: HKEY_LOCAL_MACHINE HKU: HEKY_USER HER: 相对根键

UMDF驱动安装

VS2013 + WDF8.1,UMDF驱动选择User Mode Driver,不要选User Mode Driver 2.0,否则Win7安装有问题,如图 另外,在驱动安装时不要忘记WUDFUpdate_<主版本号><次版本号>.dll文件,具体文件名在INF中查找。此文件可在WDF的安装目录中找到。注意:在WDF的安装目录中会有3个WUDFUpdate_xxx.dll文件,x86,x6

电脑驱动分类

电脑驱动程序(驱动程序)是操作系统与硬件设备之间的桥梁,用于使操作系统能够识别并与硬件设备进行通信。以下是常见的驱动分类: 1. 设备驱动程序 显示驱动程序:控制显卡和显示器的显示功能,负责图形渲染和屏幕显示。 示例:NVIDIA、AMD 显示驱动程序。打印机驱动程序:允许操作系统与打印机通信,控制打印任务。 示例:HP、Canon 打印机驱动程序。声卡驱动程序:管理音频输入和输出,与声卡硬件

麒麟系统安装GPU驱动

1.nvidia 1.1显卡驱动 本机显卡型号:nvidia rtx 3090 1.1.1下载驱动 打开 https://www.nvidia.cn/geforce/drivers/ 也可以直接使用下面这个地址下载 https://www.nvidia.com/download/driverResults.aspx/205464/en-us/ 1.1.3安装驱动 右击,