当前位置: 首页 > news >正文

【Create my OS】从零编写一个操作系统

前言

相信每个自学操作系统的同学,大致学习路线都离不开 HIT-OS、MIT-6.S081、MIT-6.824、MIT-6.828等经典的公开课。但学习完这些经典公开课并完成相应的Lab,很多同学脑海中对于操作系统的知识其实都是零散的,让你从头开始编写一个操作系统,我相信大部分人还是无从下手。因为Lab只是修改相应的核心模块,对于整体系统的组织、模块间的处理等细节,往往没有人去关注,也就是说我们还需要进一步把这些概念串起来、巩固起来。那么,我相信大部分人都有过一个想法:“我能不能自己写一个操作系统”,这可能是大部分操作系统开发人员的梦想吧。

因此!本项目将展示如何从零开始使用 ANSI C 编写出一个基于 64 位 RISC-V 架构的操作系统——Jokerix,该系统支持在内核上运行用户态(User/Application mode)的终端,并输入命令执行其他程序。

源码公开:Joker001014/Jokerix (github.com)


目录

0 前置知识 【Create my OS】0 前置知识 | JokerDebug (joker001014.github.io)

    0.1 RISC-V硬件机制0.2 RISC-V 汇编0.3 SBI 规范0.4 GDB 调试0.5 Jokerix 体系结构0.6 实验环境

1 最小内核 【Create my OS】1 最小内核 | JokerDebug (joker001014.github.io)

    1.1 内核入口点1.2 生成内核镜像1.3 使用 QEMU 运行1.4 封装 SBI接口

2 开启中断 【Create my OS】2 开启中断 | JokerDebug (joker001014.github.io)

    2.1 RISC-V 中断机制2.2 触发断点2.3 中断上下文2.4 开启时钟中断

3 内存管理 【Create my OS】3 内存管理 | JokerDebug (joker001014.github.io)

    3.1 Buddy System3.2 动态内存分配3.3 内存按页分配框架3.4 基于线段树的页帧分配

4 虚拟内存 【Create my OS】4 虚拟内存 | JokerDebug (joker001014.github.io)

    4.1 Sv39内核映射4.2 实现页表4.3 内核重映射

5 内核线程 【Create my OS】5 内核线程 | JokerDebug (joker001014.github.io)

    5.1 线程切换5.2 构造线程结构5.3 从启动线程到新线程

6 线程调度 【Create my OS】6 线程调度 | JokerDebug (joker001014.github.io)

    6.1 线程管理6.2 调度线程6.3 Round-Robin 调度算法6.4 调度测试

7 用户线程 【Create my OS】7 用户线程 | JokerDebug (joker001014.github.io)

    7.1 创建用户程序7.2 实现系统调用7.3 进程内存空间7.4 创建用户进程

8 文件系统 【Create my OS】8 文件系统 | JokerDebug (joker001014.github.io)

    8.1 SimpleFS8.2 打包镜像8.3 内核文件驱动8.4 文件系统测试

9 实现终端 【Create my OS】9 实现终端 | JokerDebug (joker001014.github.io)

    9.1 键盘中断9.2 条件变量与输入缓冲9.3 echo 程序9.4 实现终端

编写代码文件时间线:

