本文來源電子發燒友社區,作者:少年阿炳, 帖子地址:https://bbs.elecfans.com/jishu_2241429_1_1.html
環境搭建:
搭建環境可以參考官方手冊,也可參考下面別人寫的博客,整個環境搭建過程比較簡單,容易上手。
官方教程:可以參考CSM Studio 軟件中,在菜單欄點擊 幫助->CSM Studio,獲得新手手冊一本。
參考博客:https://bbs.elecfans.com/jishu_2237353_1_1.html
新建項目:
在"幫助->CSM Studio"中的手冊有詳細介紹。
新建的項目有很多功能的參考用法,建議多多閱讀。
注意:新建的demo是一個點燈demo,但是因為io口不同,所以參考電路圖修改一下io口初始化和while循環內的代碼,修改后才能正常亮燈。
下面進入正文:
1. 按鍵控制 Led燈
按鍵對應的IO口初始化需要分兩步
將IO口設置為輸入模式,在將IO口設置為上拉或者下拉。
復制代碼
之后通過按鍵掃描判斷高低電平,控制LED燈亮滅即可。
詳細代碼請看附件。
2.串口的使用
參考資料:
從uart.h中可以指導串口收發分為:中斷和非中斷兩種
2.1 非中斷方式串口的初始化以及收發數據
復制代碼
上面三行代碼依次功能為串口初始化,接收數據,發送數據
注意:void Uart_Reveive(UART_TypeDef *UARTx,uint8_t *packet,uint16_t lenth)
該函數每次需要固定接收到lenth個字節的數據才能結束,不然就會一直等待。
2.2中斷方式串口的初始化以及收發數據
復制代碼
串口的初始化已經對應的io初始化全部由UART_Init_IT_case1函數完成。
值得注意的是一定要在中斷開啟時,先清除一下中斷,不然開機后會自動進一次中斷,根據用戶手冊所得,我們需要將UART的CTRL 寄存器的0位置1.
之后就只需要在uart.c文件中修改void UART1_IRQhandler(void)中的內容 即可。
原先的void UART1_IRQhandler(void)已經有現成的功能可以使用。
我的void UART1_IRQhandler(void)函數根據需要做了修改。
復制代碼
復制代碼
詳細內容請參考附件。
附件內容包括:按鍵控制led亮滅,非中斷串口接發,中斷串口控制led
項目源代碼詳見作者原文地址
環境搭建:
搭建環境可以參考官方手冊,也可參考下面別人寫的博客,整個環境搭建過程比較簡單,容易上手。
官方教程:可以參考CSM Studio 軟件中,在菜單欄點擊 幫助->CSM Studio,獲得新手手冊一本。
參考博客:https://bbs.elecfans.com/jishu_2237353_1_1.html
新建項目:
在"幫助->CSM Studio"中的手冊有詳細介紹。
新建的項目有很多功能的參考用法,建議多多閱讀。
注意:新建的demo是一個點燈demo,但是因為io口不同,所以參考電路圖修改一下io口初始化和while循環內的代碼,修改后才能正常亮燈。
下面進入正文:
1. 按鍵控制 Led燈
按鍵對應的IO口初始化需要分兩步
將IO口設置為輸入模式,在將IO口設置為上拉或者下拉。
- GPIO_PULL_Init(GPIOA,PIN0,GPIO_PULLUP); //GPIO 上拉
- GPIO_MODE_Init(GPIOA,PIN0,GPIO_MODE_INPUT); //GPIO 模式
之后通過按鍵掃描判斷高低電平,控制LED燈亮滅即可。
詳細代碼請看附件。
2.串口的使用
參考資料:
- “Sources->Drivers->src內的uart.c文件”
- “Head->Drivers->Inc內的uart.h文件”
- CSM32RV20 用戶手冊
從uart.h中可以指導串口收發分為:中斷和非中斷兩種
2.1 非中斷方式串口的初始化以及收發數據
- //串口一初始化
- UART_Init_case1(UART1);//非中斷模式
- Uart_Reveive(UART1,uartReceive,10);
- Uart_Send(UART1,uartReceive,10);//適用于非中斷發送模式
上面三行代碼依次功能為串口初始化,接收數據,發送數據
注意:void Uart_Reveive(UART_TypeDef *UARTx,uint8_t *packet,uint16_t lenth)
該函數每次需要固定接收到lenth個字節的數據才能結束,不然就會一直等待。
2.2中斷方式串口的初始化以及收發數據
- UART_Init_IT_case1(UART1);//中斷模式
- Interrupt_Enable(UART1_int_ID);//CLIC使能單個中斷
- UART1->CTRL |= 0x00000001U;//清除中斷標志位,防止開機先進一次中斷
- SYS_Interrupt_Enable();//CLIC開總中斷
串口的初始化已經對應的io初始化全部由UART_Init_IT_case1函數完成。
值得注意的是一定要在中斷開啟時,先清除一下中斷,不然開機后會自動進一次中斷,根據用戶手冊所得,我們需要將UART的CTRL 寄存器的0位置1.
之后就只需要在uart.c文件中修改void UART1_IRQhandler(void)中的內容 即可。
原先的void UART1_IRQhandler(void)已經有現成的功能可以使用。
我的void UART1_IRQhandler(void)函數根據需要做了修改。
- void UART1_IRQhandler(void)
- {
- if((UART1->CTRL&0x00000001)==1)//接收到數據
- {
- //buff[l_len++]=UART1->DATA;
- if(uart_dev.frameok==0) //接收未完成
- {
- uart_dev.rxbuf[uart_dev.rxlen++]=UART1->DATA;
- UART1_RX_CNT=uart_dev.rxlen;
- if(uart_dev.rxlen>RECV_LEN-1)
- {
- uart_dev.rxlen=0;
- }
- }
- UART1->CTRL |= 0x00000001U;
- }
- }
- #include "headfile.h"
- void mp_receive_data(uint8_t *buf, uint16_t *len)
- {
- uint8_t rxlen = UART1_RX_CNT;
- uint16_t i = 0;
- *len = 0; //默認為0
- Delay32M_ms(10); //等待40ms,連續超過10ms沒有接收到一個數據,則認為接收結束
- if (rxlen == UART1_RX_CNT && rxlen) //接收到了數據,且接收完成了
- {
- for (i = 0; i < rxlen; i++)
- {
- buf[i] = uart_dev.rxbuf[i];
- }
- *len = UART1_RX_CNT; //記錄本次數據長度
- UART1_RX_CNT = 0; //清零
- uart_dev.frameok=1; //標記完成一幀數據接收
- // getData=0;//數據接收完成,標志位清零
- }
- }
- uint8_t ReceiveBuff[RECV_LEN];
- int main(void)
- {
- uint16_t rlen=0;
- uart_dev.rxlen=0;
- ///----System Init ---------------------------------------------------------------------------------------------
- CLIC_Init();//系統中斷配置
- System_Clock_Init();//系統時鐘初始化
- ///----Chapter 5 GPIO Test Init ---------------------------------------------------------------------------------
- GPIO_MODE_Init(GPIOA,PIN8,GPIO_MODE_OUTPUT); //GPIO 模式
- for(uint8_t i=0;i<10;i++)
- {
- GPIO_Toggle(GPIOA,PIN8); //GPIO 翻轉
- Delay32M_ms(100);
- }
- UART_Init_IT_case1(UART1);//中斷模式
- Interrupt_Enable(UART1_int_ID);//CLIC使能單個中斷
- UART1->CTRL |= 0x00000001U;//清除中斷標志位,防止開機先進一次中斷
- SYS_Interrupt_Enable();//CLIC開總中斷
- ee_printf("請輸入:on 或者off (開燈/關燈)rn");
- while(1)
- {
- mp_receive_data(ReceiveBuff, &rlen);
- if(uart_dev.frameok==1)//如果接收到數據
- {
- ee_printf("收到數據:");
- Uart_Send(UART1,(uint8_t *)ReceiveBuff,rlen);
- ee_printf("收到數據:rn");
- if((ReceiveBuff[0]=='o')&&(ReceiveBuff[1]=='n'))
- {
- GPIO_Write(GPIOA,PIN8,GPIO_RESET);
- ee_printf("燈開了!rn");
- }
- else if((ReceiveBuff[0]=='o')&&(ReceiveBuff[1]=='f')&&(ReceiveBuff[2]=='f'))
- {
- GPIO_Write(GPIOA,PIN8,GPIO_SET);
- ee_printf("關燈了!rn");
- }
- else
- {
- ee_printf("請輸入:on 或者off (開燈/關燈)rn");
- }
- uart_dev.frameok=0;
- uart_dev.rxlen=0;
- }
- }
- return 0;
- }
詳細內容請參考附件。
附件內容包括:按鍵控制led亮滅,非中斷串口接發,中斷串口控制led



