共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 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
vscode+cmake搭建雅特力AT32L021开发环境被打赏30分 | |
【换取逻辑分析仪】自制底板并驱动ArduinoNanoRP2040ConnectLCD扩展板被打赏47分 | |
【分享评测,赢取加热台】RISC-V GCC 内嵌汇编使用被打赏38分 | |
【换取逻辑分析仪】-基于ADI单片机MAX78000的简易MP3音乐播放器被打赏48分 | |
我想要一部加热台+树莓派PICO驱动AHT10被打赏38分 | |
【换取逻辑分析仪】-硬件SPI驱动OLED屏幕被打赏36分 | |
换逻辑分析仪+上下拉与多路选择器被打赏29分 | |
Let'sdo第3期任务合集被打赏50分 | |
换逻辑分析仪+Verilog三态门被打赏27分 | |
换逻辑分析仪+Verilog多输出门被打赏24分 |