CPU设计实战-协处理器访问指令的实现

目录

一 协处理器的作用与功能

1.计数寄存器和比较寄存器

2.Status寄存器

3.Cause寄存器(标号为13)

4.EPC寄存器(标号为14)

5.PRId寄存器(标号为15)

6.Config 寄存器(标号为16)-配置寄存器

二 协处理器的实现

 三 协处理器访问指令说明

四 具体实现

1.译码阶段

2.执行阶段


一 协处理器的作用与功能

我们之前实现的指令操作很多都是算术操作,CPU还需要进行一些指令集扩展的操作,比如系统控制与浮点单元计算等。MIPS架构定义了四种协处理器如下:

我们在这里只实现CP0的主要功能中的中断异常处理,它还可以进行工作状态的配置如大小端模式的切换,高速缓存控制,存储管理单元控制等。

协处理器中为每种功能定义了相应的32个32位的寄存器,主要是通过读写协处理器中的寄存器去实现相关功能。

我们的目标是实现中断异常管理以及最基本的工作状态的配置,只需要关注上面标黑的寄存器即可。

1.计数寄存器和比较寄存器

定时中断的实现是通过Count计数器寄存器和Compare寄存器来实现的。

Count寄存器是一个不停计数的32位寄存器,计数频率一般与CPU时钟频率相同,当计数达到32位无符号数的上限时,会从0开始重新计数。Count 寄存器可读、可写。
Compare寄存器是一个32位的寄存器,与Count寄存器一起完成定时中断功能。 当Count寄存器中的计数值与Compare寄存器中的值一样时, 会产生定时中断。这个中断会一直保持,直到有数据被写入Compare寄存器。Compare 寄存器可读、可写。 

2.Status寄存器

 Status寄存器也是一个32位、可读、可写的寄存器,用来控制处理器的操作模式、中断使能以及诊断状态。这里我们主要进行中断使能和基本工作状态的配置。

CU3-CU0表示协处理器是否可用(Coprocessor Usability), 分别控制协处理器CP3、CP2、 CPI、
CP0。为0时,表示相应的协处理器不可用;为1时,表示相应的协处理器可用。对于OpenMIPS
处理器而言,只有协处理器CPO,所以可以设置本字段为4'b0001。

IM7-IM0表示是否屏蔽相应中断(Interrupt Mask), 0表示屏蔽,1 表示不屏蔽,MIPS处理器可以
8个中断源,对应IM字段的8位,其中6个中断源是处理器外部硬件中断,另外2个是软件中断

中断是否能够被处理器响应是由Status寄存器与Cause寄存器共同决定的,如果Status寄存器的IM字段(中断源选择)与Cause寄存器的IP字段(外部中断挂是否发生)的相应位都为1,而且Status寄存器的IE字段(全局使能中断)也为1时,处理器才响应相应中断。
EXL表示是否处于异常级(Exception Level), 当异常发生时,会设置本字段为1,表示处理器处于异常级,此时,处理器会进入内核模式下工作,并且禁止中断
IE表示是否使能中断(Interrupt Enable),这是全局中断使能标志位。为1表示中断使能,为0表示中断禁止。

3.Cause寄存器(标号为13)


Cause寄存器主要记录最近一次异常发生的原因,也控制软件中断请求。Cause寄存器的各字段如表10-6所示,除了IP[1:0]、 IV和WP,其余字段都是只读的

4.EPC寄存器(标号为14)


EPC是异常程序计数器(Exception Program Counter),用来存储异常返回地址,一般情况下,存储发生异常的指令的地址,但是,如果发生异常的指令位于延迟槽中,那么EPC存储的是前一条转移指令的地址。因为之前我们定义,延迟槽中的指令就是转移指令之后的指令并且一定执行。所以异常真正发生在转移阶段。

5.PRId寄存器(标号为15)


PRId寄存器是处理器标志( Processor Identifier)寄存器,包含的信息有:制造商信息、处理器类型以及处理器的版本等。各个字段如表10-9所示。其中R是保留字段。

6.Config 寄存器(标号为16)-配置寄存器


