Risc-V Simple Learning

Risc-V Simple Learning

原文链接:https://ovea-y.cn/risc_v_simple_learning/

诞生原因

  • x86指令集爆发性增长
  • 由于非商业,所以不会受到随意的更改
  • 没有历史包袱
    • 例如x86还保留着BCD数据格式的操作指令,占据了操作码空间的1.6%(4/256)
  • 模块化的ISA(核心是RV32I),可以根据自己的需求进行选择
    • x86由于是增量式的ISA,因此每次带有新指令的CPU必须也要实现旧指令。
  • 简介的ISA,相比其他RISC架构指令集,实现同一功能可以进行更少的指令执行

RV32/RV64的特权架构

机器模式(M)

机器模式是risc-v中的最高权限模式,具有对裸机的完整控制权,是所有RISC-V处理器必须实现的权限模式。

特性

  • 拦截
  • 异常处理
    • 同步异常(指令执行期间产生的,例如执行了不合规范的指令,或者访问了错误的内存地址等)
      • 访问错误异常 当物理内存地址不支持访问时(比如写入ROM)
      • 断点异常 在执行ebreak指令,或者地址或数据雨调试触发器匹配时发生
      • 环境调用异常 在执行ecall指令时发生
      • 非法指令异常 在译码阶段发现无效操作码时发生
      • 非对齐地址异常 在有效地址不能被访问大小整除时发生,例如地址为0x12的amoadd.w
    • 中断(与指令流异步的外部事件,比如鼠标移动等)

Pasted image 20240120234852

异常处理

八个控制状态寄存器(CSR)是机器模式下异常处理的必要部分

  • mtvec(Machine Trap Vector)它保存发生异常时处理器需要跳转到的地址。

  • mepc(Machine Exception PC)它指向发生异常的指令。

  • mcause(Machine Exception Cause)它指示发生异常的种类。

  • mie(Machine Interrupt Enable)它指出处理器目前能处理和必须忽略的中断。

  • mip(Machine Interrupt Pending)它列出目前正准备处理的中断。

  • mtval(Machine Trap Value)它保存了陷入(trap)的附加信息:地址例外中出错的地址、发生非法指令例外的指令本身,对于其他异常,它的值为 0。

  • mscratch(Machine Scratch)它暂时存放一个字大小的数据。

  • mstatus(Machine Status)它保存全局中断使能,以及许多其他的状态

    Pasted image 20240120234902

监管者模式(S)

用户模式(U)

原文链接:https://ovea-y.cn/risc_v_simple_learning/

Read more

香港银行开户指南

香港银行开户指南

注意:本文所有内容,都是需要前往香港的情况下才能使用! 本文主要介绍2家实体银行和3家虚拟银行! 实体银行包含: * 中国银行(香港) * 汇丰银行(香港),该银行也被称为“香港上海汇丰银行” 虚拟银行包含: * 众安银行 * 天星银行 * 蚂蚁银行 1、各银行所需资料和办理方式 银行名称 办理方式 所需材料 & 要求 备注 汇丰银行(香港) 提前预约,线下到营业点办理 (如果没预约,只能很早排队取线下号,不一定能取到) 必备证件: 1. 港澳通行证 2. 入境海关小票 3. 身份证 投资证明: 1. 证券App近三月股票交割单 2. 中国结算近三月交割单 3. 银行近三月流水单 4. 支付宝投资流水 资产证明: 1. 银行资产证明 2.

By 夕元
C++协程(Coroutines)

C++协程(Coroutines)

原文链接:https://ovea-y.cn/cpp_coroutine_20/ C++协程(Coroutines) 1. 简单介绍协程 协程可以简单的理解为,它是一个可以随时“中断”,并再次恢复执行的函数。 C++协程框架的特点: * 无栈协程 * 非对称设计(开发者可以自行设计协程调度器,做成对称设计) 2. 协程和函数的区别 函数:函数调用是线性、同步、一次性的执行模式,调用者必须等待被调用方法执行完成后返回。 协程:协程可以异步执行,调用者不需要等待协程完成,可以在协程挂起时继续做其他事情。在执行过程中通过特定的语法(co__yield_和_co__await)暂停执行,并在之后的某个时刻恢复执行。 2.1 普通函数的执行过程 一个普通函数在执行的时候,主要包含两个操作,分别是调用(call)和返回(return)

By 夕元
GitHub Workflows

GitHub Workflows

原文链接:https://ovea-y.cn/github_workflows/ 本文介绍GitHub工作流的创建和作用。 工作流创建方式 在git项目下,创建.github/workflows文件夹,里面编写的任何yml文件都是工作流的一部分。 secrets的创建方式 secrets.GITHUB_TOKEN是GitHub自动创建的,不需要自己创建。 secrets.SERVER_HOST这个的来源,需要在GitHub对应的项目的设置中设置。 readme的构建标签 配置好Branch、Event类型后,把下面这段内容复制到markdown文档里,就会自动显示自动化流程状态了。其实就是一张图片,由GitHub自动生成提供。 一. 自动构建网站并推送到远程服务器 自动构建hugo,并更新远程服务器的静态网站内容。 自动化流程文件 name: Deploy Hugo Site # 当推送到main分支时触发部署流程 on: push: branches: - main

By 夕元
代码版本管理工具(git/gerrit/repo)

代码版本管理工具(git/gerrit/repo)

原文链接:https://ovea-y.cn/code_version_control_tools__git_gerrit_repo/ 一、版本控制工具的历史 1.1 版本控制雏形 在版本控制软件出现之前,就具备diff与patch工具来对源码进行比较和打补丁了,在CVS出来的一段时间里,Linus一直在使用diff与patch工具管理着Linux的代码。diff与patch也是源码版本控制中最基本的概念。 1.1.1 diff —— 用于比较两个文件或目录之间的差异 -u 表示使用 unified 格式 -r 表示比较目录 -N 表示将不存在的文件当作空文件处理,这样新添加的文件也会出现在patch文件中 diff -urN a.c b.c > c.patch 1.1.2 patch —— 用于应用差异修改 通过patch可以将原始文件变成目标文件,

By 夕元