虚拟串口、虚拟CAN

虚拟串口

socat -d -d pty,raw,echo=0 pty,raw,echo=0

cat < /dev/pts/20 #收

sudo echo "1111"> /dev/pts/19 #发

虚拟CANFD

创建虚拟CAN接口
在Linux上能使用虚拟CAN接口之前,需要在终端执行以下三个步骤:

加载vcan内核模块: sudo modprobe vcan

创建虚拟CAN接口: sudo ip link add dev vcan0 type vcan

将虚拟CAN接口处于在线状态: sudo ip link set up vcan0 或 sudo ip link set dev vcan0 up

将虚拟CAN接口处于离线状态: sudo ip link set down vcan0 或 sudo ip link set dev vcan0 down

删除虚拟CAN接口: sudo ip link del dev vcan0

然后,通过命令ip addr | grep "can" 来验证是否可用并处于在线状态

sudo apt install can-utils

candump -tz vcan0 #收

cansend vcan0 123#abc #发

ubuntu 使用虚拟can 与 socketCAN使用_ubuntu can通信_小鱼仙官的博客-CSDN博客

【Linux】Socket Can(支持Canfd)编程及测试_球状闪电00的博客-CSDN博客

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是基于 STM32F1xx 标准外设库实现 USB 虚拟串口通信的代码: ```c #include "stm32f1xx.h" #include "usbd_cdc_if.h" #define APP_RX_DATA_SIZE 2048 #define APP_TX_DATA_SIZE 2048 uint8_t UserRxBufferFS[APP_RX_DATA_SIZE]; uint8_t UserTxBufferFS[APP_TX_DATA_SIZE]; USBD_CDC_LineCodingTypeDef LineCoding = { 115200, /* baud rate*/ 0x00, /* stop bits-1*/ 0x00, /* parity - none*/ 0x08 /* nb. of bits 8*/ }; USBD_HandleTypeDef hUsbDeviceFS; static void MX_USB_DEVICE_Init(void) { hUsbDeviceFS.Instance = USB; hUsbDeviceFS.Init.dev_endpoints = 7; hUsbDeviceFS.Init.speed = USBD_SPEED_FULL; hUsbDeviceFS.Init.ep0_mps = DEP0CTL_MPS_64; hUsbDeviceFS.Init.dma_enable = DISABLE; hUsbDeviceFS.Init.low_power_enable = DISABLE; hUsbDeviceFS.Init.lpm_enable = DISABLE; hUsbDeviceFS.Init.battery_charging_enable = DISABLE; if (HAL_PCD_Init(&hUsbDeviceFS.pcd) != HAL_OK) { Error_Handler(); } if (HAL_PCDEx_SetRxFiFo(&hUsbDeviceFS.pcd, 0x80) != HAL_OK) { Error_Handler(); } if (HAL_PCDEx_SetTxFiFo(&hUsbDeviceFS.pcd, 0, 0x40) != HAL_OK) { Error_Handler(); } if (HAL_PCDEx_SetTxFiFo(&hUsbDeviceFS.pcd, 1, 0x80) != HAL_OK) { Error_Handler(); } } void USB_Init(void) { MX_USB_DEVICE_Init(); USBD_Init(&hUsbDeviceFS, &CDC_Desc, DEVICE_FS); USBD_RegisterClass(&hUsbDeviceFS, &USBD_CDC); USBD_CDC_RegisterInterface(&hUsbDeviceFS, &USBD_Interface_fops_FS); USBD_Start(&hUsbDeviceFS); } void CDC_Transmit_FS(uint8_t* Buf, uint16_t Len) { uint8_t result = USBD_OK; USBD_CDC_HandleTypeDef *hcdc = (USBD_CDC_HandleTypeDef*)hUsbDeviceFS.pClassData; if (hcdc->TxState != 0) { return; } USBD_CDC_SetTxBuffer(&hUsbDeviceFS, Buf, Len); result = USBD_CDC_TransmitPacket(&hUsbDeviceFS); if (result != USBD_OK) { Error_Handler(); } } void HAL_PCD_MspInit(PCD_HandleTypeDef* pcdHandle) { GPIO_InitTypeDef GPIO_InitStruct = {0}; if(pcdHandle->Instance==USB) { /* USB clock enable */ __HAL_RCC_USB_CLK_ENABLE(); __HAL_RCC_GPIOA_CLK_ENABLE(); /**USB GPIO Configuration PA11 ------> USB_DM PA12 ------> USB_DP */ GPIO_InitStruct.Pin = GPIO_PIN_11|GPIO_PIN_12; GPIO_InitStruct.Mode = GPIO_MODE_AF_PP; GPIO_InitStruct.Pull = GPIO_NOPULL; GPIO_InitStruct.Speed = GPIO_SPEED_FREQ_HIGH; GPIO_InitStruct.Alternate = GPIO_AF14_USB; HAL_GPIO_Init(GPIOA, &GPIO_InitStruct); /* USB interrupt Init */ HAL_NVIC_SetPriority(USB_LP_CAN1_RX0_IRQn, 0, 0); HAL_NVIC_EnableIRQ(USB_LP_CAN1_RX0_IRQn); } } void USB_LP_CAN1_RX0_IRQHandler(void) { HAL_PCD_IRQHandler(&hUsbDeviceFS.pcd); } void Error_Handler(void) { while (1) { } } ``` 以上代码中,`UserRxBufferFS` 和 `UserTxBufferFS` 分别是接收和发送缓冲区,`LineCoding` 是串口参数设置结构体,`USB_Init()` 函数用于初始化 USB 设备,`CDC_Transmit_FS()` 函数用于发送数据,`HAL_PCD_MspInit()` 函数用于初始化 USB 外设引脚,`USB_LP_CAN1_RX0_IRQHandler()` 函数是 USB 中断处理函数。 在使用此代码前,需要在 STM32CubeMX 中配置 USB 外设为 Virtual Com Port,然后生成代码即可。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值