Config寄存器包含了与处理器有关的各种配置和功能信息,其各个字段如下所示,大部分字段由硬件在重启时进行初始化,或定为常量。

BE
其值为1表示处理器工作在大端模式(MSB),为0表示处理器工作在小端模式(LSB)。OpenMIPS处理器工作在大端模式,所以设置本字段为1。
AT
指令集架构类型(Architecture Type)字段,当其值为2'b00时,表示MIPS32架构

现在我们可以整理一下中断的实现操作:

中断分为外部中断和定时中断

定时中断的实现是通过Count计数器寄存器和Compare寄存器来实现的。

Count寄存器是一个不停计数的32位寄存器,计数频率一般与CPU时钟频率相同,当计数达到32位无符号数的上限时,会从0开始重新计数。Count 寄存器可读、可写。


Compare寄存器是一个32位的寄存器,与Count寄存器一起完成定时中断功能。 当Count寄存器中的计数值与Compare寄存器中的值一样时, 会产生定时中断。这个中断会一直保持,直到有数据被写入Compare寄存器。Compare 寄存器可读、可写。 

外部中断是否能够被处理器响应是由Status寄存器与Cause寄存器共同决定的,如果Status寄存器的IM字段(中断源选择)与Cause寄存器的IP字段(外部中断挂是否发生)的相应位都为1,而且Status寄存器的IE字段(全局使能中断)也为1时,处理器才响应相应中断。

二 协处理器的实现

之前说过对协处理器指令实现操作本质就是去读写协处理器,所以接口类似于一个单端口的存储器,包括读写使能,读写地址,输出寄存器和外部中断的输入。 

先对寄存器做初始化,主要是对工作状态寄存器进行基本赋值:

读写操作按照读写地址进行赋值,寄存器地址按照之前的表按地址号进行定义。

写操作:

对计数器和比较寄存器进行读写之前先实现他们的基本操作定义输出信号,计数器需要一直计数,cause保留外部中断请求,其值与外部中断输入一致,定时中断请求的输出:

需要注意当写入比较寄存器时,定时中断结束。以及有些寄存器并不是可写的

读操作:

 三 协处理器访问指令说明

 这两个指令一个写一个读:

这2条指令的格式与之前已实现的指令都不同,主要特点是:指令码都为6'b010000,MIPS32 指令集架构定义为COP0类,需要借助于第21~ 25bit的值才能确定具体是哪一条指令。 此外,指令的第3~10bit为0,第0~2bit是sel域,这个域的作用取决于具体的MIPS32架构处理器,对OpenMIPS处理器而言,sel 域没有作用,不用考虑。下面分别说明mtc0、mfc0 两条指令的用法、作用。
●当指令码是6'b010000,且第21~25bit的值为5'"b00100 时,是mtc0指令。
指令用法为:mtc0 rt, rd。
指令作用为: CPR[0, rd] <- GPR[rt],将地址为rt的通用寄存器的值赋给协处理器CP0中地址为rd的寄存器。
●当指令码是 6'b010000,且第21~ 25bit的值为500000时,是mfc0指令。
指令用法为: mfc0 rt, rd。
指令作用为: GPR[rt] <- CPR[0, rd],读出协处理器CPO中地址为rd的寄存器的值,并赋给地址为rt的通用寄存器。
 

四 具体实现

 

指令的读写在执行阶段进行定义,读操作需要提前去读CP0寄存器的值并传递回来,而写操作需要把使能以及写入值与地址传递到CP0.此外新引入的寄存器同样会发生数据相关问题,还是使用数据前推进行解决。

1.译码阶段

mtc0修改CP0寄存器的值,修改的值在rt里,修改的地址在rd中,所以不需要写通用寄存器,但是需要读rt中的值。

mfc0是读出协处理器CPO中地址为rd的寄存器的值,并赋给地址为rt的通用寄存器。需要写通用寄存器,两个地址都在指令中直接用,不需要读寄存器。

2.执行阶段

要实现mfc0需要两步,先去读CP0的值,可能不是最新的值所以判断一下数据相关(如果访存和回写阶段需要写回CP0并且写回地址和我们要读的地址一样),如果是把写入的值直接传过来,记为moveres。

