|
这个帖子,我昨天发在AVR版,一天了只有人看,没有人回答,发邮件到avr.cn@atmel.com,一直提示发送失败,所以最后的希望就在傻孩子这里了,要是到这里还没有办法解决的话,我只能放弃了~
以前一直用mega16,所以串口没有任何问题。最近换成用168了,出了点状况,具体情况如下:
168的串口0,可以用查询的方式,但是不能用中断的方式。刚开始我以为是中断向量的宏定义错了(其实不是),找了好久才发现问题。是UCSR0B这个寄存器里的RXCIE0这一位的问题。如果我只UCSR0B=(1<<RXEN0)|(1<<TXEN0)这样配置(查询),串口可以正常的发送和接受,但是如果我UCSR0B=(1<<RXEN0)|(1<<TXEN0)|(1<<RXCIE0)这样配置的话(允许接收中断),串口就不能接收,但是还可以发送的。
这也就是说,一旦串口接收完成中断使能,那么串口反倒不能接收了,搞了二天,数据手册都看翻了,搜遍了网络,也没有人遇到这个问题,看看有没有人也遇到同样的情况了。谢谢。附上我的测试程序:
//查询方式
void put_char(unsigned char c)
{
loop_until_bit_is_set(UCSR0A,UDRE0);
UDR0=c;
}
unsigned char get_char(void)
{
loop_until_bit_is_set(UCSR0A,RXC0);
return UDR0;
}
//中断方式
ISR(SIG_UART_RECV)
{
unsigned char temp;
temp=UDR0;
_delay_ms(1);
UDR0=temp;
}
ISR(SIG_UART_TRANS)
{
;
}
void main(void)
{
//uart 初始化
UCSR0B=(1<<RXEN0)|(1<<TXEN0)|(1<<RXCIE0)|(1<<TXCIE0);
UBRR0H=0;
UBRR0L=25; //baud=9600 UBRR=CK/(baud*16) -1
sei();
while(1)
{
put_char(get_char());
}
} |
阿莫论坛20周年了!感谢大家的支持与爱护!!
月入3000的是反美的。收入3万是亲美的。收入30万是移民美国的。收入300万是取得绿卡后回国,教唆那些3000来反美的!
|