前言
- 上一篇讲了STM32 USB 虚拟串口的功能实现,可以通过STM32输出信息到PC端
- 这篇简单的做个应用:打印LOG(日志)信息到虚拟串口
操作方法
- 基于上篇的STM32 USB Virtual Port Com 例程,把USB的发送,改为字符串输出
- 这里使用标准C库的:
vsnprintf
函数,目的是格式化打印字符串到指定的数组
#include "main.h"
#include "usb_device.h"
#include "usbd_cdc_if.h"
#include <stdio.h>
#include <stdarg.h>
void SystemClock_Config(void);
static void MX_GPIO_Init(void);
#define DBG_BUFF_MAX_LEN 256
void usb_vcom_puts(uint8_t *buf)
{
CDC_Transmit_FS(buf, strlen((const char *)buf));
}
/* debug print : support float double */
int printk(const char *fmt, ...)
{
va_list args;
static char log_buf[DBG_BUFF_MAX_LEN] = { 0 };
va_start(args, fmt);
int length = vsnprintf(log_buf, sizeof(log_buf) - 1, fmt, args);
usb_vcom_puts((uint8_t *)log_buf);
return length;
}
void vcp_send_test(uint8_t ch)
{
uint8_t temp_buf[DBG_BUFF_MAX_LEN];
for (uint16_t i = 0; i < DBG_BUFF_MAX_LEN; i++)
{
temp_buf[i] = 0x41;
}
temp_buf[0] = ch;
CDC_Transmit_FS(temp_buf, sizeof(temp_buf));
}
int main(void)
{
uint32_t cnt = 0x00;
HAL_Init();
SystemClock_Config();
MX_GPIO_Init();
MX_USB_DEVICE_Init();
HAL_Delay(2000);
printk("%s : STM32 USB Virtual Port Com Test!\r\n", __func__, cnt);
while (1)
{
HAL_Delay(3000);
printk("%s: hell, usb virtual com,cnt = %d\r\n", __func__, cnt);
cnt++;
}
}
调试效果
- 编译下载
- PC端串口助手,打开STM32 USB虚拟的串口,波特率随意(不要太高就好)
小结
- USB功能很强大,多多去了解,会发现更多
- 先熟悉基本的USB应用,再返回去细化或消化每个USB协议的细节