# SimpleKernel
**Repository Path**: its-come-github/SimpleKernel
## Basic Information
- **Project Name**: SimpleKernel
- **Description**: No description available
- **Primary Language**: Unknown
- **License**: MIT
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 1
- **Created**: 2022-06-08
- **Last Updated**: 2024-06-14
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README




[](https://github.com/996icu/996.ICU/blob/master/LICENSE)
[](https://996.icu)
[English](https://github.com/Simple-XX/SimpleKernel/blob/TODO/README_en.md) | [中文](https://github.com/Simple-XX/SimpleKernel/blob/TODO/README.md)
# SimpleKernel
## Key Words
- Kernel
- C/C++/AT&T ASM/cmake/shell
- Linux-like
- Multiboot2
## Abstract
SimpleKernel, a simple kernel for learning. Contains the basic functionality of an operating system
Kernels with different levels of completion are available, and you can start from where you like.
## Environment
- Ubuntu Linux
- brew
- x86_64-elf-binutils
- x86_64-elf-gcc
- xorriso
- grub
- bochs
- bochs-x
Tested on Ubuntu 20.04
- Arch Linux
- brew
- x86_64-elf-binutils
- x86_64-elf-gcc
- mtools
- xorriso
- grub
- bochs
Tested on Manjaro 5.6.15-1
- Mac
- brew
- x86_64-elf-binutils
- x86_64-elf-gcc
- xorriso
- grub
- bochs
Tested on macOS 10.15.7
## RUN
git clone https://github.com/Simple-XX/SimpleKernel.git
cd SimpleKernel/
bash ./run.sh
Screenshot

## Directory Structure
The whole project according to the functional modules delimited molecular directory, each subdirectory and then divided header file and source file directory, so that the architecture is clear and easy to understand.
### Directory Design
- Principle
The naming of the directory should accurately describe the basic function of the module, it is recommended to use lowercase letters and do not contain underline, dot and other special symbols;
Directories must be placed under the parent directory that they contain, and they need to be explicitly coupled to other directories.
### Dependencies
- Principle
New components are often dependent on existing components of the system, and the components that are directly dependent must be specified with minimal coupling.
### Header File
#### Naming
- Principle
Header file naming should accurately describe the contents of the module contained in the file to achieve the purpose of easy to understand.
## CMake
## Test
### CI
Each push will be tested using Github Action.
## Code Style
- git commit:
https://zhuanlan.zhihu.com/p/182553920
- code style
Specified by tools/clang-format
## Image Files
simplekernel.iso: multiboot2 boot
fs.img: file system, unuse
## TODO
- concurrent
- File system
- drive
## CONTRIBUTORS
[MRNIU](https://github.com/MRNIU)
[cy295957410](https://github.com/cy295957410)
[rakino](https://github.com/rakino)
[xiaoerlaigeid](https://github.com/xiaoerlaigeid)
## CONTRIBUTING
See CONTRIBUTING.md.
## Thanks
[osdev](https://wiki.osdev.org)
[GRUB 在 Mac 上的安装](https://wiki.osdev.org/GRUB#Installing_GRUB_2_on_OS_X)
[multiboot](https://www.gnu.org/software/grub/manual/multiboot/multiboot.html)
《程序员的自我修养--链接、装载与库》(俞甲子 石凡 潘爱民)
[JamesM's kernel development tutorials](http://www.jamesmolloy.co.uk/tutorial_html/1.-Environment%20setup.html)
[xOS](https://github.com/fengleicn/xOS)
[hurlex](http://wiki.0xffffff.org/posts/hurlex-8.html)
[howerj/os](https://github.com/howerj/os)
[cfenollosa/os-tutorial](https://github.com/cfenollosa/os-tutorial)
[omarrx024/xos](https://github.com/omarrx024/xos)
[PurpleBooth/project-title](https://gist.github.com/PurpleBooth/109311bb0361f32d87a2%23project-title)
[0xAX weblong](http://0xax.blogspot.com/search/label/asm)
[How-to-Make-a-Computer-Operating-System](https://github.com/SamyPesse/How-to-Make-a-Computer-Operating-System)
[coding-style](https://www.kernel.org/doc/Documentation/process/coding-style.rst)
[DNKernel](https://github.com/morimolymoly/DNKernel)
[c-algorithms](https://github.com/fragglet/c-algorithms)
[Linux内核中的中断栈与内核栈的补充说明](http://blog.chinaunix.net/uid-23769728-id-3077874.html)
[Linux进程管理 (1)进程的诞生](https://www.cnblogs.com/arnoldlu/p/8466928.html)
[SynestiaOS](https://github.com/SynestiaOS/SynestiaOS)
## Donors
- [digmouse233](https://github.com/digmouse233)
- l*e
- fslongjin
## Donate
Thank you!
(Please specify the GitHub id for joining the sponsor list
## CopyRight
MIT LICENCE