RSIC-V“一芯”学习笔记(一)——概述

考研的文章和资料之后想写的时候再写怕趴

文章目录

  • 一、阶段设计
  • 二、环境、开发语言和工具
  • 三、最重要的两个观念
  • 四、处理器芯片设计
  • 五、处理器芯片设计包含很多软件问题
  • 六、处理器芯片的评价指标
  • 七、复杂系统的构建和维护
  • 八、专业世界观
  • 九,提问的艺术(提问模板)
  • 十、考核情况

一、阶段设计

  1. B阶段:以RVE为主、将RT-Thread移植到AM、在给定的面积预算内优化处理器设计
  2. A阶段:从RVE转到RV64IMAC、最终运行Linux发行版
  3. 开源EDA
    在这里插入图片描述

二、环境、开发语言和工具

Linux环境:我准备直接用虚拟机了
软件:C语言、C++(少量)、gcc编译器。
(幸好之前苏嵌学过gcc、makefile等基础知识,底子打的好)
硬件开发:verilog 开源verilator仿真器+开源gtkwave波形查看器
(对于verilog,看了看之前学fpga的时候,倒是了解过一点,但是学的不是很深入)

硬件配置:笔记本电脑就行,无需FPGA
(当然自己设计的处理器放在上面跑也是可以的)
这里比较推荐的是ASIC

三、最重要的两个观念

1.硬件需要软件的支持才能发挥作用
狭义的处理器芯片设计: RTL开发
广义的处理器芯片设计:计算机系统软硬件协同设计

2.复杂系统是迭代演进的(多周期->流水线->超标量->乱序执行)
做事规律-从易到难,逐步推进
推荐阅读:《 系统设计黄金法则:简单之美》,包云岗
KISS法则- Keep It Simple, Stupid

四、处理器芯片设计

本质:实例化和连续
可以用面包板开发,但是逐渐转成RTL开发(效率高、更方便)

补充:RTL级和Verilog语言
RTL:寄存器传输级
Verilog可以从五个层次对电路(系统)进行描述,包括:系统级、算法级、寄存器传输级(即RTL级)、门级、开关级。我们平时用的最多的为RTL级,故Verilog代码也经常被称为RTL代码。
入门verilog文章–想学verilog的,可以看看这篇文章

五、处理器芯片设计包含很多软件问题

两个本质原因

  1. 处理器芯片和其他芯片不同,离开软件就无法工作.
  2. 代码即软件- RTL代码也是,即使它描述的是硬件
    需要使用合适的软件技术管理/维护/测试/评估/优化代码

软件怎么在处理器上运行?等等

六、处理器芯片的评价指标

  1. 正确性-最基本。运行100000000次后,是否也能正常运行?
  2. 软件支持–你设计的芯片只能运行排序程序,还是能启动Linux
  3. 微结构复杂度 - 单周期 复杂度 cache 分支预测
  4. PPA(性能(IPC主频)、功耗、面积)
  5. 可配置性
  6. 代码可读性、可维护性

七、复杂系统的构建和维护

  1. 了解全系统的每一处细节,为调bug有大方向
  2. 先完成后完美,体会每一项技术对系统带来的性能提升
  3. 构建正确的工具,提升开发速率
  4. 经验总结

八、专业世界观

  1. 代码要独立完成

在这里插入图片描述

九,提问的艺术(提问模板)

