日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > 嵌入式 > 嵌入式云IOT技術圈
[導讀]一、RT-Thread簡單介紹 大部分MCU工程師或多或少都接觸過實時OS,如今實時操作系統(tǒng)種類繁多,有Ucos,F(xiàn)reertos,liteOS,TinyOS,RT-Thread等等各種實時OS,這么多的實時OS,我們該如何去選擇學習呢?其中最有代表性的莫過于RT-Thread。 為什么說它具有代表性

一、RT-Thread簡單介紹

大部分MCU工程師或多或少都接觸過實時OS,如今實時操作系統(tǒng)種類繁多,有Ucos,F(xiàn)reertos,liteOS,TinyOS,RT-Thread等等各種實時OS,這么多的實時OS,我們該如何去選擇學習呢?其中最有代表性的莫過于RT-Thread。

為什么說它具有代表性?因為做過Linux開發(fā)的小伙伴學習了RT-Thread以后,普遍覺得RT-Thread在編寫代碼的套路和Linux大部分是非常相似的,甚至業(yè)界都有很多人說如果想進階Linux,RT-Thread不可不學。

為什么要學習RT-Thread? 

1、開源、免費。

2、資料、教程非常完善。

3、豐富的組件以及軟件包,組件化開發(fā),簡化項目流程,讓開發(fā)者更專注于應用業(yè)務

二、RT-Thread串口實戰(zhàn)

最近這段時間上手了下RTT,那真叫一個香啊,具體的使用請參考RTT官方文檔:

https://www.rt-thread.org/document/site/programming-manual/device/uart/uart/#

首先用RT-Thread Studio創(chuàng)建一個RTT項目:

選擇基于芯片還是基于BSP,這里我選擇的是基于芯片,用STM32F103C8T6這個板子來跑:

接下來開始配置組件:

雙擊以后會彈出圖形界面配置選項:

這里我配置了ulog日志、串口、Pin以及finsh命令,接下來開始熟悉串口設備配置和使用的步驟:

1、配置串口

(1)在board.h中配置串口

//我的傳感器接在USART2上,所以需要定義該宏。
#define BSP_USING_UART2

(2)配置串口2對應的GPIO以及TX、RX對應的引腳

#define UART2_TX_PORT       GPIOA
#define UART2_RX_PORT GPIOA
#define UART2_TX_PIN GPIO_PIN_2
#define UART2_RX_PIN GPIO_PIN_3

2、在主函數中開始調用串口組件相關的函數使用串口

定義串口句柄以及配置句柄

/*接收成功標志位*/
uint8_t rk_ok_flag = 0;
static rt_device_t serial;
#define SAMPLE_UART_NAME "uart2"
struct serial_configure config = RT_SERIAL_CONFIG_DEFAULT; /* 初始化配置參數 */

對應的RT_SERIAL_CONFIG_DEFAULT是默認的串口參數,如下:
/* Default config for serial_configure structure */
#define RT_SERIAL_CONFIG_DEFAULT \
{ \
BAUD_RATE_115200, /* 115200 bits/s */ \
DATA_BITS_8, /* 8 databits */ \
STOP_BITS_1, /* 1 stopbit */ \
PARITY_NONE, /* No parity */ \
BIT_ORDER_LSB, /* LSB first sent */ \
NRZ_NORMAL, /* Normal mode */ \
RT_SERIAL_RB_BUFSZ, /* Buffer size */ \
0 \
}

如果需要調整波特率或者串口的其它參數,則需重新修改對應的配置參數即可。

(1)查找串口設備

serial = rt_device_find(SAMPLE_UART_NAME);
if (!serial)
{
rt_kprintf("find %s failed!\n", SAMPLE_UART_NAME);
return RT_ERROR;
}

(2)修改串口參數 由于我使用的傳感器波特率是9600,其它參數默認,則只需修改波特率即可

config.baud_rate = BAUD_RATE_9600;        //修改波特率為 9600
//config.data_bits = DATA_BITS_8; //數據位 8
//config.stop_bits = STOP_BITS_1; //停止位 1
//config.bufsz = 128; //修改緩沖區(qū) buff size 為 128
//config.parity = PARITY_NONE; //無奇偶校驗位
/*修改后通過調用設備控制接口將串口參數寫入*/
rt_device_control(serial, RT_DEVICE_CTRL_CONFIG, &config);

(3)打開串口設備(這里我選用的是中斷接收)

rt_device_open(serial, RT_DEVICE_FLAG_INT_RX | RT_DEVICE_FLAG_STREAM);

//上面的參數對應以下含義:
//#define RT_DEVICE_FLAG_INT_RX 0x100 /**< INT mode on Rx */
//#define RT_DEVICE_FLAG_DMA_RX 0x200 /**< DMA mode on Rx */
//#define RT_DEVICE_FLAG_INT_TX 0x400 /**< INT mode on Tx */
//#define RT_DEVICE_FLAG_DMA_TX 0x800 /**< DMA mode on Tx */
//#define RT_DEVICE_FLAG_STREAM 0x040 /**< stream mode */

(4)設置串口中斷接收回調函數