然后再写入:

如果是mtc0 指令,那么给出对CP0中寄存器的写信息:设置写操作信号cp0_ reg_ we. o为WriteEnable、 写入地址为指令中第11~ 15bit的值、写入的值就是译码阶段传递过来的regl_i的值,参考译码阶段可知,该值正是地址为rt的通用寄存器的值。

后面把需要写入寄存器的值一直传递到CP0寄存器就行了。
 

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

git命令行提交——github

1. 克隆仓库至本地 git clone 右键paste&#xff08;github仓库地址&#xff09; cd 仓库路径&#xff08;进入到仓库内部准备提交文件等操作&#xff09; 2. 查看main分支 git branch&#xff08;列出本地仓库中的所有分支&#xff09; 3. 创建新分支&#xff08;可省…

Edu18 -- Divide by Three --- 题解

目录 Divide by Three&#xff1a; 题目大意&#xff1a; ​编辑​编辑思路解析&#xff1a; 代码实现&#xff1a; Divide by Three&#xff1a; 题目大意&#xff1a; 思路解析&#xff1a; 一个数字是3的倍数&#xff0c;那么他的数位之和也是3的倍数&#xff0c;所以我…

安信可IDE(AiThinker_IDE)编译ESP8266工程方法

0 工具准备 AiThinker_IDE.exe ESP8266工程源码 1 安信可IDE&#xff08;AiThinker_IDE&#xff09;编译ESP8266工程方法 1.1 解压ESP8266工程文件夹 我们这里使用的是NON-OS_SDK&#xff0c;将NON-OS_SDK中的1_UART文件夹解压到工作目录即可 我这里解压到了桌面&#xff0c…

WiFi模块助力少儿编程:创新学习与实践体验

随着科技的飞速发展&#xff0c;少儿编程已经成为培养孩子们创造力和问题解决能力的重要途径之一。在这个过程中&#xff0c;WiFi模块的应用为少儿编程领域注入了新的活力&#xff0c;使得学习编程不再是单一的代码教学&#xff0c;而是一个充满创新与实践的综合性体验。 物联网…

Redis作为缓存的数据一致性问题

背景 使用Reids作为缓存的原因&#xff1a; 在高并发场景下&#xff0c;传统关系型数据库的并发能力相对比较薄弱&#xff08;QPS不能太大&#xff09;&#xff1b; 使用Redis做一个缓存。让用户请求先打到Redis上而不是直接打到数据库上。 但是如果出现数据更新操作&#xff…

开发指南002-前后端信息交互规范-概述

前后端之间采用restful接口&#xff0c;服务和服务之间使用feign。信息交互遵循如下平台规范&#xff1a; 前端&#xff1a; 建立api目录&#xff0c;按照业务区分建立不同的.js文件&#xff0c;封装对后台的调用操作。其中qlm*.js为平台预制的接口文件&#xff0c;以qlm_user.…

【红外与可见光融合:条件学习:实例归一化(IN)】

Infrared and visible image fusion based on a two-stage class conditioned auto-encoder network &#xff08;基于两级类条件自编码器网络的红外与可见光图像融合&#xff09; 现有的基于自动编码器的红外和可见光图像融合方法通常利用共享编码器从不同模态中提取特征&am…

arduino安装索尼spresense开发库

arduino安装索尼spresense开发库 一.库安装二.库文件下载1.直接下载2.git下载1.git加速下载2.git下载加速3.将文件导入arduino 一.库安装 打开arduino点击文件->首选项 将以下链接添加进附加开发板管理器网址 https://github.com/sonydevworld/spresense-arduino-compatib…

什么是数据采集与监视控制系统(SCADA)?

SCADA数据采集是一种用于监控和控制工业过程的系统。它可以实时从现场设备获得数据并将其传输到中央计算机&#xff0c;以便进行监控和控制。SCADA数据采集系统通常使用传感器、仪表和控制器收集各种类型的数据&#xff0c;例如温度、压力、流量等&#xff0c;然后将这些数据汇…

【李沐】动手学习ai思路softmax回归实现