步骤功能文件(斜体表示二次修改)
1CPU自检,跳转到Bootloader/
2将内核代码从磁盘加载到内存(Bootloader),由OpenSBI提供:把 CPU 从 M-Mode 切换到 S-Mode,并跳转到一个固定的地址 0x80200000/
3编写内核入口点:设置OS启动栈,跳转到main.c执行kernel/entry.S
kernel/main.c
4entry.Smain.c 编译和链接生成ELF文件(需存放在0x80200000),进一步生成二进制镜像文件Makefile
kernel/kernel.ld
5QEMU加载镜像文件,至此成功运行操作系统。/
6封装SBI接口ecall;调用SBI接口实现 printf 功能kernel/sbi.h
kernel/printf.c
7封装CSR读写;初始化中断处理程序入口,设置断点中断处理程序kernel/riscv.h
kernel/interrupt.c
8保存和恢复中断上下文信息kernel/context.h
kernel/interrupt.S
9初始化开启时钟中断,设置时钟中断处理程序kernel/timer.c
kernel/interrupt.c
10基于二叉树的动态内存分配,采用Buddy System Allocation算法kernel/heap.c
kernel/consts.h
11基于线段树的页帧分配kernel/memory.c
12设置页表,将内核运行在虚拟地址空间kernel/kernel.ld
kernel/entry.S
13实现三级页表,将内核各个段映射到页表上kernel/mapping.c
14借助中断恢复机制创建内核线程,及线程上下文切换kernel/thread.c
kernel/switch.S
kernel/context.h
15线程管理框架,创建调度线程kernel/processor.c
kernel/thread.c
16实现Round-Robin线程调度算法kernele/rrscheduler.c
17实现系统调用user/syscall.h
18实现用户态printf、动态内存分配、用户程序入口点、用户测试函数user/io.c
user/malloc.c
user/entry.c
user/ulib.h
user/hello.c
19编译用户程序并链接,将用户程序合并到内核user/Makefile
user/linkUser.asm
20处理用户态系统调用kernel/interrupt.c
kernel/syscall.c
21编译的用户程序为ELF文件,实现ELF文件加载和内存映射kernel/elf.c
kernel/mapping.c
22创建用户线程结构(创建用户栈、创建内核栈、创建上下文)kernel/thread.c
kernel/mapping.c
23打包生成文件系统镜像fs.img,将文件系统内容合并到内核mkfs/mksfs.c
mkfs/simplefs.h
kernel/linkFS.asm
Makefile
24从文件系统中找到 Inode,加载 ELF 文件数据到字节数组中kernel/fs.c
kernel/main.c
kernel/thread.c
25处理键盘中断,实现条件变量,维护等待线程队列kernel/queue.c
kernel/condition.c
kernel/interrupt.c
kernel/mapping.c
kerne/processor.c
26标准输入缓冲区,维护缓存内容和条件变量kernel/stdin.c

相关文章:

  • mesh转solid freecad
  • docker compose的变量使用说明
  • Spring常见面试题
  • PCB比对--CAM Brd文件比对
  • 中文分词总结:历程、问题、发展
  • 【笔记】Blockchain
  • 黑龙江亿林网络启盛裸金属服务器评测:24 核 32G + 联通千兆共享,高负载业务的新利器
  • 68元开启智能硬件新纪元——明远智睿SSD2351开发板引领创新浪潮
  • Guava 在大数据计算场景下的使用指南
  • mysql_mcp_server quickstart
  • sqlserver 计算周岁年龄的函数
  • 【web应用】若依框架:若依框架中的面包屑导航与顶部导航栏:设计与实现
  • 前端面试七之列表渲染和组件重用
  • 新书速览|CUDA并行编程与性能优化
  • Transformer、RNN (循环神经网络) 和 CNN (卷积神经网络)的区别
  • 消除品类洞察:头部稳固,新玩家如何创新突围手游市场?
  • Lavazza拉瓦萨再度牵手兰博基尼汽车 百年咖啡注入超跑速度
  • 算法导论第二章:递归与分治的数学艺术
  • 行为模式-命令模式
  • 【Zephyr 系列 21】OTA 升级与产测系统集成:远程配置、版本验证、自动回滚机制设计
  • 可以做哪些网站有哪些内容/免费b2b信息发布网站
  • 影视传媒公司网站模板/seo在线优化技术
  • 顺天亿建设网站/谷歌搜索入口365
  • 网站一年多少钱?/深圳关键词推广优化
  • 021新手学做网站/如何在各大网站发布信息
  • 网站建设价格如何/sem推广竞价托管公司