共2条
1/1 1 跳转至页
UART 高手请看初始化代码,为何不能同时使用两UART中断?
问
PINSEL0 = 0x00050005; // 设置I/O连接到UART0 UART1,
PINSEL1 = 0x00000000; //其他连接通用IO
uart0_set.datab = 8; // 8位数据位
uart0_set.stopb = 1; // 1位停止位
uart0_set.parity = 0; // 无奇偶校验
UART0_Ini(9600, uart0_set); // 初始化串口模式
UART1_Ini(9600,uart0_set);
U0FCR = 0x81; // 使能FIFO,并设置触发点为8字节
U0IER = 0x01; // 允许RBR中断,即接收中断
U1FCR = 0x81; // 使能FIFO,并设置触发点为8字节
U1IER = 0x01; // 允许RBR中断,即接收中断
/* 设置uart0中断允许 */
VICIntSelect = 0x00000000; // 设置所有通道为IRQ中断
VICVectCntl0 = 0x26; // UART0中断通道分配到IRQ slot 0,即优先级最高
VICVectAddr0 = (int)IRQ_UART0; // 设置UART0向量地址
/*-------UART1 中断允许-----------------------------*/
VICVectCntl2 = 0x27; // UART1中断通道分配到IRQ slot 1,
VICVectAddr1 = (int)IRQ_UART1; // 设置UART1向量地址
VICIntEnable = 0x000000c0; // 使能UART0\1中断bit7 bit6 =1
这样不管从PC机发送数据到那一个UART都不会产生中断。
但我把VICIntEnable = 0x000000c0;改为VICIntEnable =
0x00000040; // 使能UART0中断bit6=1
UART0中断产生并且正确,
把VICIntEnable = 0x000000c0;改为VICIntEnable =
0x00000080; // 使能UART1中断bit7=1
UART1中断产生并且正确,
但同时设置两个UART中断允许,为什么就都不能产生中断 呢?
答 1: 这两句有问题: VICVectCntl2 = 0x27; // UART1中断通道分配到IRQ slot 1,
VICVectAddr1 = (int)IRQ_UART1; // 设置UART1向量地址 答 2: 不好意思,是我写错了 VICVectCntl2 = 0x27;VICVectCntl2 = 0x27;应是VICVectCntl1 = 0x27
但是一样的问题。 答 3: 看不出其它问题,而且我们针对您的问题对所有实验板测试..没有发现您遇到的问题。
PINSEL0 = 0x00050005; // 设置I/O连接到UART0 UART1,
PINSEL1 = 0x00000000; //其他连接通用IO
uart0_set.datab = 8; // 8位数据位
uart0_set.stopb = 1; // 1位停止位
uart0_set.parity = 0; // 无奇偶校验
UART0_Ini(9600, uart0_set); // 初始化串口模式
UART1_Ini(9600,uart0_set);
U0FCR = 0x81; // 使能FIFO,并设置触发点为8字节
U0IER = 0x01; // 允许RBR中断,即接收中断
U1FCR = 0x81; // 使能FIFO,并设置触发点为8字节
U1IER = 0x01; // 允许RBR中断,即接收中断
/* 设置uart0中断允许 */
VICIntSelect = 0x00000000; // 设置所有通道为IRQ中断
VICVectCntl0 = 0x26; // UART0中断通道分配到IRQ slot 0,即优先级最高
VICVectAddr0 = (int)IRQ_UART0; // 设置UART0向量地址
/*-------UART1 中断允许-----------------------------*/
VICVectCntl2 = 0x27; // UART1中断通道分配到IRQ slot 1,
VICVectAddr1 = (int)IRQ_UART1; // 设置UART1向量地址
VICIntEnable = 0x000000c0; // 使能UART0\1中断bit7 bit6 =1
这样不管从PC机发送数据到那一个UART都不会产生中断。
但我把VICIntEnable = 0x000000c0;改为VICIntEnable =
0x00000040; // 使能UART0中断bit6=1
UART0中断产生并且正确,
把VICIntEnable = 0x000000c0;改为VICIntEnable =
0x00000080; // 使能UART1中断bit7=1
UART1中断产生并且正确,
但同时设置两个UART中断允许,为什么就都不能产生中断 呢?
答 1: 这两句有问题: VICVectCntl2 = 0x27; // UART1中断通道分配到IRQ slot 1,
VICVectAddr1 = (int)IRQ_UART1; // 设置UART1向量地址 答 2: 不好意思,是我写错了 VICVectCntl2 = 0x27;VICVectCntl2 = 0x27;应是VICVectCntl1 = 0x27
但是一样的问题。 答 3: 看不出其它问题,而且我们针对您的问题对所有实验板测试..没有发现您遇到的问题。
共2条
1/1 1 跳转至页
回复
| 有奖活动 | |
|---|---|
| 这个春节你犒赏自己什么了?分享你的故事,有奖征集 | |
| 2026年“我要开发板活动”第三季,开始了! | |
| 硬核工程师专属补给计划——填盲盒 | |
| “我踩过的那些坑”主题活动——第002期 | |
| 【EEPW电子工程师创研计划】技术变现通道已开启~ | |
| 发原创文章 【每月瓜分千元赏金 凭实力攒钱买好礼~】 | |
| 【EEPW在线】E起听工程师的声音! | |
| 高校联络员开始招募啦!有惊喜!! | |
我要赚赏金打赏帖 |
|
|---|---|
| 【S32K3XX】Standby RAM的初始化流程被打赏¥18元 | |
| Gravity:中英文语音合成模块V2.0及其串口控制被打赏¥24元 | |
| 全彩色度变化图的绘制被打赏¥27元 | |
| 【FreeRtos】FreeRtos任务栈的生长方向管理方式被打赏¥20元 | |
| 【瑞萨RA8D1 LVGL/LWIP评测】LVGL添加输入设备:EC11旋转编码器被打赏¥39元 | |
| 【瑞萨RA8D1 LVGL/LWIP评测】RA8D1部署FreeRTOS+LVGL被打赏¥33元 | |
| 空气质量检测器设计与实现被打赏¥24元 | |
| 【瑞萨RA8D1 LVGL/LWIP评测】LWIP进行UDP、TCP、HTTP、MQTT功能联合测试被打赏¥41元 | |
| 【瑞萨RA8D1 LVGL/LWIP评测】RA8D1部署FreeRTOS+LWIP被打赏¥36元 | |
| RTOS怎么选?让我来给你答案!被打赏¥15元 | |
我要赚赏金