模板:
请回答以下问题:

  1. 你认为本问题是否属于能力训练的范畴?
  • 是, 我应该尽最大努力解决这个问题来得到训练
  • 否, 我要汇报讲义或框架代码中的问题, 或提供改进的建议
  • 其他, 请补充说明
  1. 这个问题是否可以通过自己动手试一试来了解答案? (例如类似"执行ls会发生什么"/“C语言中除0会发生什么”/“Cache是直接相联更好还是组相联更好”)
  • 是, 我试一试就可以知道答案
  • 否, 这个问题不属于此类别
  1. 是否已经阅读并理解相关的报错信息
  • 不适用, 这个问题没有报错信息
  1. 是否已经仔细阅读了讲义, 并确认讲义中没有提到相关信息
  • 不适用, 这个问题属于调试的训练, 需要我独立解决
  1. 是否可以通过重新编译解决问题?
  • 不适用, 这个问题和代码无关
  1. 是否已经尝试STFW?
  • 不适用, 这个问题和我的代码强相关, 无法在网上直接搜索到相关信息
  1. 是否已经尝试RTFM?

  • 不适用, 这个问题和手册无关
  1. 是否已经尝试RTFSC(包括Makefile等脚本和相关配置文件)?
  • 不适用, 这个问题和代码无关
  1. 这个问题是否可以稳定复现?
  1. 请列出你认为对解决问题有帮助的版本信息, 可以是系统/工具/代码等版本.

  2. 请详细描述复现这个问题的具体步骤(需要的时候附上截图).

  3. 请描述你期望看到的结果.

  4. 请阐述你尝试的过程和得到的结果, 并针对这些尝试结果进行分析, 给出自己的思考(需要的时候附上截图).

十、考核情况

在所提交的项目里面随机注入三个bug,
覆盖软件、硬件、环境
约45分钟找出bug

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

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

相关文章

pandas创建一个新的dataframe对象

import pandas as pd df pd.DataFrame() print(df)

ddos攻击会让服务器受到什么影响?-速盾网络(sudun)

DDoS攻击是一种网络攻击手段,它通过利用大量的请求或恶意流量超过服务器的处理能力,从而导致服务器无法正常工作或服务质量显著下降。 首先,DDoS攻击会对服务器的带宽造成极大的压力。攻击者会利用大量的机器或网络资源发起攻击,…

Ubuntu下使用Virtual Box中显示没有可用的USB设备

Ubuntu中使用Virtual Box,但是使用到USB时只有USB1.1可以使用,并且提示没有可以使用的USB设备,解决方法如下 下载并安装Vitrual Box提供的功能扩展包 分别点击帮助->关于,查看当前使用的版本进入到Virtual Box官网下载链接根…

MATLAB中untrace函数用法

目录 语法 说明 untrace函数的功能是在仿真调试会话中移除跟踪点。 语法 untrace blk 说明 untrace blk 从当前仿真调试会话的跟踪点列表中移除块 blk 的跟踪点。每当在仿真调试会话中执行块时,软件会显示与跟踪点对应的块的信息。 当以编程方式启动仿真调试会…

vue前端开发自学练习,Props数据传递-类型校验,默认值的设置!

vue前端开发自学练习,Props数据传递-类型校验,默认值的设置! 实际上,vue开发框架的时候,充分考虑到了前端开发人员可能会遇到的各种各样的情况,比如大家经常遇到的,数据类型的校验,再比如,默认…

Spring之整合Mybatis底层源码

文章目录 一、整体核心思路1 . 简介2. 整合思路 二、源码分析1. 环境准备2. 源码分析 一、整体核心思路 1 . 简介 有很多框架需要与Spring进行整合,而整合的核心思路就是把其他框架所产生的对象放到Spring容器中,让其成为一个bean。比如Mybatis&#x…

在Colab上测试Mamba

我们在前面的文章介绍了研究人员推出了一种挑战Transformer的新架构Mamba 他们的研究表明,Mamba是一种状态空间模型(SSM),在不同的模式(如语言、音频和时间序列)中表现出卓越的性能。为了说明这一点,研究人员使用Mamba-3B模型进行了语言建模…

Oladance、南卡、Cleer开放式耳机怎么样?全方位测评大PK!

​开放式耳机作为新兴的音频设备领域中备受欢迎的选择,但市场上琳琅满目的产品汇集了质量千差万别的耳机,其中存在着一些粗制滥造的产品。身为一位音频设备测评博主,我经常收到有关哪个品牌的开放式耳机质量好的疑问。面对市面上众多选择&…

MFC结合GDI+

