12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697 |
- /*!
- \file usbd_conf.h
- \brief usb device driver basic configuration
- \version 2023-06-30, V2.1.6, firmware for GD32F30x
- */
- /*
- Copyright (c) 2023, GigaDevice Semiconductor Inc.
- Redistribution and use in source and binary forms, with or without modification,
- are permitted provided that the following conditions are met:
- 1. Redistributions of source code must retain the above copyright notice, this
- list of conditions and the following disclaimer.
- 2. Redistributions in binary form must reproduce the above copyright notice,
- this list of conditions and the following disclaimer in the documentation
- and/or other materials provided with the distribution.
- 3. Neither the name of the copyright holder nor the names of its contributors
- may be used to endorse or promote products derived from this software without
- specific prior written permission.
- THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
- AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
- WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
- IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
- INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
- NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
- PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
- WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
- ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
- OF SUCH DAMAGE.
- */
- #ifndef USBD_CONF_H
- #define USBD_CONF_H
- #include "gd32f30x.h"
- #include "gd32f303e_eval.h"
- #define USBD_CFG_MAX_NUM 1U
- #define USBD_ITF_MAX_NUM 4U
- /* define if low power mode is enabled; it allows entering the device into DEEP_SLEEP mode
- following USB suspend event and wakes up after the USB wakeup event is received. */
- //#define USB_DEVICE_LOW_PWR_MODE_SUPPORT
- /* USB feature -- Self Powered */
- /* #define USBD_SELF_POWERED */
- /* endpoint count used by the CDC ACM device 0 */
- #define CDC_ACM0_CMD_EP EP_IN(3U)
- #define CDC_ACM0_DATA_IN_EP EP_IN(1U)
- #define CDC_ACM0_DATA_OUT_EP EP_OUT(1U)
- /* endpoint count used by the CDC ACM device 1 */
- #define CDC_ACM1_CMD_EP EP_IN(4U)
- #define CDC_ACM1_DATA_IN_EP EP_IN(2U)
- #define CDC_ACM1_DATA_OUT_EP EP_OUT(2U)
- /* endpoint0, Rx/Tx buffers address offset */
- #define EP0_RX_ADDR (0x40U)
- #define EP0_TX_ADDR (0x80U)
- /* CDC0 data Tx buffer address offset */
- #define BULK0_TX_ADDR (0x110U)
- /* CDC0 data Rx buffer address offset */
- #define BULK0_RX_ADDR (0xD0U)
- /* CDC0 command Tx buffer address offset */
- #define INT0_TX_ADDR (0xC0U)
- /* CDC0 data Tx buffer address offset */
- #define BULK1_TX_ADDR (0x1A0U)
- /* CDC0 data Rx buffer address offset */
- #define BULK1_RX_ADDR (0x160U)
- /* CDC0 command Tx buffer address offset */
- #define INT1_TX_ADDR (0x120U)
- #define CDC_ACM_CMD_PACKET_SIZE 8U
- #define CDC_ACM_DATA_PACKET_SIZE 64U
- /* endpoint count used by the CDC ACM device */
- #define EP_COUNT (5U)
- #define USB_STRING_COUNT 4U
- /* base address offset of the allocation buffer, used for buffer descriptor table and packet memory */
- #define BTABLE_OFFSET (0x0000U)
- #define USB_PULLUP GPIOG
- #define USB_PULLUP_PIN GPIO_PIN_8
- #define RCU_AHBPeriph_GPIO_PULLUP RCU_GPIOG
- #endif /* USBD_CONF_H */
|