共2条
1/1 1 跳转至页
UART1 请问周公我的UART1怎么进不了中断??
问
管脚是这样设置的PINSEL0|=0x00050005;/* 选择管脚为UART0 ,UART1*/
串口0可以正常进入中断,为什么串口1不能??我用的是LPC2132
void Uart1_Init(uint32 bps)
{
uint16 Fdiv;
//PINSEL0 = (PINSEL0 & 0x0000FFFF) | 0x55550000; /* 选择管脚为UART1 */
U1LCR = 0x80; /* 允许访问分频因子寄存器 */
Fdiv = (Fpclk / 16) / bps; /* 设置波特率 */
U1DLM = Fdiv / 256;
U1DLL = Fdiv % 256;
U1LCR = 0x03; /* 禁止访问分频因子寄存器 */
/* 且设置为8,1,n */
U1IER = 0x01; /* 允许接收和发送中断 */
U1FCR = 0x06; /* 禁止FIFO */
VICIntSelect = 0x00000000; // 设置所有通道为IRQ中断
VICVectCntl1 = 0x27; // UART1中断通道分配到IRQ slot 1,
VICVectAddr1 = (int)Uart1_Pross; // 设置UART1向量地址
VICIntEnable |= 0x00000080; // 使能UART1中断
}
void __irq Uart1_Pross(void)
{
unsigned char c,port_num,IIR;
//VICIntEnClr = (1 << 6) | (1 << 4);
VICVectAddr = 0; // 通知中断控制器中断结束
while(((IIR = U1IIR) & 0x01) == 0) /* 有中断未处理完 */
{
switch (IIR & 0x0e)
{
case 0x02: /* THRE中断 */
{
...............
}
case 0x04:/* 接收数据可用 */
{
.........
}
答 1: re:请将我们示例光盘的UART0中断方式程序进行修改,UART0-》UART1,
并把中断号改为0x07即可。
见示例:
#include "config.h"
/* 定义串口模式设置数据结构 */
typedef struct UartMode
{
uint8 datab; // 字长度,5/6/7/8可选
uint8 stopb; // 停止位,1/2可选
uint8 parity; // 奇偶校验位,0-无校验,1-奇校验,2-偶校验
}UARTMODE;
uint8 rcv_buf[8]; // UART1数据接收缓冲区
volatile uint8 rcv_new; // 接收新数据标志
/*
*********************************************************************************************************
** 函数名称 :IRQ_UART1()
** 函数功能 :串口0接收中断服务程序
** 入口参数 :无
** 出口参数 :无
*********************************************************************************************************
*/
void __irq IRQ_UART1 (void)
{
uint8 i;
if ((U1IIR & 0x0F) == 0x04)
rcv_new = 1; // 设置接收到新的数据标志
for (i=0; i<8; i++)
{
rcv_buf[i] = U1RBR;// 读取FIFO的数据,并清除中断
}
VICVectAddr = 0x00; // 中断处理结束
}
/*
*********************************************************************************************************
** 函数名称 :UART1_SendByte()
** 函数功能 :向串口0发送1字节数据
** 入口参数 :dat 要发送的数据
** 出口参数 :无
*********************************************************************************************************
*/
void UART1_SendByte (uint8 dat)
{
U1THR = dat; // 要发送的数据
}
/*
*********************************************************************************************************
** 函数名称 :UART1_SendBuf()
** 函数功能 :向串口发送8字节数据
** 入口参数 :dat 要发送的数据
** 出口参数 :无
*********************************************************************************************************
*/
void UART1_SendBuf (void)
{
uint8 i;
for (i=0; i<8; i++)
UART1_SendByte(rcv_buf[i]);
while ((U1LSR & 0x20) == 0);// 等待数据发送完毕
}
/*
*********************************************************************************************************
** 函数名称 :UART1_Init()
** 函数功能 :串口初始化,设置工作模式和波特率。
** 入口参数 :baud 波特率
** set 模式设置(UARTMODE数据结构)
** 出口参数 :1-初始化成功, 0-初始化失败
*********************************************************************************************************
*/
int8 UART1_Init (uint32 baud, UARTMODE set)
{
uint32 bak;
/* 参数过滤 */
if ((baud ==0 ) || (baud > 115200)) return (0);
if ((set.datab <5) || (set.datab > 8)) return (0);
if ((set.stopb == 0) || (set.stopb > 2)) return (0);
if (set.parity > 4) return (0);
/* 设置串口波特率 */
U1LCR = 0x80; // DLAB = 1
bak = (Fpclk >> 4) / baud;
U1DLM = bak >> 8;
U1DLL = bak & 0xFF;
/* 设置串口模式 */
bak = set.datab - 5; // 设置字长
if (set.stopb == 2) bak |= 0x04;// 判断是否为2位停止位
if (set.parity != 0)
{
set.parity = set.parity - 1;
bak |= 0x08;
}
bak |= set.parity << 4; // 设置奇偶校验
U1LCR = bak;
return (1);
}
/*
*********************************************************************************************************
** 函数名称 :main()
** 函数功能 :从串口UART1接收字符串"ABCDEFGH",并发送回上位机显示。
** 调试说明 :需要PC串口显示终端软件如EasyARM.exe。
*********************************************************************************************************
*/
int main (void)
{
UARTMODE set;
set.datab = 8;
set.stopb = 1;
set.parity = 0;
rcv_new = 0;
PINSEL0 = 0x00050005; // 设置I/O连接到UART1
UART1_Init(115200, set); // 串口初始化
U1FCR = 0x81; // 使能FIFO,并设置触发点为8字节
U1IER = 0x01; // 允许RBR中断,即接收中断
// 或者在startup.s中使能IRQ中断
//IRQEnable(); // 使能IRQ中断
/* 使能UART1中断 */
VICIntSelect = 0x00000000; // 设置所有的通道为IRQ中断
VICVectCntl0 = 0x20 | 0x07; // UART1分配到IRQ slot0,即最高优先级
VICVectAddr0 = (uint32)IRQ_UART1;// 设置UART1向量地址
VICIntEnable = 1 << 0x07; // 使能UART1中断
while (1)
{
if (rcv_new == 1)
{
rcv_new =0;
UART1_SendBuf();
}
}
return 0;
} 答 2: 一样我以前也遇见过这种情况,那是因为IRQEnable()没有开启。
串口0可以正常进入中断,为什么串口1不能??我用的是LPC2132
void Uart1_Init(uint32 bps)
{
uint16 Fdiv;
//PINSEL0 = (PINSEL0 & 0x0000FFFF) | 0x55550000; /* 选择管脚为UART1 */
U1LCR = 0x80; /* 允许访问分频因子寄存器 */
Fdiv = (Fpclk / 16) / bps; /* 设置波特率 */
U1DLM = Fdiv / 256;
U1DLL = Fdiv % 256;
U1LCR = 0x03; /* 禁止访问分频因子寄存器 */
/* 且设置为8,1,n */
U1IER = 0x01; /* 允许接收和发送中断 */
U1FCR = 0x06; /* 禁止FIFO */
VICIntSelect = 0x00000000; // 设置所有通道为IRQ中断
VICVectCntl1 = 0x27; // UART1中断通道分配到IRQ slot 1,
VICVectAddr1 = (int)Uart1_Pross; // 设置UART1向量地址
VICIntEnable |= 0x00000080; // 使能UART1中断
}
void __irq Uart1_Pross(void)
{
unsigned char c,port_num,IIR;
//VICIntEnClr = (1 << 6) | (1 << 4);
VICVectAddr = 0; // 通知中断控制器中断结束
while(((IIR = U1IIR) & 0x01) == 0) /* 有中断未处理完 */
{
switch (IIR & 0x0e)
{
case 0x02: /* THRE中断 */
{
...............
}
case 0x04:/* 接收数据可用 */
{
.........
}
答 1: re:请将我们示例光盘的UART0中断方式程序进行修改,UART0-》UART1,
并把中断号改为0x07即可。
见示例:
#include "config.h"
/* 定义串口模式设置数据结构 */
typedef struct UartMode
{
uint8 datab; // 字长度,5/6/7/8可选
uint8 stopb; // 停止位,1/2可选
uint8 parity; // 奇偶校验位,0-无校验,1-奇校验,2-偶校验
}UARTMODE;
uint8 rcv_buf[8]; // UART1数据接收缓冲区
volatile uint8 rcv_new; // 接收新数据标志
/*
*********************************************************************************************************
** 函数名称 :IRQ_UART1()
** 函数功能 :串口0接收中断服务程序
** 入口参数 :无
** 出口参数 :无
*********************************************************************************************************
*/
void __irq IRQ_UART1 (void)
{
uint8 i;
if ((U1IIR & 0x0F) == 0x04)
rcv_new = 1; // 设置接收到新的数据标志
for (i=0; i<8; i++)
{
rcv_buf[i] = U1RBR;// 读取FIFO的数据,并清除中断
}
VICVectAddr = 0x00; // 中断处理结束
}
/*
*********************************************************************************************************
** 函数名称 :UART1_SendByte()
** 函数功能 :向串口0发送1字节数据
** 入口参数 :dat 要发送的数据
** 出口参数 :无
*********************************************************************************************************
*/
void UART1_SendByte (uint8 dat)
{
U1THR = dat; // 要发送的数据
}
/*
*********************************************************************************************************
** 函数名称 :UART1_SendBuf()
** 函数功能 :向串口发送8字节数据
** 入口参数 :dat 要发送的数据
** 出口参数 :无
*********************************************************************************************************
*/
void UART1_SendBuf (void)
{
uint8 i;
for (i=0; i<8; i++)
UART1_SendByte(rcv_buf[i]);
while ((U1LSR & 0x20) == 0);// 等待数据发送完毕
}
/*
*********************************************************************************************************
** 函数名称 :UART1_Init()
** 函数功能 :串口初始化,设置工作模式和波特率。
** 入口参数 :baud 波特率
** set 模式设置(UARTMODE数据结构)
** 出口参数 :1-初始化成功, 0-初始化失败
*********************************************************************************************************
*/
int8 UART1_Init (uint32 baud, UARTMODE set)
{
uint32 bak;
/* 参数过滤 */
if ((baud ==0 ) || (baud > 115200)) return (0);
if ((set.datab <5) || (set.datab > 8)) return (0);
if ((set.stopb == 0) || (set.stopb > 2)) return (0);
if (set.parity > 4) return (0);
/* 设置串口波特率 */
U1LCR = 0x80; // DLAB = 1
bak = (Fpclk >> 4) / baud;
U1DLM = bak >> 8;
U1DLL = bak & 0xFF;
/* 设置串口模式 */
bak = set.datab - 5; // 设置字长
if (set.stopb == 2) bak |= 0x04;// 判断是否为2位停止位
if (set.parity != 0)
{
set.parity = set.parity - 1;
bak |= 0x08;
}
bak |= set.parity << 4; // 设置奇偶校验
U1LCR = bak;
return (1);
}
/*
*********************************************************************************************************
** 函数名称 :main()
** 函数功能 :从串口UART1接收字符串"ABCDEFGH",并发送回上位机显示。
** 调试说明 :需要PC串口显示终端软件如EasyARM.exe。
*********************************************************************************************************
*/
int main (void)
{
UARTMODE set;
set.datab = 8;
set.stopb = 1;
set.parity = 0;
rcv_new = 0;
PINSEL0 = 0x00050005; // 设置I/O连接到UART1
UART1_Init(115200, set); // 串口初始化
U1FCR = 0x81; // 使能FIFO,并设置触发点为8字节
U1IER = 0x01; // 允许RBR中断,即接收中断
// 或者在startup.s中使能IRQ中断
//IRQEnable(); // 使能IRQ中断
/* 使能UART1中断 */
VICIntSelect = 0x00000000; // 设置所有的通道为IRQ中断
VICVectCntl0 = 0x20 | 0x07; // UART1分配到IRQ slot0,即最高优先级
VICVectAddr0 = (uint32)IRQ_UART1;// 设置UART1向量地址
VICIntEnable = 1 << 0x07; // 使能UART1中断
while (1)
{
if (rcv_new == 1)
{
rcv_new =0;
UART1_SendBuf();
}
}
return 0;
} 答 2: 一样我以前也遇见过这种情况,那是因为IRQEnable()没有开启。
共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分 |