rt_device_set_rx_indicate(serial, uart_recv_callback);
//這里uart_recv_callback即是串口的中斷回調函數,當接收到數據時會觸發(fā)回調函數。
//需要用戶自己去實現(xiàn)。

回調函數實現(xiàn)如下:

/* 接收數據回調函數 */
static rt_err_t uart_recv_callback(rt_device_t dev, rt_size_t size)
{
/*接收到串口數據,將接收標志置1*/
rk_ok_flag = 1;
return RT_EOK;
}

(5)接收數據(這里我沒有按官方的教程使用線程的方式去接收,而是直接在主函數中接收)

由于我的傳感器數據格式如下:

序號 信號值 報警值\r\n

所以這里我需要做一下接收處理的判斷,判斷接收數據的默認是否為\r\n這兩個字符, 如果是,則認為就是我的一行數據。

char ch;
int i = 0;
static int count = 1;
char buf[25] = { 0 };
while (1)
{
if (1 == rk_ok_flag && 0 == rt_device_read(serial, -1, &ch, 1))
{
rk_ok_flag = 0;
buf[i++] = ch;
if (buf[i - 2] == '\r' && buf[i - 1] == '\n')
{
count++;
rt_pin_write(LED0_PIN, count % 2);
i = 0;
rt_kprintf("傳感器數據:%s\n", buf);
memset(buf, 0, 25);
}
}
}

3、整體源碼實現(xiàn)

/*
* Copyright (c) 2006-2019, RT-Thread Development Team
*
* SPDX-License-Identifier: Apache-2.0
*
* Change Logs:
* Date Author Notes
* 2019-09-09 RT-Thread first version
*/

#include <rtthread.h>
#include <board.h>
#include <rtdevice.h>

#include <string.h>

#define DBG_TAG "main"
#define DBG_LVL DBG_LOG
#include <rtdbg.h>

/* PLEASE DEFINE the LED0 pin for your board, such as: PA5 */
#define LED0_PIN GET_PIN(C, 13)

uint8_t rk_ok_flag = 0;
static rt_device_t serial;
#define SAMPLE_UART_NAME "uart2"
struct serial_configure config = RT_SERIAL_CONFIG_DEFAULT; /* 初始化配置參數 */


/* 接收數據回調函數 */
static rt_err_t uart_recv_callback(rt_device_t dev, rt_size_t size)
{
rk_ok_flag = 1;
return RT_EOK;
}

int main(void)
{
char ch;
int i = 0;
static int count = 1;
char buf[25] = { 0 };
/* set LED0 pin mode to output */
rt_pin_mode(LED0_PIN, PIN_MODE_OUTPUT);
//1、查看串口設備
serial = rt_device_find(SAMPLE_UART_NAME);
if (!serial)
{
rt_kprintf("find %s failed!\n", SAMPLE_UART_NAME);
return RT_ERROR;
}
/* step2:修改串口配置參數 */
config.baud_rate = BAUD_RATE_9600; //修改波特率為 9600
/* step3:控制串口設備。通過控制接口傳入命令控制字,與控制參數 */
if(RT_EOK != rt_device_control(serial, RT_DEVICE_CTRL_CONFIG, &config))
{
rt_kprintf("配置串口設備失敗\n");
return RT_ERROR;
}
rt_kprintf("配置串口設備成功!\n");
/* step4:以中斷接收及輪詢發(fā)送模式打開串口設備 */
if(RT_EOK != rt_device_open(serial, RT_DEVICE_FLAG_INT_RX))
{
rt_kprintf("打開串口設備失敗!\n");
return RT_ERROR;
}
rt_kprintf("打開串口設備成功!\n");
/* step5:設置接收回調函數 */
rt_device_set_rx_indicate(serial, uart_recv_callback);
/* step6:數據處理及展示 */
while (1)
{
if (1 == rk_ok_flag && 0 == rt_device_read(serial, -1, &ch, 1))
{
rk_ok_flag = 0;
buf[i++] = ch;
if (buf[i - 2] == '\r' && buf[i - 1] == '\n')
{
i = 0;
count++;
/*調試燈翻轉*/
rt_pin_write(LED0_PIN, count % 2);
rt_kprintf("傳感器數據:%s\n", buf);
memset(buf, 0, 25);
}
}
}
return RT_EOK;
}

接下來對編寫好的源代碼進行編譯:

4、執(zhí)行結果

通過RT-Thread Studio自帶的串口調試助手可以看到打印消息:

整體編寫不到100行,RTT的組件確實做得很牛逼!不愧國產的驕傲!后面根據實際項目的使用情況,可能會使用DMA或者其它的方式來讀取,甚至可能結合線程、信號量來使用,期待分享!

往期精彩

C語言字符串的另類用法

以過來人經驗分享學習與工作

別瞎找了,你要的C語言經典示例都在這~

開源按鍵組件MultiButton支持菜單操作(事件驅動型)

若覺得本次分享的文章對您有幫助,隨手點[在看]并轉發(fā)分享,也是對我的支持。

免責聲明:本文內容由21ic獲得授權后發(fā)布,版權歸原作者所有,本平臺僅提供信息存儲服務。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除( 郵箱:macysun@21ic.com )。
換一批
延伸閱讀
關閉