您现在的位置: 主页 > 嵌入式开发入门到精通 > 单片机技术进阶 > STM32L152的IAP移植笔记 -
本文所属标签:
为本文创立个标签吧:

STM32L152的IAP移植笔记 -

来源: 网络用户发布,如有版权联系网管删除 2018-09-07 

[导读]本文将针对STML152的IAP移植过程作一个笔记。首先得下载AN3310的示例代码,地址为:http://www.st.com/content/st_com/en/products/embedded-software/mcus-embedded-software/stm32-embedded-software/stm32-standard

本文将针对STML152的IAP移植过程作一个笔记。

本文引用地址: http://www.21ic.com/app/mcu/201807/783719.htm

首先得下载AN3310的示例代码,地址为:http://www.st.com/content/st_com/en/products/embedded-software/mcus-embedded-software/stm32-embedded-software/stm32-standard-peripheral-libraries-expansions/stsw-stm32075.html

下载完成后,我们需要做些修改,我们将在NUCLEO-L152RE板子上进行验证测试。

由于NUCLEO-L152RE板子默认MCU是没有外挂晶振的,但可以通过ByPass方式使用ST-LInk的8M晶振,但这里只是作为IAP,且只需要使用到串口,因此可以只使用HSI,于是,在AN3310的工程中打开system_stm32l1xx.c文件找到SystemInit函数,注释掉//SetSysClock();,让系统使用默认的HSI即可。


voidSystemInit(void)

{

/*!

RCC->CR|=(uint32_t)0x00000100;

/*!

RCC->CFGR&=(uint32_t)0x88FFC00C;

/*!

RCC->CR&=(uint32_t)0xEEFEFFFE;

/*!

RCC->CR&=(uint32_t)0xFFFBFFFF;

/*!

RCC->CFGR&=(uint32_t)0xFF02FFFF;

/*!

RCC->CIR=0x00000000;

#ifdefDATA_IN_ExtSRAM

SystemInit_ExtMemCtl();

#endif/*DATA_IN_ExtSRAM*/

/*ConfiguretheSystemclockfrequency,AHB/APBxprescalersandFlashsettings*/

//SetSysClock();

#ifdefVECT_TAB_SRAM

SCB->VTOR=SRAM_BASE|VECT_TAB_OFFSET;/*VectorTableRelocationinInternalSRAM.*/

#else

SCB->VTOR=FLASH_BASE|VECT_TAB_OFFSET;/*VectorTableRelocationinInternalFLASH.*/

#endif

}

然后修改man.c文件中的main函数,注释掉一些按键,让程序默认进入到升级模式:


intmain(void)

{

/*UnlocktheFlashProgramErasecontroller*/

FLASH_If_Init();

/*InitializeKeyButtonmountedonSTM32L15xx-EVALboard*/

//STM_EVAL_PBInit(BUTTON_KEY,BUTTON_MODE_GPIO);

/*TestifKeypush-buttononSTM32L15xx-EVALBoardispressed*/

//if(STM_EVAL_PBGetState(BUTTON_KEY)!=0x00)

{

/*ExecutetheIAPdriverinordertoreprogramtheFlash*/

IAP_Init();

/*Displaymainmenu*/

Main_Menu();

}

#if0

/*Keeptheuserapplicationrunning*/

else

{

/*Testifusercodeisprogrammedstartingfromaddress"APPLICATION_ADDRESS"*/

if(((*(__IOuint32_t*)APPLICATION_ADDRESS)&0x2FFE0000)==0x20000000)

{

/*Jumptouserapplication*/

JumpAddress=*(__IOuint32_t*)(APPLICATION_ADDRESS+4);

Jump_To_Application=(pFunction)JumpAddress;

/*Initializeuserapplication'sStackPointer*/

__set_MSP(*(__IOuint32_t*)APPLICATION_ADDRESS);

Jump_To_Application();

}

}

#endif

while(1)

{}

}


由于NUCLEO板子默认使用的是USART2,因此需要修改使用的串口:


voidIAP_Init(void)

{

USART_InitTypeDefUSART_InitStructure;

/*USARTresourcesconfiguration(Clock,GPIOpinsandUSARTregisters)----*/

/*USARTconfiguredasfollow:

-BaudRate=115200baud

-WordLength=8Bits

-OneStopBit

-Noparity

-Hardwareflowcontroldisabled(RTSandCTSsignals)

-Receiveandtransmitenabled

*/

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;

//STM_EVAL_COMInit(COM2,&USART_InitStructure);

USART2_Init(&USART_InitStructure);

}


USART2_Init()函数为新添加的串口初始化函数,其定义如下:


voidUSART2_Init(USART_InitTypeDef*USART_InitStruct)

{

GPIO_InitTypeDefGPIO_InitStructure;

/*EnableGPIOclock*/

RCC_AHBPeriphClockCmd(RCC_AHBPeriph_GPIOA,ENABLE);

/*EnableUARTclock*/

RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);

/*ConnectPXxtoUSARTx_Tx*/

GPIO_PinAFConfig(GPIOA,GPIO_PinSource2,GPIO_AF_USART2);

/*ConnectPXxtoUSARTx_Rx*/

GPIO_PinAFConfig(GPIOA,GPIO_PinSource3,GPIO_AF_USART2);

/*ConfigureUSARTTxasalternatefunctionpush-pull*/

GPIO_InitStructure.GPIO_Pin=GPIO_Pin_2|GPIO_Pin_3;

GPIO_InitStructure.GPIO_Mode=GPIO_Mode_AF;

GPIO_InitStructure.GPIO_Speed=GPIO_Speed_40MHz;

GPIO_InitStructure.GPIO_OType=GPIO_OType_PP;

GPIO_InitStructure.GPIO_PuPd=GPIO_PuPd_UP;

GPIO_Init(GPIOA,&GPIO_InitStructure);

/*ConfigureUSARTRxasalternatefunctionpush-pull*/

//GPIO_InitStructure.GPIO_Pin=COM_RX_PIN[COM];

//GPIO_Init(COM_RX_PORT[COM],&GPIO_InitStructure);

/*USARTconfiguration*/

USART_Init(USART2,USART_InitStruct);

/*EnableUSART*/

USART_Cmd(USART2,ENABLE);

}


接下来需要修改程序中使用到的打印函数:


voidSerialPutChar(uint8_tc)

{

USART_SendData(USART2,c);

while(USART_GetFlagStatus(USART2,USART_FLAG_TXE)==RESET)

{

}

}



uint32_tSerialKeyPressed(uint8_t*key)

{

if(USART_GetFlagStatus(USART2,USART_FLAG_RXNE)!=RESET)

{

*key=(uint8_t)USART2->DR;

return1;

}

else

{

return0;

}

}


基本上就移植好了,编译烧录进NUCLEO板中运行。


接下来需要找一个PC端软件超级



              查看评论 回复



 

"STM32L152的IAP移植笔记 -"的相关文章

网站地图

围观()