k210 cpu、asm、rust、smpboot、ipi
介绍
k210的datasheet主要讲了与外设相关的内容,k210并不支持最新的完整的riscv指令集,而是实现了一部分。本文想要通过汇编来一点点摸索k210的寄存器,布局,mmu,缓存等结构
相关链接:https://github.com/rcore-os/rCore-Tutorial/issues/80#issuecomment-663055705
riscv指令模块
在包云岗老师翻译的riscv reader 手册 的指令集参考手册中
第二章介绍了RV32I的寄存器和6中指令类型
类型简介:https://blog.csdn.net/m0_46450829/article/details/105201216
第五章介绍了RV32F和RV32D的寄存器(浮点寄存器)和相关指令
k210架构
实际上k210使用的是rocket core:https://canaan-creative.com/716.html
riscv 裸机编程:https://blog.csdn.net/u010451780/article/details/120830800
什么是设备树:https://rcore-os.github.io/rCore-Tutorial-deploy/docs/lab-5/guide/part-1.html
IA-32体系结构下的多核启动
参考《linux源码情景分析》,首先由引导处理器进行自身的初始化,特别是内存的初始化之后,再调用smp_init()进行smp结构的初始化(创建一个带有主线程的进程),然后利用apic给另外一个核以信号,并设置其初始运行地址,等待启动
gdb 调试方法
常用gdb命令 https://blog.csdn.net/houzijushi/article/details/79901344
gdb线程调试命令 https://blog.csdn.net/nyist327/article/details/42969677
100个gdb调试小技巧 https://wizardforcel.gitbooks.io/100-gdb-tips/content/print-threads.html
jtag调试
riscv 汇编
gnu 伪指令 https://blog.csdn.net/qq_41596356/article/details/121539963
一个assembly教程 https://github.com/riscv-non-isa/riscv-asm-manual/blob/master/riscv-asm.md
找的很多教程和arm这个汇编很像,所以一并记录下来
arm 汇编手册 http://www.rowleydownload.co.uk/arm/documentation/gnu/as/index.html#Top
很详细的汇编教程 (arm)https://blog.csdn.net/liuzq/article/details/83615085
riscv 特权级二进制接口规范
英文原版:https://github.com/riscv-non-isa/riscv-sbi-doc/blob/master/riscv-sbi.adoc
洛佳大佬翻译版本:https://zh.m.wikisource.org/wiki/Translation:特权层二进制接口规范标准
rust 内联汇编
某位同学的博客
https://xiaopengli89.github.io/posts/rust-asm-macro/
参考手册详细教程(英文)
https://doc.rust-lang.org/stable/reference/inline-assembly.html
riscv 汇编调用规范
https://inst.eecs.berkeley.edu/~cs61c/resources/RISCV_Calling_Convention.pdf
其他相关资料
aiot中riscv芯片的相关报告:https://www.hexiaoqing.net/wp-content/uploads/2016/05/AIoT技术挑战与RISC-V-处理器机遇-202007.pdf
一个老哥的博客,关于riscv的,介绍了riscv芯片的数据通路 https://suda-morris.github.io/blog/cs/risc-v.html
微内核相关资料
微内核科普(鸿蒙) https://blog.csdn.net/icolakele/article/details/100110384
微内核相关概念 https://blog.csdn.net/drsonxu/article/details/80922826
SOSP名人堂 https://posts.careerengine.us/author/5f0e1622daae0f4acf222cb1/posts?from=authorDetailSidePanel
操作系统实现目标:

