4
0
mirror of https://github.com/RT-Thread/rt-thread.git synced 2025-01-25 15:47:25 +08:00
rt-thread-official/bsp/renesas/docs/Introduction_to_RA_Series_Drives.md
Sherman 1c64c9ef08
[bsp/renesas/docs/] Add English documents (#5985)
* [bsp/renesas/docs/] Add English documents
2022-05-25 10:02:42 +08:00

5.1 KiB

Introduction to RA Series Drives

In the RT-Thread real-time operating system, a wide variety of device drivers are managed through a set of I/O device management frameworks. The device management framework provides a set of standard device operation APIs for upper-level applications, and developers can efficiently interact with the underlying hardware peripherals by calling these standard device operation APIs. The structure of the Device Management Framework is shown in the following figure:

image-20220308143402996

Developing applications using the I/O Device Management Framework has the following advantages:

  • Develop applications using the same standard set of APIs to make applications more portable
  • Upgrades and modifications to the underlying drivers do not affect the upper-level code
  • Drivers and applications are independent of each other, making it easy for multiple developers to work together

1. Introduction to drive classification

This section introduces the different class-driven concepts provided by BSPs, and for a BSP, there are three types of drivers:

  • Onboard Peripheral Drivers: Refers to peripherals on the development board outside of the MCU, such as TF cards, Ethernet, etc
  • On-chip Peripheral Drivers: Refers to peripherals on the MCU chip, such as hardware timers, ADCs, and watchdogs
  • Board extended module Drivers: Refers to modules of a development board that can be connected via an expansion interface or a DuPont wire, such as an RW007 module

A schematic diagram of these three peripherals is shown below:

Peripheral

2. How to use peripheral drivers

The driver libraries currently provided by RT-Thread already support multiple series of BSPs for RA. Click on the driver name in the table below to jump to the introductory document for the corresponding driver framework. Developers can read the materials to learn how to use these peripheral drivers through the device driver framework in application development.

2.1 On-chip peripherals

Driver Introduction
GPIO Operate the GPIO pins
UART Send and receive data through serial ports
I2C Send and receive data via software I2C
SPI Send and receive data over SPI
ADC Measure the analog data on the pin
SDIO Read and write data through SDIO
TIMER Use hardware timers to implement the function of measuring time and timing execution callback functions
PWM Outputs a PWM waveform at a specific pin
RTC Set and read times
WDT Watchdog driver
QSPI Send and receive data via SPI (1, 2, 4-wire).

2.2 On-board peripherals

Driver Introduction
I2C On-board I2C sensor
SDIO SD (TF) card for SPI interface or SDIO interface

2.3 Extensions

Driver Introduction
RW007 WIFI module with SPI interface
HS300x Temperature and humidity sensor with I2C interface
ZMOD4410 Indoor air quality sensor with I2C interface

2.4 Driver sample code

In RT-Thread's examples\test directory, there is sample code provided by RT-Thread based on different peripheral drivers. You can quickly test the drivers provided in BSP by turning on the drivers to be tested in the env tool and adding the corresponding driver framework test files from examples\test to the project.

This tutorial translated by Josh Zou