MFC结合GDI 创建一个空的MFC界面,在确定按钮函数里进行画图: 1、包含头文件与库 在stdafx.h中加入以下三行代码: #include "gdiplus.h" using namespace Gdiplus; #pragma comment(lib, "gdiplus.lib")2、安装GDI 在…

常州ipad签约 电子签约 战略签约 启动签约

ipad电子签约、签约上墙、多人签约、电子签约、签约仪式、签约软件、签军令状、签字上屏、屏幕签字等,并且本公司ipad签约可以实现 甲方对应N个乙方签约系统对多人:是指只有一个甲方,多个第三方。甲方只要签名一次就可以自动帖加指定的位置 …

基于Flask的高并发部署方案

在AI部署方案中,Flask是最常用的方案!本文列举几种最常用基于Flask的部署方案。 Flask方案 简介 Flask 是一个轻量级的 Python Web 框架,它非常适合构建小型到中型的应用程序。下面是对 Flask 的详细解释和简单示例: Flask 的特点: 轻量级:相比于 Django,Flask 更轻…

uni-app做A-Z排序通讯录、索引列表

上图是效果图,三个问题 访问电话通讯录,拿数据拿到用户的联系人数组对象,之后根据A-Z排序根据字母索引快速搜索 首先说数据怎么拿 - 社区有指导https://ask.dcloud.net.cn/question/64117 uniapp 调取通讯录 // #ifdef APP-PLUSplus.contac…

安谋科技“周易”NPU与飞桨完成II级兼容性测试,助力实现多样化AI部署

近日,安谋科技(中国)有限公司(以下简称“安谋科技”)“周易”NPU系列IP与飞桨已完成II级兼容性测试,测试结果显示,双方兼容性表现良好,整体运行稳定。这是安谋科技加入“硬件生态共创…

个人装机记录

配置单: CPU:13900K 主板:z790-a 吹雪 D5 显卡:华硕 tuf 4090 固态:三星990 pro 2TB 2 内存:金士顿 fury d5 6000频 32G2 散热:龙神三代360 电源:tuf 1200W 机箱:tuf 502…

【Node.js学习 day3——http模块】

创建HTTP服务端 //1.导入http模块 const http require(http);//2.创建服务对象 const server http.createServer((request, response) > {response.end(Hello HTTP Server);//设置响应体 });//3.监听端口,启动服务 server.listen(9000,()>{console.log(服务…

IMS中如何区分initial INVITE和re-INVITE?

这里就要先看下Dialog的定义。 dialog是两个UA之间持续一段时间的点对点 SIP关系。dialog通过SIP消息建立,例如对 INVITE request的 2xx response。dialog由Call-ID、local tag和remote tag来区分,也就是Call-ID 、from-tag和to-tag就可以确定一个dialog…

java锁的分类

锁定义和特征 乐观锁 VS 悲观锁 区别 乐观锁不会添加锁,无锁算法,没有线程被阻塞。悲观锁拿到资源就加锁,线程被阻塞。 乐观锁:CAS算法 Compare-And-Swap(比较并交换)的缩写,轻量级锁。 Java中&#xff…

力扣(leetcode)第551题学生出勤记录I(Python)

551.学生出勤记录I 题目链接:551.学生出勤记录I 给你一个字符串 s 表示一个学生的出勤记录,其中的每个字符用来标记当天的出勤情况(缺勤、迟到、到场)。记录中只含下面三种字符: ‘A’:Absent&#xff0…

数字档案安全与高效管理的先锋——亚信安慧AntDB数据库

档案工作在维护历史真实面貌、保障人民利益方面具有至关重要的作用。随着社会的发展,数字化转型成为档案管理领域的不可逆趋势。数字档案的存储和传输已经成为档案工作的重要组成部分,然而,这也伴随着一系列的挑战,其中安全风险是…

【MATLAB】逐次变分模态分解SVMD信号分解算法

有意向获取代码,请转文末观看代码获取方式~ 1 基本定义 逐次变分模态分解(Sequential Variational Mode Decomposition,简称SVMD)是一种用于信号处理和数据分析的方法。它可以将复杂的信号分解为一系列模态函数,每个…