qemu文档网址 https://www.qemu.org/docs/master/
linux中riscv 体系结构下的代码:https://github.com/riscvarchive/riscv-linux/tree/18c83d2c0390fd0e8336ad090a047c56037d19f5/arch/riscv/kernel
从零开始学os https://learningos.github.io/rcore_step_by_step_webdoc/
k210 cpu、asm、rust、smpboot、ipi的更多相关文章
- [转载] 深入了解Java ClassLoader、Bytecode 、ASM、cglib
转载自http://www.iteye.com/topic/98178 一.Java ClassLoader 1,什么是ClassLoader 与 C 或 C++ 编写的程序不同,Java 程序并 ...
- 转:WebGL、Asm.js和WebAssembly概念简介
WebGL.Asm.js和WebAssembly概念简介 转:http://www.techbrood.com/zh/news/webgl/webgl%E3%80%81asm_js%E5%92%8Cw ...
- 为什么CPU缓存会分为一级缓存L1、L2、L3?有什么意义?
https://baijiahao.baidu.com/s?id=1598811284058671259&wfr=spider&for=pc 简介:CPU缓存是CPU一个重要的组成部分 ...
- 【番外篇】Rust环境搭建+基础开发入门+Rust与.NET6、C++的基础运算性能比较
前言:突然想打算把Rust作为将来自己主要的副编程语言.当然,主语言还是C#,毕竟.NET平台这么强大,写起来就是爽.缘起:之前打算一些新的产品或者新的要开发的东西,由于没有历史包袱,就想重新选型一下 ...
- java的反射机制和javassist、asm
1.java的反射机制,可以帮助我们在运行的时候获取我们引用的java类相关的信息,包括类的名字.所包含的方法名字.方法参数等等 2.javassit这个jar包,大概看了下,更厉害,它可以直接操作字 ...
- 【优化】COUNT(1)、COUNT(*)、COUNT(常量)、COUNT(主键)、COUNT(ROWID)、COUNT(非空列)、COUNT(允许为空列)、COUNT(DISTINCT 列名)
[优化]COUNT(1).COUNT(*).COUNT(常量).COUNT(主键).COUNT(ROWID).COUNT(非空列).COUNT(允许为空列).COUNT(DISTINCT 列名) 1. ...
- Java虚拟机6:内存溢出和内存泄露、并行和并发、Minor GC和Full GC、Client模式和Server模式的区别
前言 之前的文章尤其是讲解GC的时候提到了很多的概念,比如内存溢出和内存泄露.并行与并发.Client模式和Server模式.Minor GC和Full GC,本文详细讲解下这些概念的区别. 内存溢出 ...
- Windows网络驱动、NDIS驱动(微端口驱动、中间层驱动、协议驱动)、TDI驱动(网络传输层过滤)、WFP(Windows Filtering Platform)
catalog . 引言 . Windows 2000网络结构和OSI模型 . NDIS驱动 . NDIS微端口驱动编程实例 . NDIS中间层驱动编程实例 . NDIS协议层驱动编程实例 . TDI ...
- tomcat的maxThreads、acceptCount(最大线程数、最大排队数)
转载:http://blog.sina.com.cn/s/blog_605f5b4f01012ljj.html tomcat 的Connector配置如下 <Connector port=&qu ...
- java gc的工作原理、如何优化GC的性能、如何和GC进行有效的交互
java gc的工作原理.如何优化GC的性能.如何和GC进行有效的交互 一个优秀的Java 程序员必须了解GC 的工作原理.如何优化GC的性能.如何和GC进行有效的交互,因为有一些应用程序对性能要求较 ...
随机推荐
- .NET7 一个实用功能-中央包管理
依赖管理是 NuGet 的核心功能.Nuget管理单个项目的依赖关系很容易.管理多项目解决方案的依赖关系可能会变得很困难,因为它们的规模和复杂性开始扩大. 在您管理许多不同项目的公共依赖项的情况下,您 ...
- 记一次HTTPClient模拟登录获取Cookie的开发历程
记一次HTTPClient模拟登录获取Cookie的开发历程 环境: springboot : 2.7 jdk: 1.8 httpClient : 4.5.13 设计方案 通过新建一个 ...
- springboot集成支付宝的支付(easy版)
SpringBoot对接支付宝 需要先注册账号 到支付宝开发者平台创建网页支付应用 启用公钥模式 需要使用到appId和下面的两个秘钥 写配置信息的代码 1.引入依赖 <dependency&g ...
- hwlog----types.go
// Copyright(C) 2021. Huawei Technologies Co.,Ltd. All rights reserved.// Package hwlog provides the ...
- 编译器优化丨Cache优化
摘要:本文重点介绍几种通过优化Cache使用提高程序性能的方法. 本文分享自华为云社区<编译器优化那些事儿(7):Cache优化>,作者:毕昇小助手. 引言 软件开发人员往往期望计算机硬件 ...
- 【大数据面试】【框架】Hive:架构、计算引擎、比较、内外部表、by、函数、优化、数据倾斜、动静态分区
一.组成 1.架构 源数据原本是存在dubby数据库,存在MySQL可以支持多个客户端 客户端.数据存储(HDFS).MR计算引擎 2.计算引擎的选择 MR引擎:基于磁盘,计算时间长,但一定能算出结果 ...
- IE浏览器卸载
1.打开此电脑,点击上箭头,打开控制面板: 2.选择卸载程序: 3.点击启用或关闭Windows功能: 4.弹出Windows功能对话框,找到Inetrnet Explorer 11,取消勾选: 5. ...
- SQL语句查询优化方法
建立索引并命中索引,在查询的时候,要尽量让数据库引擎使用索引.加入explain执行计划 1.尽量避免使用select * 2.尽量避免使用!= 3.尽量避免使用or 优化方式:可以用union代替o ...
- vue elementui弹框内 富文本编辑器的使用,及踩坑
最近vue项目中遇到弹框内使用富文本编辑器,遇到最大的问题是,在打开弹框后才能创建富文本编辑器,并且只能创建一次,多次点击弹框,报错: Error in v-on handler: "Err ...
- Blazor组件自做十四 : Blazor FileViewer 文件预览 组件
Blazor FileViewer 文件预览 组件 目前支支持 Excel(.docx) 和 Word(.xlsx) 格式 示例: https://www.blazor.zone/fileViewer ...