来源&#xff1a;https://www.cnblogs.com/blzm742624643/p/15079086.html 一、从零开始实现 1.1 首先引入Fashion-MNIST数据集 1 import torch 2 from IPython import display 3 from d2l import torch as d2l 4 5 batch_size 256 6 train_iter, test_iter d2l.load_data…

tcp流式服务和粘包问题

目录 1.概念 2.流式服务 3.粘包问题 1.概念 套接字是一个全双工的 使用TCP协议通信的双方必须先建立连接,然后才能开始数据的读写,双方都必须为该连接分配必要的内核资源,以管理连接的状态和连接上数据的传输. TCP连接是全双工的,即双方的数据读写可以通过一个连接进行,完成…

集合框架(一)List系列集合

特点 有序&#xff0c;可重复&#xff0c;有索引。 LIst集合的特有方法 /** 目标&#xff1a;掌握List系列集合的特点&#xff0c;以及其提供的特有方法* */import java.util.ArrayList; import java.util.List;public class ListTest1 {public static void main(String[] arg…

android开发环境搭建

android开发环境搭建 Android 开发环境搭建1.JDK安装与配置1.1 Jdk官方下载1.2 JDK安装1.3 环境变量配置1.4 新建JAVA_HOME1.5 修改Path变量1.6 新建classpath1.7 验证环境是否配置完成 2.开发工具二选一1.如何创建一个工程2.工程的目录结构的了解3.与开发的相关的常规视图4.我…

记录WiFi转WDS桥接再转网线

第一步&#xff1a; 把LAN口修改为 和 主路由器的前三位段位编码一致&#xff0c;最后一位设置大于250&#xff0c;减少抢IP的可能性。这个步骤是修改 桥接路由器的登录IP 第二部&#xff1a; 设置IP池。网关和dns服务器都是同一个&#xff0c;用手机连接主路由器wifi可以找到 …

【Flink】Flink 的八种分区策略(源码解读)

Flink 的八种分区策略&#xff08;源码解读&#xff09; 1.继承关系图1.1 接口&#xff1a;ChannelSelector1.2 抽象类&#xff1a;StreamPartitioner1.3 继承关系图 2.分区策略2.1 GlobalPartitioner2.2 ShufflePartitioner2.3 BroadcastPartitioner2.4 RebalancePartitioner2…

HTML 学习笔记(五)超链接

HYperText 超文是用超链接的方式&#xff0c;将不同空间的文字信息组合在一起的网状文其就像一个桥梁&#xff0c;建立了不同页面中的联系&#xff0c;实现了访问不同网站中页面的功能 <!DOCTYPE html> <html lang"en"><head><meta charset&qu…

深度学习+感知机

深度学习感知机 1感知机总结 2多层感知机1XOR2激活函数3多类分类总结 3代码实现 1感知机 是个很简单的模型,是个二分类的问题。 感知机&#xff08;perceptron&#xff09;是Frank Rosenblatt在1957年提出的一种人工神经网络&#xff0c;被视为一种最简单形式的前馈神经网络&…

【C语言】深入理解指针(进阶篇)

一、数组名的理解 数组名就是地址&#xff0c;而且是数组首元素的地址。 任务&#xff1a;运行以下代码&#xff0c;看数组名是否是地址。 #include <stdio.h> int main() {int arr[] { 1,2,3,4,5,6,7,8,9,0 };printf("&arr[0] %p\n", &arr[0]);pri…

[Java安全入门]三.CC1链

1.前言 Apache Commons Collections是一个扩展了Java标准库里的Collection结构的第三方基础库&#xff0c;它提供了很多强大的数据结构类型和实现了各种集合工具类。Commons Collections触发反序列化漏洞构造的链叫做cc链&#xff0c;构造方式多种&#xff0c;这里先学习cc1链…

Dubbo-记录

1.概念 Apache Dubbo 是一款 RPC 服务开发框架&#xff0c;用于解决微服务架构下的服务治理与通信问题&#xff0c;官方提供了 Java、Golang 等多语言 SDK 实现。使用 Dubbo 开发的微服务原生具备相互之间的远程地址发现与通信能力&#xff0c; 利用 Dubbo 提供的丰富服务治理…