这些小活动你都参加了吗?快来围观一下吧!>>
电子产品世界 » 论坛首页 » 综合技术 » 基础知识 » UART1 请问周公我的UART1怎么进不了中断??

共2条 1/1 1 跳转至

UART1 请问周公我的UART1怎么进不了中断??

院士
2006-09-17 18:14:16     打赏
UART1 请问周公我的UART1怎么进不了中断??



关键词: UART1     请问     周公     我的     怎么     不了     中断    

院士
2006-12-22 22:43:00     打赏
2楼
问 管脚是这样设置的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()没有开启。

共2条 1/1 1 跳转至

回复

匿名不能发帖!请先 [ 登陆 注册 ]