/* This file is the part of the LUS32 project * * Copyright ©2016 Dmitry Filimonchuk * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * http://www.apache.org/licenses/LICENSE-2.0 * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /** \ingroup USB_CDC * \addtogroup USB_CDC_ATM USB CDC ATM subclass * \brief USB CDC ATM subclass definitions * \details This module based on "Universal Serial Bus Communications Class Subclass Specification for Asynchronous Transfer Mode Devices" Revision 1.2 * @{ */ #ifndef _USB_CDC_ATM_H_ #define _USB_CDC_ATM_H_ #ifdef __cplusplus extern "C" { #endif /**\name Communications Class Subclass Codes * @{ */ #define USB_CDC_SUBCLASS_ATM 0x07 /**< ATM Networking Control Model */ /* @} */ /**\name CDC ATM subclass specific Functional Descriptors codes * @{ */ #define USB_DTYPE_CDC_ATM 0x10 /**< ATM Networking Functional Descriptor */ /** @} */ /**\name CDC ATM subclass specific requests * @{ */ #define USB_CDC_SET_ATM_DATA_FORMAT 0x50 /**< Chooses which ATM data format will be exchanged between the host and the ATM Networking device. */ #define USB_CDC_GET_ATM_DEVICE_STATISTICS 0x51 /**< Retrieves global statistics from the ATM Networking device. */ #define USB_CDC_SET_ATM_DEFAULT_VC 0x52 /**< Pre-selects the VPI/VCI value for subsequent GET_ATM_DEVICE_STATISTICS requests */ #define USB_CDC_GET_ATM_VC_STATISTICS 0x53 /**< Retrieves statistics from the ATM Networking device for a particular VPI/VCI. */ /** @} */ /**\name ATM Device Statistics Feature Selector Codes * @{ */ #define ATM_STAT_US_CELLS_SENT 0x01 /**< The number of cells that have been sent upstream to the WAN link by the ATM layer. */ #define ATM_STAT_DS_CELLS_RECEIVED 0x02 /**< The number of cells that have been received downstream from the WAN link by the ATM layer */ #define ATM_STAT_DS_CELLS_USB_CONGESTION 0x03 /**< The number of cells that have been received downstream from the WAN link by the ATM * layer and discarded due to congestion on the USB link. */ #define ATM_STAT_DS_CELLS_AAL5_CRC_ERROR 0x04 /**< The number of cells that have been received downstream from the WAN link by the ATM * layer and discarded due to AAL5 CRC errors. */ #define ATM_STAT_DS_CELLS_HEC_ERROR 0x05 /**< The number of cells that have been received downstream from the WAN link and discarded * due to HEC errors in the cell header. */ #define ATM_STAT_DS_CELLS_HEC_ERROR_CORRT 0x06 /**< The number of cells that have been received downstream from the WAN link and have * been detected with HEC errors in the cell header and successfully corrected. */ /** @} */ /**\brief ATM Networking Functional Descriptor */ struct usb_cdc_atm_desc { uint8_t bFunctionLength; /**< Size of this functional descriptor, in bytes. */ uint8_t bDescriptorType; /**< CS_INTERFACE descriptor type. \see \ref USB_DTYPE_CS_INTERFACE */ uint8_t bDescriptorSubType; /**< ATM Networking Functional Descriptor subtype \ref USB_DTYPE_CDC_ATM */ uint8_t iEndSystemIdentifier; /**< The string descriptor holds the End System Identifier. */ uint8_t bmDataCapabilities; /**< The ATM data types the device supports */ uint8_t bmATMDeviceStatistics; /**< Indicates which optional statistics functions the device collects. */ uint16_t wType2MaxSegmentSize; /**< The maximum segment size that the Type 2 device is capable of supporting */ uint16_t wType3MaxSegmentSize; /**< The maximum segment size that the Type 3 device is capable of supporting */ uint16_t wMaxVC; /**< The maximum number of simultaneous virtual circuits the device is capable * of supporting (Type 3 only) */ } __attribute__((packed)); /** @} */ #ifdef __cplusplus } #endif #endif /* _USB_CDC_ATM_H_ */