項目源代碼詳見作者原文地址
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
南京中科微
+關注
關注
0文章
60瀏覽量
995 -
CSM32RV20
+關注
關注
0文章
40瀏覽量
299
發布評論請先 登錄
相關推薦
熱點推薦
有獎丨米爾 瑞芯微YR3562開發板免費試用
米爾與瑞芯微合作發布的新品基于瑞芯微RK3562應用處理器的MYD-YR3562開發板免費試用活動來啦~~米爾提供了3塊價值599元的MYD-YR3562

迅為RK3568開發板篇Openharmony配置HDF控制UART-開發板串口簡介
。
在開發板背面的 20pin 座子上有一組 TTL 電平串口——串口 9。
在接下來的實驗中,我們將配置三路串口——
發表于 02-17 10:48
瑞芯微平臺Android系統串口測試方法,觸覺智能RK3562開發板演示
瑞芯微方案主板Android系統串口測試方法,通用RK3568、RK3566、RK3588、RK3576等。觸覺智能RK3562開發板演示

基于Arduino的串口通信項目
基于Arduino的串口通信項目涉及多個方面,包括硬件連接、軟件編程、串口參數配置等。 一、硬件準備 Arduino開發板 :確保你有一塊Arduino開發板,如Arduino Uno
追加名額丨米爾瑞芯微RK3576開發板有獎試用
米爾與瑞芯微合作發布的新品基于瑞芯微RK3576應用處理器的MYD-LR3576開發板免費試用活動加碼啦~~米爾追加了2塊價值849元的MYD-LR3576

