README.md

    RT-Thread

    English | 简体中文 |

    GitHub GitHub release Build Status Gitter GitHub pull-requests PRs Welcome

    Introduction

    RT-Thread was born in 2006, it is an open source, neutral, and community-based real-time operating system (RTOS).

    RT-Thread is mainly written in C language, easy to understand and easy to port(can be quickly port to a wide range of mainstream MCUs and module chips). It applies object-oriented programming methods to real-time system design, making the code elegant, structured, modular, and very tailorable.

    RT-Thread has Standard version and Nano version. For resource-constrained microcontroller (MCU) systems, the NANO kernel version that requires only 3KB Flash and 1.2KB RAM memory resources can be tailored with easy-to-use tools; And for resource-rich IoT devices, RT-Thread can use the on-line software package management tool, together with system configuration tools, to achieve intuitive and rapid modular cutting, seamlessly import rich software packages, thus achieving complex functions like Android's graphical interface and touch sliding effects, smart voice interaction effects, and so on.

    RT-Thread Architecture

    RT-Thread has not only a real-time kernel, but also rich components. Its architecture is as follows:

    architecture

    It includes:

    • Kernel layer: RT-Thread kernel, the core part of RT-Thread, includes the implementation of objects in the kernel system, such as multi-threading and its scheduling, semaphore, mailbox, message queue, memory management, timer, etc.; libcpu/BSP (Chip Migration Related Files/Board Support Package) is closely related to hardware and consists of peripheral drivers and CPU porting.

    • Components and Service Layer: Components are based on upper-level software on top of the RT-Thread kernel, such as virtual file systems, FinSH command-line interfaces, network frameworks, device frameworks, and more. Its modular design allows for high internal cohesion inside the components and low coupling between components.

    • RT-Thread software package: A general-purpose software component running on the RT-Thread IoT operating system platform for different application areas, consisting of description information, source code or library files. RT-Thread provides an open package platform with officially available or developer-supplied packages that provide developers with a choice of reusable packages that are an important part of the RT-Thread ecosystem. The package ecosystem is critical to the choice of an operating system because these packages are highly reusable and modular, making it easy for application developers to build the system they want in the shortest amount of time. RT-Thread supports more than 370 software packages.

    RT-Thread Features

    • Designed for resource-constrained devices, the minimum kernel requires only 1.2KB of RAM and 3 KB of Flash.

    • Has rich components and a prosperous and fast growing package ecosystem.

    • Elegant code style, easy to use, read and master.

    • High Scalability. RT-Thread has high-quality scalable software architecture, loose coupling, modularity, is easy to tailor and expand.

    • Supports high-performance applications.

    • Supports cross-platform and a wide range of chips.

    Code Catalogue

    RT-Thread source code catalog is shown as follow:

    Name Description
    BSP Board Support Package based on the porting of various development boards
    components Components, such as finsh shell, file system, protocol stack etc.
    documentation Related documents, like coding style, doxygen etc.
    examples Related sample code
    include Head files of RT-Thread kernel
    libcpu CPU porting code such as ARM/MIPS/RISC-V etc.
    src The source files for the RT-Thread kernel.
    tools The script files for the RT-Thread command build tool.

    RT-Thread has now been ported for nearly 200 development boards, most BSPs support MDK, IAR development environment and GCC compiler, and have provided default MDK and IAR project, which allows users to add their own application code directly based on the project. Each BSP has a similar directory structure, and most BSPs provide a README.md file, which is a markdown-format file that contains the basic introduction of BSP, and introduces how to simply start using BSP.

    Resources

    Supported Architectures

    RT-Thread supports many architectures, and has covered the major architectures in current applications. Architecture and chip manufacturer involved:

    • ARM Cortex-M0/M0+:manufacturers like ST
    • ARM Cortex-M3:manufacturers like ST、Winner Micro、MindMotion, ect.
    • ARM Cortex-M4:manufacturers like ST、Nuvton、NXP、GigaDevice、Realtek、Ambiq Micro, ect.
    • ARM Cortex-M7:manufacturers like ST、NXP
    • ARM Cortex-M23:manufacturers like GigaDevice
    • ARM Cortex-R4
    • ARM Cortex-A8/A9:manufacturers like NXP
    • ARM7:manufacturers like Samsung
    • ARM9:manufacturers like Allwinner、Xilinx 、GOKE
    • ARM11:manufacturers like Fullhan
    • MIPS32:manufacturers like loongson、Ingenic
    • RISC-V:manufacturers like Hifive、Kendryte、Nuclei
    • ARC:manufacturers like SYNOPSYS
    • DSP:manufacturers like TI
    • C-Sky
    • x86

    Supported IDE and Compiler

    The main IDE/compilers supported by RT-Thread are:

    • RT-Thread Studio IDE
    • MDK KEIL
    • IAR
    • GCC

    RT-Thread Studio IDE

    User Manual | Tutorial Videos

    RT-Thread Studio IDE (a.k.a. RT-Studio) is a one-stop intergrated development environment built by RT-Thread team. It has a easy-to-use graphical configuration system and a wealth of software packages and components resources. RT-Studio has the features of project creation, configuration and management,as well as code editing, SDK management, build configuration, debugging configuration, program download and debug. We're looking to make the use of RT-Studio as intuitive as possible, reducing the duplication of work and improving the development efficiency.

    studio

    Env Tool

    Env Manual

    In the early stage, RT-Thread team also created an auxiliary tool called Env. It is an auxiliary tool with a TUI (Text-based user interface). Developers can use Env tool to configure and generate the GCC, Keil MDK, and IAR projects.

    env

    Getting Started

    RT-Thread Programming Guide | RT-Thread Studio IDE | Kernel Sample | RT-Thread Beginners Guide

    Based on the STM32F103 BluePill

    Simulator

    RT-Thread BSP can be compiled directly and downloaded to the corresponding development board for use. In addition, RT-Thread also provides qemu-vexpress-a9 BSP, which can be used without hardware platform. See the getting started guide below for details.

    License

    RT-Thread is an open source software and has been licensed under Apache License Version 2.0 since v3.1.1. License information and copyright information can generally be seen at the beginning of the code:

    /* Copyright (c) 2006-2018, RT-Thread Development Team
     *
     * SPDX-License-Identifier: Apache-2.0
     * ...
     */

    Community

    RT-Thread is very grateful for the support from all community developers, and if you have any ideas, suggestions or questions in the process of using RT-Thread, RT-Thread can be reached by the following means, and we are also updating RT-Thread in real time on these channels. At the same time, any questions can be asked in the issue section of RT-Thread repository or RT-Thread forum, and community members will answer them.

    Website | Github | Twitter | LinkedIn | Youtube | Facebook | Medium

    Contribution

    If you are interested in RT-Thread and want to join in the development of RT-Thread and become a code contributor,please refer to the Code Contribution Guide.

    项目简介

    当前项目暂无项目简介

    发行版本

    当前项目没有发行版本

    贡献者 214

    全部贡献者

    开发语言

    • C 96.8 %
    • Assembly 2.1 %
    • HTML 0.5 %
    • Python 0.3 %
    • C++ 0.1 %