STM32之串口

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/plm199513100/article/details/79410874

/*
名称:STM32之串口
说明:对于STM32的串口通信来说,从外部看,和C51差不多。从内部看,啊。。我还不了解。

从使用上说,也是需要先配置USART,然后通过终端或者轮询的方式接受或者输出数据。由于有了固件库函数的帮助,STM32的串口配置起来比C51还要方便不少。

本实验完成的是输入输出重定向,主要是重写了fput()和fget()函数。

*/

实验主要代码如下:


//USART1配置信息
void USART1_Config(void)
{
    GPIO_InitTypeDef GPIO_InitStructure;
    USART_InitTypeDef USART_InitStructure;

    /* config USART1 clock */
 RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA, ENABLE);

    //GPIO初始化
    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;         //默认的复用功能
    GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
    GPIO_Init(GPIOA, &GPIO_InitStructure);

    GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
    GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
    GPIO_Init(GPIOA, &GPIO_InitStructure);


        /* USART1 mode config */
    USART_InitStructure.USART_BaudRate = 115200;
    USART_InitStructure.USART_WordLength = USART_WordLength_8b;
    USART_InitStructure.USART_StopBits = USART_StopBits_1;
    USART_InitStructure.USART_Parity = USART_Parity_No ;
    USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
    USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
    USART_Init(USART1, &USART_InitStructure);
    USART_Cmd(USART1, ENABLE);

}


//fput用作重定向,为了使用库函数printf()函数
int fputc(int ch, FILE *f)
{
    /* 将 Printf 内容发往串口 */
    USART_SendData(USART1, (unsigned char) ch);
    //while (!(USART1->SR & USART_FLAG_TXE));
    while( USART_GetFlagStatus(USART1,USART_FLAG_TC)!= SET);
    return (ch);

}

//fgetc用作重定向,为了使用库函数scanf()函数
int fgetc(FILE *f)
{
    while(USART_GetFlagStatus(USART1,USART_FLAG_RXNE) != SET)   ;       //等待不空

    return (int)USART_ReceiveData(USART1);
}

猜你喜欢

转载自blog.csdn.net/plm199513100/article/details/79410874