共2条
1/1 1 跳转至页
问
我在调试时发现,若同时设置两个中断(UART0 分配为SLOT0 和 TIMER0 分配为 SLOT1)则不能产生中断,见程序示例。
而将UART或TIMER0分别配置为SLOT0,关闭SLOT1 则中断正常,不知是否需要修改LPC2200模板设置,如何修改。
void __irq IRQ_Timer0(void)
{
TCounter --;
if (TCounter ==0)
{
FL_overtime = 0x5A;
}
T0IR = 0x01;
VICVectAddr = 0x00;
}
void __irq IRQ_UART0(void)
{
if( 0x04==(U0IIR&0x0F)) //若有接收到数据
{
Receive = U0RBR; //取接收到的数据==〉recv_data
}
VICVectAddr = 0x00; // 中断处理结束
}
void initial(void)
{
UARTMODE uart0_set;
uart0_set.datab = 8; // 8位数据位
uart0_set.stopb = 1; // 1位停止位
uart0_set.parity = 0; // 无奇偶校验
UART0_Ini(115200, uart0_set); // 初始化串口模式
U0FCR = 0x01; // 使能FIFO,并设置触发点为1字节
U0IER = 0x01; // 允许RBR中断,即接收中断
T0PR = 0;
T0MCR = 0x03;
T0MR0 = Fpclk/1000; //1ms定时中断
T0TCR = 0x01;
/* 设置中断允许 */
VICIntSelect = 0x00000000; // 设置所有通道为IRQ中断
VICVectCntl0 = 0x26; // UART0中断通道分配到IRQ slot 0,即优先级最高
VICVectAddr0 = (int)IRQ_UART0; // 设置UART0向量地址
VICVectCntl1 = 0x24; // Timer0中断通道分配到IRQ slot1.
VICVectAddr1 = (uint32)IRQ_Timer0; // 设置Timer0向量地址
VICIntEnable = 0x00000060; // 使能UART0、Timer0中断
}
int main (void)
{
uint8 temp;
uint32 uid,uid1;
/*
uint8 err=0;
volatile uint16 *ADR;
volatile uint16 *ip;
*/
uint16 temp1;
PINSEL0 = 0x00050055; // 定义TXD0、RXD0、SCL、SDA、TXD1、RXD1,其余为通用IO
PINSEL1 = 0x000002A9; //设置EINT0、SCK1、MISO1、MOSI1、SSEL1、其它为GPIO
IO0DIR = P0_IOCON; //设置I/O口输入/输出方向
initial();
while(1)
{
// 等待中断
}
} 答 1: 找到错误啦
我把控制位搞错了,应该是:
VICIntEnable = 0x00000050; // 使能UART0、Timer0中断
测试后,中断都正常了。
而将UART或TIMER0分别配置为SLOT0,关闭SLOT1 则中断正常,不知是否需要修改LPC2200模板设置,如何修改。
void __irq IRQ_Timer0(void)
{
TCounter --;
if (TCounter ==0)
{
FL_overtime = 0x5A;
}
T0IR = 0x01;
VICVectAddr = 0x00;
}
void __irq IRQ_UART0(void)
{
if( 0x04==(U0IIR&0x0F)) //若有接收到数据
{
Receive = U0RBR; //取接收到的数据==〉recv_data
}
VICVectAddr = 0x00; // 中断处理结束
}
void initial(void)
{
UARTMODE uart0_set;
uart0_set.datab = 8; // 8位数据位
uart0_set.stopb = 1; // 1位停止位
uart0_set.parity = 0; // 无奇偶校验
UART0_Ini(115200, uart0_set); // 初始化串口模式
U0FCR = 0x01; // 使能FIFO,并设置触发点为1字节
U0IER = 0x01; // 允许RBR中断,即接收中断
T0PR = 0;
T0MCR = 0x03;
T0MR0 = Fpclk/1000; //1ms定时中断
T0TCR = 0x01;
/* 设置中断允许 */
VICIntSelect = 0x00000000; // 设置所有通道为IRQ中断
VICVectCntl0 = 0x26; // UART0中断通道分配到IRQ slot 0,即优先级最高
VICVectAddr0 = (int)IRQ_UART0; // 设置UART0向量地址
VICVectCntl1 = 0x24; // Timer0中断通道分配到IRQ slot1.
VICVectAddr1 = (uint32)IRQ_Timer0; // 设置Timer0向量地址
VICIntEnable = 0x00000060; // 使能UART0、Timer0中断
}
int main (void)
{
uint8 temp;
uint32 uid,uid1;
/*
uint8 err=0;
volatile uint16 *ADR;
volatile uint16 *ip;
*/
uint16 temp1;
PINSEL0 = 0x00050055; // 定义TXD0、RXD0、SCL、SDA、TXD1、RXD1,其余为通用IO
PINSEL1 = 0x000002A9; //设置EINT0、SCK1、MISO1、MOSI1、SSEL1、其它为GPIO
IO0DIR = P0_IOCON; //设置I/O口输入/输出方向
initial();
while(1)
{
// 等待中断
}
} 答 1: 找到错误啦
我把控制位搞错了,应该是:
VICIntEnable = 0x00000050; // 使能UART0、Timer0中断
测试后,中断都正常了。
共2条
1/1 1 跳转至页
回复
有奖活动 | |
---|---|
【有奖活动】分享技术经验,兑换京东卡 | |
话不多说,快进群! | |
请大声喊出:我要开发板! | |
【有奖活动】EEPW网站征稿正在进行时,欢迎踊跃投稿啦 | |
奖!发布技术笔记,技术评测贴换取您心仪的礼品 | |
打赏了!打赏了!打赏了! |
打赏帖 | |
---|---|
与电子爱好者谈读图四被打赏50分 | |
与电子爱好者谈读图二被打赏50分 | |
【FRDM-MCXN947评测】Core1适配运行FreeRtos被打赏50分 | |
【FRDM-MCXN947评测】双核调试被打赏50分 | |
【CPKCORRA8D1B评测】---移植CoreMark被打赏50分 | |
【CPKCORRA8D1B评测】---打开硬件定时器被打赏50分 | |
【FRDM-MCXA156评测】4、CAN loopback模式测试被打赏50分 | |
【CPKcorRA8D1评测】--搭建初始环境被打赏50分 | |
【FRDM-MCXA156评测】3、使用FlexIO模拟UART被打赏50分 | |
【FRDM-MCXA156评测】2、rt-thread MCXA156 BSP制作被打赏50分 |