/*
此函数是依据网上程序改写,串口5选用中止接纳 收够20个字符 就向PC 回来20个数字 详见main函数和中止函数
*/
#include “stm32f10x_lib.h”
unsigned char TxBuffer5[100] ;
unsigned int i;
unsigned int flag;
/***************************************************
* 函数称号 :void RCC_Configuration()
* 功用描绘 : 复位和时钟操控 装备
* 参数 : 无
* 回来值 : 无
* 大局变量 : 无
* 大局静态变量: 无
* 部分静态变量: 无
***********************************************************/
void RCC_Configuration()
{
ErrorStatus HSEStartUpStatus; //界说外部高速晶振发动状况枚举变量
RCC_DeInit(); //复位RCC外部寄存器到默许值
RCC_HSEConfig(RCC_HSE_ON); //翻开外部高速晶振
HSEStartUpStatus=RCC_WaitForHSEStartUp(); //等候外部高速时钟准备好
if(HSEStartUpStatus==SUCCESS){ //外部高速时钟现已准备好
FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); /*敞开FLASH预读缓冲功用,加快FLASH的读取。
一切程序中有必要的用法,方位:RCC初始化子函数里边,时钟起振之后 */
FLASH_SetLatency(FLASH_Latency_2); //FLASH时序推迟几个周期,等候总线同步操作。引荐依照单片机体系运转频率,0—24MHz时,取 //Latency=0;24—48MHz时,取Latency=1;48~72MHz时,取Latency=2。
RCC_HCLKConfig(RCC_SYSCLK_Div1); //装备AHB(HCLK)==体系时钟/1
RCC_PCLK2Config(RCC_HCLK_Div1); //装备APB2(高速)(PCLK2)==体系时钟/1
RCC_PCLK1Config(RCC_HCLK_Div2); //装备APB1(低速)(PCLK1)==体系时钟/2
//注:AHB首要担任外部存储器时钟。APB2担任AD,I/O,高档TIM,串口1。APB1担任DA,USB,SPI,I2C,CAN,串口2345,一般TIM。
RCC_PLLConfig(RCC_PLLSource_HSE_Div1,RCC_PLLMul_9); //装备PLL时钟==(外部高速晶体时钟/1)* 9 ==72MHz
RCC_PLLCmd(ENABLE); //使能PLL时钟
while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY)==RESET); //等候PLL时钟安排妥当
RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK); //装备体系时钟==PLL时钟
while(RCC_GetSYSCLKSource()!=0x08); //等候体系时钟源的发动
}
//————————以下为敞开外设时钟的操作———————–//
// RCC_AHBPeriphClockCmd (ABP2设备1 | ABP2设备2 , ENABLE); //发动AHB设备
// RCC_APB2PeriphClockCmd(ABP2设备1 | ABP2设备2 , ENABLE); //发动ABP2设备
// RCC_APB1PeriphClockCmd(ABP2设备1 | ABP2设备2 , ENABLE); //发动ABP1设备
// RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_AFIO | RCC_APB2Periph_USART1 , ENABLE); //翻开APB2外设
RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA | RCC_APB2Periph_AFIO
|RCC_APB2Periph_GPIOC | RCC_APB2Periph_GPIOD, ENABLE);
RCC_APB1PeriphClockCmd(RCC_APB1Periph_UART5,ENABLE);
}
/*********************************************
* 函数称号 : NVIC_Configuration(void)
* 功用描绘 : NVIC(嵌套中止操控器)装备
* 参数 : 无
* 回来值 : 无
* 大局变量 : 无
* 大局静态变量: 无
* 部分静态变量: 无
***********************************************/
void NVIC_Configuration( )
{
//注:总共16个优先级,分为抢占式和呼应式。两种优先级所占的数量由此代码确认,NVIC_PriorityGroup_x可所以0、1、2、3、4,
//别离代表抢占优先级有1、2、4、8、16个和呼应优先级有16、8、4、2、1个。规则两种优先级的数量后,一切的中止等级有必要在其中挑选,
//抢占等级高的会打断其他中止优先履行,而呼应等级高的会在其他中止履行完优先履行。
/* Enable the USART1 Interrupt
}
/****************************************
* 函数称号 :GPIO_Configuration()
* 功用描绘 : GPIO装备
* 参数 : 无
* 回来值 : 无
* 大局变量 : 无
* 大局静态变量: 无
* 部分静态变量: 无
****************************************/
void GPIO_Configuration()
{
GPIO_InitTypeDef GPIO_InitStructure; //界说GPIO初始化结构体
//——–将UART5 的TX 装备为复用推挽输出 AF_PP———————//
GPIO_InitStructure.GPIO_Pin=GPIO_Pin_12; //管脚方位界说,标号可所以NONE、ALL、0至15。
GPIO_InitStructure.GPIO_Speed=GPIO_Speed_50MHz; //输出速度50MHz
GPIO_InitStructure.GPIO_Mode=GPIO_Mode_AF_PP; //推挽输出形式 Out_PP
GPIO_Init(GPIOC,&GPIO_InitStructure); //E组GPIO初始化
//——–将USART1 的TX 装备为复用推挽输出 AF_PP———————//
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
GPIO_Init(GPIOA, &GPIO_InitStructure);
//——–将UART5 的RX 装备为复用浮空输入 IN_FLOATING———————//
GPIO_InitStructure.GPIO_Pin=GPIO_Pin_2; //管脚方位界说
//输入形式下装备输出速度无意义
//GPIO_InitStructure.GPIO_Speed=GPIO_Speed_2MHz; //输出速度2MHz
GPIO_InitStructure.GPIO_Mode=GPIO_Mode_IN_FLOATING; //浮空输入 IN_FLOATING
GPIO_Init(GPIOD,&GPIO_InitStructure); //C组GPIO初始化
//——–将USART1 的RX 装备为复用浮空输入 IN_FLOATING———————//
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
GPIO_Init(GPIOA, &GPIO_InitStructure);
}
/****************************************************
* 函数称号 :USART1_Configuration( )
* 功用描绘 : 装备USART1数据格式、波特率等参数
* 参数 : 无
* 回来值 : 无
* 大局变量 : 无
* 大局静态变量: 无
* 部分静态变量: 无
*******************************************************/
void UART5_Configuration( )
{
USART_InitTypeDef USART_InitStructure; //串口设置康复默许参数
USART_InitStructure.USART_BaudRate = 115200; //波特率115200
USART_InitStructure.USART_WordLength = USART_WordLength_8b; //字长8位
USART_InitStructure.USART_StopBits = USART_StopBits_1; //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; //翻开Rx接纳和Tx发送功用
/* Configure USART1 */
//USART_Init(USART1, &USART_InitStructure);
/* Configure UART5 */
USART_Init(UART5, &USART_InitStructure); //初始化
/* Enable USART1 Receive and Transmit interrupts */
// USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);
// USART_ITConfig(USART1, USART_IT_TXE, ENABLE);
/* Enable UART5 Receive and Transmit interrupts */
USART_ITConfig(UART5, USART_IT_RXNE, ENABLE); // 若接纳数据寄存器满,则发生中止
// USART_ITConfig(UART5, USART_IT_TXE, ENABLE);
/* Enable the USART1 */
// USART_Cmd(USART1, ENABLE);
/* Enable the UART5 */
USART_Cmd(UART5, ENABLE); //发动串口
//—–如下句子处理第1个字节无法正确发送出去的问题—–//
USART_ClearFlag(UART5, USART_FLAG_TC); // 清标志
// USART_ClearFlag(USART1, USART_FLAG_TC);
}
/********这是中止服务子程序,在stm32f10x_it.c中************************ */
void UART5_IRQHandler(void)
{
if(USART_GetITStatus(UART5, USART_IT_RXNE) != RESET) //若接纳数据寄存器满
{
TxBuffer5[i]=USART_ReceiveData(UART5);
i++;
}
if(i==20)
{ flag=1;
i=0;}
// USART_SendData(UART5, USART_ReceiveData(UART5)); //回发给PC
// while(USART_GetFlagStatus(UART5, USART_IT_TXE)==RESET);//等候发完
}
/*
void delay(void)
{
unsigned int a,b;
for(a=0;a<1000;a++)
for(b=0;b<200;b++)
} */
/**************************************************
* 函数称号 :main()
* 功用描绘 : 主函数
* 参数 : 无
* 回来值 : 无
* 大局变量 : 无
* 大局静态变量: 无
* 部分静态变量: 无
****************************************************/
int main()
{
unsigned int j;
RCC_Configuration();
GPIO_Configuration();
NVIC_Configuration( );
UART5_Configuration();
while(1){
if(flag)
{
for(j=0;j<20;j++)
{
USART_SendData(UART5,j); //回发给PC
while(USART_GetFlagStatus(UART5, USART_FLAG_TXE)==RESET);//等候发完 USART_IT_TXE
}
flag=0;
}
}
}