求指点:
USART1 和USART2 发送正常
代码很简单,现在有个问题就是接受中断不通。
有不知道是板子上的2303坏了,还是USART1坏了,反正用MCUISP下载握手不成功,用jtag可以。
所以想用USART2 弄个串口调试,可是串口2接受不到。
前几天把USART1的 RXD和TXD接在一起,程序中自己打印,自己接受,然后显示在TFT上没有问题,说明芯片本身是好的,但是今天测试就不行了。
怎么能快速排除问题
com_init(u32 baud)
{
USART_InitTypeDef usart_init_pra;
GPIO_InitTypeDef gpio_config;
NVIC_InitTypeDef nvic_config;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_AFIO | RCC_APB2Periph_GPIOA,ENABLE);
//USART1_TX PA.9
gpio_config.GPIO_Pin = GPIO_Pin_9;
gpio_config.GPIO_Speed = GPIO_Speed_50MHz;
gpio_config.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_Init(GPIOA, &gpio_config);
//USART1_RX    A.10
gpio_config.GPIO_Pin = GPIO_Pin_10;
gpio_config.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_Init(GPIOA, &gpio_config);
usart_init_pra.USART_BaudRate = baud;
usart_init_pra.USART_WordLength = USART_WordLength_8b;
usart_init_pra.USART_StopBits = USART_StopBits_1;
usart_init_pra.USART_Parity = USART_Parity_No; //不奇偶校验
usart_init_pra.USART_HardwareFlowControl = USART_HardwareFlowControl_None; //硬件流控制失能
usart_init_pra.USART_Mode = USART_Mode_Rx | USART_Mode_Tx; //使能接收发送
USART_Init(USART1,&usart_init_pra); //初始化参数
//NVIC配置 分组已经配置
nvic_config.NVIC_IRQChannel = USART1_IRQn;
nvic_config.NVIC_IRQChannelPreemptionPriority = 3;
nvic_config.NVIC_IRQChannelSubPriority = 6;
NVIC_Init(&nvic_config);
USART_ClearFlag(USART1,USART_FLAG_TC); //复位后被硬件置1,需要清除负责容易丢失第一个数据
USART_ITConfig(USART1,USART_IT_RXNE,ENABLE); //允许接收中断
USART_Cmd(USART1,ENABLE); //使能串口1
RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);
//USART1_TX PA.2
gpio_config.GPIO_Pin = GPIO_Pin_2;
gpio_config.GPIO_Speed = GPIO_Speed_50MHz;
gpio_config.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_Init(GPIOA, &gpio_config);
//USART1_RX    A.3
gpio_config.GPIO_Pin = GPIO_Pin_3;
gpio_config.GPIO_Mode = GPIO_Mode_IN_FLOATING;
GPIO_Init(GPIOA, &gpio_config);
usart_init_pra.USART_BaudRate = baud;
usart_init_pra.USART_WordLength = USART_WordLength_8b;
usart_init_pra.USART_StopBits = USART_StopBits_1;
usart_init_pra.USART_Parity = USART_Parity_No; //不奇偶校验
usart_init_pra.USART_HardwareFlowControl = USART_HardwareFlowControl_None; //硬件流控制失能
usart_init_pra.USART_Mode = USART_Mode_Rx | USART_Mode_Tx; //使能接收发送
USART_Init(USART2,&usart_init_pra); //初始化参数
//NVIC配置 分组已经配置
nvic_config.NVIC_IRQChannel = USART2_IRQn;
nvic_config.NVIC_IRQChannelPreemptionPriority = 3;
nvic_config.NVIC_IRQChannelSubPriority = 7;
NVIC_Init(&nvic_config);
USART_ClearFlag(USART2,USART_FLAG_TC); //复位后被硬件置1,需要清除负责容易丢失第一个数据
USART_ITConfig(USART2,USART_IT_RXNE,ENABLE); //允许接收中断
USART_Cmd(USART2,ENABLE); //使能串口2
}
void com_snd(unsigned char com, unsigned int uiLen, unsigned char *SendBuf)
{
u8 i=0,j=0;
if (com == 2)
{
for (i=0;i<uiLen;i++)
{
while(USART_GetFlagStatus(USART2,USART_FLAG_TXE) != SET); //发送寄存器满等待
USART_SendData(USART2,SendBuf);
}
}else {
for (i=0;i<uiLen;i++)
{
while(USART_GetFlagStatus(USART1,USART_FLAG_TXE) != SET); //发送寄存器满等待
USART_SendData(USART1,SendBuf);
}
}
}
int main(void)
{
unsigned int i=0,j=0;
unsigned char buff[100];
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2); //0~7 | 0~7
LED_Init(); //推挽输出
delay_init(72);
com_init(115200);
while(1)
{
printf("j=%d,i=%02d\r\n",j,i);
com_snd(2,12,"OOO\r\n");
com_snd(1,12,"KKK\r\n");
delay_ms(1000);
}
}
|