winnie 发表于 2009-3-28 14:12:19

一个小程序,关于中断的

void interrupt usart(void)
{
rcdata.address = RCREG;
while(RCIF == 1)
{}      //待数据被读取
if(usflag.sflag.cdtransmit == 0)
{
RC3 = 1;
usflag.sflag.cdtransmit = 1;
d5ms(15000);
}
else
{
while(1)
{
   RC3 = 0;
   d5ms(15000);
   RC3 = 1;
   d5ms(15000);
}
}
}
void main(void)
{
usart_initinal();
while(1)
{ }
}
void usart_initinal(void)//串口模块初始化
{   
GIE = 1; //开全局中断
PEIE = 1; //开局部中断
TXIE = 0; //发送中断禁止 
RCIE = 1; //接收中断允许位
SPEN = 1; //串口模块使能
CREN = 1; //连续接收数据
TX9 = 0; //8位数据发送格式
RX9 = 0; //8位数据接收格式
SYNC = 0; //异步串行通信方式
BRGH = 1; //高速波特率使能
SPBRG = 0x48;//11MHZ时波特率为9600
TRISC6 = 1;
TRISC7 = 1;
TRISC3 = 0;
TRISC4 = 0;
RC3 = 0;
RC4 = 0;
}                                             
这样的芯片初始化后,上电后就产生了一个中断,我不知这个中断初始是不是有问题

winnie 发表于 2009-3-28 14:12:31

while(RCIF == 1)
{}

多余。

RCIF由硬件自动清零,在RCREG被读以后。



GIE = 1; //开全局中断
PEIE = 1; //开局部中断
TXIE = 0; //发送中断禁止 
RCIE = 1; //接收中断允许位


中断设定应该在所有IO口被设定好以后再开。

你的原因应该是先开了中断,而后在设定C6、7时候,错误产生了串口的起始位,而发生了错误的中断。
页: [1]
查看完整版本: 一个小程序,关于中断的