本文来源电子发烧友社区,作者:少年阿炳, 帖子地址: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浏览量
1369 -
CSM32RV20
+关注
关注
0文章
40浏览量
459
发布评论请先 登录
相关推荐
热点推荐
EASY EAI Nano-TB(RV1126B)开发板试用】1、初识
非常感谢电子发烧友以及灵眸科技给了我这次试用EASY EAI Nano-TB(RV1126B)开发板的机会,星期四确认了我的试用机会,星期五就收到了
发表于 11-16 11:15
关于RV-STAR开发板插上USB,电脑为什么会显示识别到两个串口呢?
刚买来时还是只显示识别到一个串口,最近莫名奇妙,我们几个同学都是这个问题,插上RV-STAR开发板,设备管理器显示两个串口?
发表于 11-10 06:31
基于FPGA开发板TSP的串口通信设计
本文详细介绍基于Terasic FPGA开发板TSP(又名C5P和OSK)和其板载CP2102N USB-UART桥接芯片的串口通信系统设计与实现。系统采用Verilog HDL编写UART收发控制器,通过CP2102N实现FPGA与PC间的快速稳定通信。
【作品合集】中科昊芯Core_DSC280025C开发板测评
的应用
【中科昊芯Core_DSC280025C开发板试用体验】---外部中断问题
第一期合集: 微五科技CF5010RBT60开发板测评作
发表于 09-18 10:52
有奖丨米尔 瑞芯微RK3506开发板免费试用
米尔与瑞芯微合作发布的新品基于瑞芯微RK3506应用处理器的MYD-YR3506开发板免费试用名额来啦~~米尔提供了3块价值299元的MYD-YR3506
有奖丨米尔 瑞芯微YR3562开发板免费试用
米尔与瑞芯微合作发布的新品基于瑞芯微RK3562应用处理器的MYD-YR3562开发板免费试用活动来啦~~米尔提供了3块价值599元的MYD-YR3562
瑞芯微平台Android系统串口测试方法,触觉智能RK3562开发板演示
瑞芯微方案主板Android系统串口测试方法,通用RK3568、RK3566、RK3588、RK3576等。触觉智能RK3562开发板演示

【南京中科微CSM32RV20开发板试用体验】串口的使用心得+使用串口点灯
评论