常用在工業控制系統上的MCU芯片資料:CSM32RV20
CSM32RV20是一款基于RISC-V核的低功耗MCU芯片。 內置RISC-V RV32IMAC內核(2.6CoreMark/MHz); 蕞高32MHz工作頻率; 內置4kB的SRAM; 內置8B

有獎丨米爾 瑞芯微RK3576開發板免費試用
米爾與瑞芯微合作發布的新品基于瑞芯微RK3576應用處理器的MYD-LR3576開發板免費試用活動來啦~~米爾提供了7塊價值849元的MYD-LR3576

全志A133開發板安卓系統調試串口復用成普通串口方法-觸覺智能EVB1309
本文介紹了在開發板/主板串口接口不夠的情況下,可將調試串口改為普通串口使用。基于觸覺智能的全志A133開發板(型號EVB1309)演示,該主

【RA-Eco-RA0E1-32PIN-V1.0開發板試用】點燈
RA0E1開發板試用報告
試用單位 : 個人開發板 : RA0E1
一、背景
很榮幸獲得由電子發燒友舉辦的RA0E1開發板
發表于 09-24 11:54
【作品合集】龍芯2K0300蜂鳥開發板試用精選
試用】龍芯2K0300蜂鳥開發板上GPIO的驅動及使用 【龍芯2K0300蜂鳥板試用】初了解龍芯2K0300蜂鳥板
作者:@cooldog1
發表于 09-10 18:17
【龍芯2K0300蜂鳥板試用】+龍芯2K0300蜂鳥開發板快速上手
開發板的串口輸出,點擊啟動按鈕,打印輸出:
接上屏幕,同時也可以看到啟動logo
啟動完成后進入一下界面,移植循環到這個界面
5.Python點燈
默認開發的系統以及集成了Pyth
發表于 08-04 14:19
評論