标签:cnt USB void Virtual 串口 include buf
前言
- 上一篇讲了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协议的细节
标签:cnt,USB,void,Virtual,串口,include,buf 来源: https://blog.csdn.net/tcjy1000/article/details/122831959
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。