简述网站建设的基本流程,奥迪网站建设策划书,超级工程网站建设,ppt模板网站开发第一种方法#xff1a;使用标准C库#xff0c;但使用标准C库你必须关闭半主机模式#xff08;1#xff09;添加下面代码就是关闭半主机模式/* 告知连接器不从C库链接使用半主机的函数 */
#pragma import(__use_no_semihosting)/* 定义 _sys_exit() 以避免使用半主机模式 */…第一种方法使用标准C库但使用标准C库你必须关闭半主机模式1添加下面代码就是关闭半主机模式
/* 告知连接器不从C库链接使用半主机的函数 */
#pragma import(__use_no_semihosting)/* 定义 _sys_exit() 以避免使用半主机模式 */
void _sys_exit(int x)
{x x;
}/* 标准库需要的支持类型 */
struct __FILE
{int handle;
};FILE __stdout;
在独立应用程序中不可能支持半主机操作。 因此必须确保应用程序中没有链接 C 库半主机函数。为确保没有从 C 库链接使用半主机的函数 必须导入符号 __use_no_semihosting 。可在工程的任何 C 或汇编语言源文件中执行此操作如下所示在 C 模块中使用 #pragma 指令#pragma import(__use_no_semihosting)在汇编语言模块中使用 IMPORT 指令IMPORT __use_no_semihosting2串口重定向将你要输出信息的串口添加到这句函数里面/// 串口发送重定向
int fputc(int ch, FILE * file)
{Uart_SendDataPoll(M0P_UART0,ch); //调用库函数通过UART0发送一个字母。return ch;
}如果是不同型号的MCU或者使用那个串口更改对应的串口号即可接下来你就自己配置好对应的串口初始化就OK了这里需要注意下本文代码我采用华大HC32L系列的它这个库函数Uart_SendDataPoll(M0P_UART0,ch)里面是有等待数据发送完毕的如果你用的是STM32单片机重定向函数应该这么写// 串口发送重定向
int fputc(int ch, FILE * file)
{USART_SendData(USART1,ch); while(USART_GetFlagStatus(USART1,USART_FLAG_TC)!SET);//等待发送结束return ch;
}
需要自己在添加一行代码来等待发送完毕因为ST发送库函数里面没有等待语句3下面是我自己完整的配置我是使用串口0#include BSP_GPIO.h
#include BSP_Uart.h//#include UFD.h
uint8_t u8Rx0Data;/* 告知连接器不从C库链接使用半主机的函数 */
#pragma import(__use_no_semihosting)/* 定义 _sys_exit() 以避免使用半主机模式 */
void _sys_exit(int x)
{x x;
}/* 标准库需要的支持类型 */
struct __FILE
{int handle;
};FILE __stdout;
/// 串口发送重定向
int fputc(int ch, FILE * file)
{Uart_SendDataPoll(M0P_UART0,ch); //调用库函数通过UART0发送一个字母。return ch;
}
static void Uart0_PortInit(void)
{stc_gpio_cfg_t stcGpioCfg;/// 打开GPIO外设时钟门控Sysctrl_SetPeripheralGate(SysctrlPeripheralGpio, TRUE);DDL_ZERO_STRUCT(stcGpioCfg);/// 端口方向配置 UART0_TXDstcGpioCfg.enDir GpioDirOut;Gpio_Init(PORT_DEBUG_TXD,PIN_DEBUG_TXD,stcGpioCfg);Gpio_SetAfMode(PORT_DEBUG_TXD,PIN_DEBUG_TXD,GpioAf2);//UART0_TXD/// 端口方向配置 UART0_RXDstcGpioCfg.enDir GpioDirIn;/// 端口上下拉配置-上拉stcGpioCfg.enPu GpioPuEnable;Gpio_Init(PORT_DEBUG_RXD,PIN_DEBUG_RXD,stcGpioCfg);Gpio_SetAfMode(PORT_DEBUG_RXD,PIN_DEBUG_RXD,GpioAf2);//UART0_RXDSysctrl_SetFunc(SysctrlSWDUseIOEn, TRUE); /*Set SWD port to GPIO mode*/
}
static void Uart0_Init(void)
{stc_uart_cfg_t stcCfg;stc_uart_baud_t stcBaud;DDL_ZERO_STRUCT(stcCfg);DDL_ZERO_STRUCT(stcBaud);/// 打开UART0外设时钟门控Sysctrl_SetPeripheralGate(SysctrlPeripheralUart0,TRUE);///UART InitstcCfg.enRunMode UartMskMode1; ///模式1stcCfg.enStopBit UartMsk1bit; ///1bit停止位stcCfg.enMmdorCk UartMskDataOrAddr; ///多机模式时stcCfg.stcBaud.u32Baud 1000000; ///波特率1000000stcCfg.stcBaud.enClkDiv UartMsk8Or16Div; ///通道采样分频配置stcCfg.stcBaud.u32Pclk Sysctrl_GetPClkFreq(); ////获得外设时钟PCLK频率值Uart_Init(M0P_UART0, stcCfg); ///串口初始化///UART中断使能Uart_ClrStatus(M0P_UART0,UartRC); ///清接收请求Uart_ClrStatus(M0P_UART0,UartTC); ///清接收请求Uart_EnableIrq(M0P_UART0,UartRxIrq); ///使能串口接收中断EnableNvic(UART0_2_IRQn, IrqLevel3, TRUE); ///系统中断使能
}void BSP_UartInit(void)
{Uart0_PortInit();Uart0_Init();
}第二种方法使用微库因为使用微库的话 ,不会使用半主机模式咱也就不用在写那几句关闭半主机模式的语句1在Keil工程中“中勾选 ”Use MicroLIB2重定向输出这个跟第一种方法一样// 串口发送重定向
int fputc(int ch, FILE * file)
{Uart_SendDataPoll(M0P_UART0,ch); //调用库函数通过UART0发送一个字母。return ch;
}3下面是我自己完整的配置我是使用串口0#include BSP_GPIO.h
#include BSP_Uart.h//#include UFD.h
uint8_t u8Rx0Data;// 串口发送重定向
int fputc(int ch, FILE * file)
{Uart_SendDataPoll(M0P_UART0,ch); //调用库函数通过UART0发送一个字母。return ch;
}
static void Uart0_PortInit(void)
{stc_gpio_cfg_t stcGpioCfg;/// 打开GPIO外设时钟门控Sysctrl_SetPeripheralGate(SysctrlPeripheralGpio, TRUE);DDL_ZERO_STRUCT(stcGpioCfg);/// 端口方向配置 UART0_TXDstcGpioCfg.enDir GpioDirOut;Gpio_Init(PORT_DEBUG_TXD,PIN_DEBUG_TXD,stcGpioCfg);Gpio_SetAfMode(PORT_DEBUG_TXD,PIN_DEBUG_TXD,GpioAf2);//UART0_TXD/// 端口方向配置 UART0_RXDstcGpioCfg.enDir GpioDirIn;/// 端口上下拉配置-上拉stcGpioCfg.enPu GpioPuEnable;Gpio_Init(PORT_DEBUG_RXD,PIN_DEBUG_RXD,stcGpioCfg);Gpio_SetAfMode(PORT_DEBUG_RXD,PIN_DEBUG_RXD,GpioAf2);//UART0_RXDSysctrl_SetFunc(SysctrlSWDUseIOEn, TRUE); /*Set SWD port to GPIO mode*/
}
static void Uart0_Init(void)
{stc_uart_cfg_t stcCfg;stc_uart_baud_t stcBaud;DDL_ZERO_STRUCT(stcCfg);DDL_ZERO_STRUCT(stcBaud);/// 打开UART0外设时钟门控Sysctrl_SetPeripheralGate(SysctrlPeripheralUart0,TRUE);///UART InitstcCfg.enRunMode UartMskMode1; ///模式1stcCfg.enStopBit UartMsk1bit; ///1bit停止位stcCfg.enMmdorCk UartMskDataOrAddr; ///多机模式时stcCfg.stcBaud.u32Baud 1000000; ///波特率1000000stcCfg.stcBaud.enClkDiv UartMsk8Or16Div; ///通道采样分频配置stcCfg.stcBaud.u32Pclk Sysctrl_GetPClkFreq(); ////获得外设时钟PCLK频率值Uart_Init(M0P_UART0, stcCfg); ///串口初始化///UART中断使能Uart_ClrStatus(M0P_UART0,UartRC); ///清接收请求Uart_ClrStatus(M0P_UART0,UartTC); ///清接收请求Uart_EnableIrq(M0P_UART0,UartRxIrq); ///使能串口接收中断EnableNvic(UART0_2_IRQn, IrqLevel3, TRUE); ///系统中断使能
}void BSP_UartInit(void)
{Uart0_PortInit();Uart0_Init();
}总结要使用第一种还是第二种看自己选择大家好像选择第一种比较多。