1. How to dynamically modify device descriptors or string descriptors?
In the file usbd_desc.c, the descriptors associated with the device and string can be dynamically adjusted by the callback function of GetDescriptor.
2. How to enable large-capacity storage class drivers to support multiple logical disks [LUN]?
Modify STORAGE_LUN_NBR in the file usbd_msc_storage_xxx.c. [xxx represents the storage medium used]
The STORAGE_Inquirydata array contains the standard query data for each LUN [inquiry data].
For example, 2 LUNs are used.
consTInt8_t STORAGE_Inquirydata[] = {
/*LUN 0 */
0x00,
0x80,
0x02,
0x02,
(USBD_STD_INQUIRY_LENGTH- 5),
0x00,
0x00,
0x00,
'S','T', 'M', ' ', ' ', ' ', ' ', ' ', /* Manufacturer:
8bytes */
'm','i', 'c', 'r', 'o', 'S', 'D', ' ', /* Product:
16Bytes */
'F','l', 'a', 's', 'h', ' ', ' ', ' ',
'1', '.', '0', '0', /* Version: 4 Bytes */
/*LUN 1 */
0x00,
0x80,
0x02,
0x02,
(USBD_STD_INQUIRY_LENGTH- 5),
0x00,
0x00,
0x00,
'S', 'T', 'M', ' ', ' ', ' ', ' ', ' ', /* Manufacturer:8 bytes */
'N','a', 'n', 'd', ' ', ' ', ' ', ' ', /* Product:16 Bytes */
'F','l', 'a', 's', 'h', ' ', ' ', ' ',
'1', '.', '0', '0', /* Version: 4 Bytes */
};
3. Where is the address of the endpoint defined?
Endpoint addresses are typically defined in the header files of each class driver.
For example, the endpoint definition of the MSC class is defined in usbd_msc.h as follows:
#define MSC_EPIN_ADDR 0x81 //For Endpoint 1 IN
#defineMSC_EPOUT_ADDR 0x01 //For Endpoint 1 OUT
4. Can the USB device library run arbitrarily in FULL SPEED or HIGH SPEED mode?
Yes, the library supports USB OTG FS and USBOTG HS modes. Among them, the USB OTG FS kernel only supports FS mode, and the USB OTG HS core supports both FS mode and HS mode.
The user selects the appropriate USB core by the following macro:
"USE_USB_HS"// USB High Speed ​​(HS) Core
"USE_USB_FS"// USB Full Speed ​​(FS) Core
"USE_USB_HS" and "USE_USB_HS_IN_FS" // USBHigh Speed ​​(HS) Core in FS mode
5. How to modify or add endpoints in the USB device class driver?
a. Initialize the endpoint using USBD_LL_OpenEP().
b. Configure the transmit or receive FIFO for the newly defined endpoint in usb_conf.c.
Take the MCU that supports the OTG function, such as STM32F2 and STM32F4, as an example.
Configure the TX/RX FIFO with HAL_PCD_SetRxFiFo() and HAL_PCD_SetTxFiFo().
Note that the size of the TX and RX FIFOs must not exceed the full FIFO owned by the corresponding USB core.
The FIFO of the USBOTG FS core is 320 x 32 bits (1.25 Kbytes)
The FIFO of the USBOTG HS core is 1024 x 32bits (4 Kbytes)
For STM32F0, STM32L0, STM32F1 and STM32F3 series that only support FS core,
Use HAL_PCD_PMA_Config() for PMA configuration.
6. Is the USB device library compatible with the real-time operating system?
Yes, this USB device library can be used with RTOS. The wrapper of the CMSIS RTOS implements an abstraction of the OS kernel.
ZGAR AZ Mesh Vape Pods 1.0
ZGAR electronic cigarette uses high-tech R&D, food grade disposable pods and high-quality raw material. A new design of gradient our disposable vape is impressive.We equip with breathing lights in the vape pen and pods.
Our team has very high requirements for product quality, taste allocation and packaging design. Designers only use Hong Kong designers, e-cigarette liquid only imports from the United States, materials are food grade, and assembly factory wants medical grade without ground workshop.
We offer best price, high quality Mesh Pods,Pod System Vape,Pods Systems Touch Screen,Empty Pod System, Pod Vape System,Disposable Pod device,Vape Pods to all over the world.
Pod Systems Vape And Smoke,Vape Pod System Device,Pod System Vape Kit,Pod System Mini Vape Pod
ZGAR INTERNATIONAL TRADING CO., LTD. , https://www.zgarpods.com