Yuqiang Wang e1498cabc9 SDK build (#47) hai 7 meses
..
.settings 4795f3d206 更新fsp为2.2.0 hai 7 meses
board 64ec089d19 [HAL_Drivers]新增CAN和CANFD切换的宏 hai 10 meses
figures eef1e05537 Improve engineering documentation and upload user manual hai 1 ano
packages 89ecd4344c upload project(usb pcdc、pmsc) hai 1 ano
rzn 0e9a0dfdbd fix iar link source hai 7 meses
rzn_cfg 0e9a0dfdbd fix iar link source hai 7 meses
rzn_gen 0e9a0dfdbd fix iar link source hai 7 meses
script 4795f3d206 更新fsp为2.2.0 hai 7 meses
src 89ecd4344c upload project(usb pcdc、pmsc) hai 1 ano
.api_xml 89ecd4344c upload project(usb pcdc、pmsc) hai 1 ano
.config 4795f3d206 更新fsp为2.2.0 hai 7 meses
.cproject 4795f3d206 更新fsp为2.2.0 hai 7 meses
.gitignore 43669c1c97 Fixed some known issues hai 1 ano
.project 89ecd4344c upload project(usb pcdc、pmsc) hai 1 ano
.secure_azone 89ecd4344c upload project(usb pcdc、pmsc) hai 1 ano
.secure_rzone 4795f3d206 更新fsp为2.2.0 hai 7 meses
.secure_xml 4795f3d206 更新fsp为2.2.0 hai 7 meses
Kconfig 4795f3d206 更新fsp为2.2.0 hai 7 meses
README.md e1498cabc9 SDK build (#47) hai 7 meses
README_zh.md e1498cabc9 SDK build (#47) hai 7 meses
SConscript 0e9a0dfdbd fix iar link source hai 7 meses
SConstruct 89ecd4344c upload project(usb pcdc、pmsc) hai 1 ano
buildinfo.ipcf 0e9a0dfdbd fix iar link source hai 7 meses
buildinfo.json 4795f3d206 更新fsp为2.2.0 hai 7 meses
configuration.xml 4795f3d206 更新fsp为2.2.0 hai 7 meses
envsetup.sh 89ecd4344c upload project(usb pcdc、pmsc) hai 1 ano
mklinks.bat 89ecd4344c upload project(usb pcdc、pmsc) hai 1 ano
mklinks.sh 89ecd4344c upload project(usb pcdc、pmsc) hai 1 ano
ozone_scons.jdebug 384e7a31df 修复scons固件无法运行的问题,添加ozone调试脚本 hai 1 ano
project.ewd 0e9a0dfdbd fix iar link source hai 7 meses
project.ewp 0e9a0dfdbd fix iar link source hai 7 meses
project.ewt 0e9a0dfdbd fix iar link source hai 7 meses
project.eww 89ecd4344c upload project(usb pcdc、pmsc) hai 1 ano
rtconfig.h 4795f3d206 更新fsp为2.2.0 hai 7 meses
rtconfig.py 384e7a31df 修复scons固件无法运行的问题,添加ozone调试脚本 hai 1 ano
rzn_cfg.txt 4795f3d206 更新fsp为2.2.0 hai 7 meses
template.ewd 0e9a0dfdbd fix iar link source hai 7 meses
template.ewp 0e9a0dfdbd fix iar link source hai 7 meses
template.eww 89ecd4344c upload project(usb pcdc、pmsc) hai 1 ano

README.md

USB-PCDC Driver Usage Instructions

English | 中文

Introduction

This example demonstrates how to implement a virtual serial port over USB. USB PCDC (USB Communication Device Class) is a subclass of the USB communication device class (CDC) that is commonly used to implement virtual serial communication functionality. In embedded device development, USB PCDC is often used to simulate a serial communication port (such as a COM port) over a USB interface, allowing data interaction with a host.

Hardware Requirements

image-20241126111451833

EtherKit provides a USB-Device peripheral, located on the development board as shown below:

image-20241126111503789

FSP Configuration Instructions

  • Open the project’s configuration.xml file using FSP and add the usb_pmcs stack:

image-20241126112205300

  • Add g_rm_block_media0:

image-20241126111550254

  • Select g_basic0_usb and set the interrupt callback function to usb_apl_callback:

image-20241126112229660

  • Next, configure the USB pins. Find USB_HS and enable it:

image-20241126111620891

Build Configuration

Locate the file at the specified path in the project: .\rzn\SConscript, and replace its content with the following:

Import('RTT_ROOT')
Import('rtconfig')
from building import *
from gcc import *

cwd = GetCurrentDir()
src = []
group = []
CPPPATH = []

if rtconfig.PLATFORM in ['iccarm'] + GetGCCLikePLATFORM():
    if rtconfig.PLATFORM == 'iccarm' or GetOption('target') != 'mdk5':
        src += Glob('./fsp/src/bsp/mcu/all/*.c')
        src += Glob('./fsp/src/bsp/mcu/all/cr/*.c')
        src += Glob('./fsp/src/bsp/mcu/r*/*.c')
        src += Glob('./fsp/src/bsp/cmsis/Device/RENESAS/Source/*.c')
        src += Glob('./fsp/src/bsp/cmsis/Device/RENESAS/Source/cr/*.c')
        src += Glob('./fsp/src/r_*/*.c')
        src += Glob('./fsp/src/r_usb_basic/src/driver/*.c')
        src += Glob('./fsp/src/r_usb_basic/src/hw/*.c')
        src += Glob('./fsp/src/r_usb_pcdc/src/*.c')
        CPPPATH = [ cwd + '/arm/CMSIS_5/CMSIS/Core_R/Include',
                    cwd + '/fsp/inc',
                    cwd + '/fsp/src/inc',
                    cwd + '/fsp/inc/api',
                    cwd + '/fsp/inc/instances',
                    cwd + '/fsp/src/r_usb_basic/src/driver/inc',
                    cwd + '/fsp/src/r_usb_basic/src/hw/inc',
                    cwd + '/fsp/src/r_usb_pcdc/src/inc',]

group = DefineGroup('rzn', src, depend = [''], CPPPATH = CPPPATH)
Return('group')

If you are using Studio for development, right-click on the project and select Sync SCons Configuration to Project. For IAR development, right-click within the current project to open the environment, and run the following command to regenerate the configuration: scons --target=iar

RT-Thread Settings Configuration

The USB example currently uses the FreeRTOS interface driver, so we also need to enable the FreeRTOS compatibility layer package:

image-20241126111643871

Compilation & Download

  • RT-Thread Studio: Download the EtherKit resource package in the RT-Thread Studio package manager, create a new project, and compile it.
  • IAR: First, double-click mklinks.bat to create the link between the rt-thread and libraries folders. Then, use Env to generate the IAR project. Finally, double-click project.eww to open the IAR project and compile it.

Once the compilation is complete, connect the Jlink interface of the development board to the PC and download the firmware to the board.

Running Results

After generating the FSP configuration, compile and download the firmware to the development board. The example will automatically start, and you will see an additional USB device in the file manager:

image-20241126112248530

Next, open the virtual serial port device and test character input:

image-20241126112301592