ISP example program.

Dependencies:   SLCD mbed USBLocalFileSystem

/media/uploads/va009039/lpc81isp-360x240.jpg

FRDM-KL46ZLPC810
UART RXDPTE23p2(P0_4)
UART TXDPTE22p8(P0_0)
nRESETD6p1(P0_5)
nISPD8p5(P0_1)
GNDGNDp7
3.3VP3V3p6

Copy binary image to the disk called LPC81ISP.
Push sw1 or sw3, start write to LPC810 flash.

Committer:
va009039
Date:
Sun Feb 16 12:56:12 2014 +0000
Revision:
1:cccfc461c61f
add virtual COM.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
va009039 1:cccfc461c61f 1 /* Copyright (c) 2010-2011 mbed.org, MIT License
va009039 1:cccfc461c61f 2 *
va009039 1:cccfc461c61f 3 * Permission is hereby granted, free of charge, to any person obtaining a copy of this software
va009039 1:cccfc461c61f 4 * and associated documentation files (the "Software"), to deal in the Software without
va009039 1:cccfc461c61f 5 * restriction, including without limitation the rights to use, copy, modify, merge, publish,
va009039 1:cccfc461c61f 6 * distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the
va009039 1:cccfc461c61f 7 * Software is furnished to do so, subject to the following conditions:
va009039 1:cccfc461c61f 8 *
va009039 1:cccfc461c61f 9 * The above copyright notice and this permission notice shall be included in all copies or
va009039 1:cccfc461c61f 10 * substantial portions of the Software.
va009039 1:cccfc461c61f 11 *
va009039 1:cccfc461c61f 12 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
va009039 1:cccfc461c61f 13 * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
va009039 1:cccfc461c61f 14 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
va009039 1:cccfc461c61f 15 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
va009039 1:cccfc461c61f 16 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
va009039 1:cccfc461c61f 17 */
va009039 1:cccfc461c61f 18
va009039 1:cccfc461c61f 19 #include "stdint.h"
va009039 1:cccfc461c61f 20 #include "USBMSD2.h"
va009039 1:cccfc461c61f 21 #include "USB_MSD.h"
va009039 1:cccfc461c61f 22 #include "USB_CDC.h"
va009039 1:cccfc461c61f 23 #include "USB_HID.h"
va009039 1:cccfc461c61f 24
va009039 1:cccfc461c61f 25 #if (DEBUG2 > 3)
va009039 1:cccfc461c61f 26 #define USB_DBG(...) do{fprintf(stderr,"[%s@%d] ",__PRETTY_FUNCTION__,__LINE__);fprintf(stderr,__VA_ARGS__);fprintf(stderr,"\r\n");} while(0);
va009039 1:cccfc461c61f 27 #else
va009039 1:cccfc461c61f 28 #define USB_DBG(...) while(0)
va009039 1:cccfc461c61f 29 #endif
va009039 1:cccfc461c61f 30
va009039 1:cccfc461c61f 31 #define DEFAULT_CONFIGURATION (1)
va009039 1:cccfc461c61f 32
va009039 1:cccfc461c61f 33 USBMSD2::USBMSD2(uint16_t vendor_id, uint16_t product_id, uint16_t product_release)
va009039 1:cccfc461c61f 34 : USBDevice(vendor_id, product_id, product_release)
va009039 1:cccfc461c61f 35 {
va009039 1:cccfc461c61f 36 USB_DBG("%p vid=%04x pid=%04x", this, vendor_id, product_id);
va009039 1:cccfc461c61f 37
va009039 1:cccfc461c61f 38 _msd = new USB_MSD(this, this);
va009039 1:cccfc461c61f 39 _cdc = new USB_CDC(this);
va009039 1:cccfc461c61f 40 _hid = new USB_HID(this);
va009039 1:cccfc461c61f 41 }
va009039 1:cccfc461c61f 42
va009039 1:cccfc461c61f 43 USBMSD2::~USBMSD2() {
va009039 1:cccfc461c61f 44 _msd->disconnect();
va009039 1:cccfc461c61f 45 USBDevice::disconnect();
va009039 1:cccfc461c61f 46 }
va009039 1:cccfc461c61f 47
va009039 1:cccfc461c61f 48 void USBMSD2::putc(int c)
va009039 1:cccfc461c61f 49 {
va009039 1:cccfc461c61f 50 _cdc->putc(c);
va009039 1:cccfc461c61f 51 }
va009039 1:cccfc461c61f 52
va009039 1:cccfc461c61f 53 int USBMSD2::getc()
va009039 1:cccfc461c61f 54 {
va009039 1:cccfc461c61f 55 return _cdc->getc();
va009039 1:cccfc461c61f 56 }
va009039 1:cccfc461c61f 57
va009039 1:cccfc461c61f 58 int USBMSD2::readable()
va009039 1:cccfc461c61f 59 {
va009039 1:cccfc461c61f 60 return _cdc->readable();
va009039 1:cccfc461c61f 61 }
va009039 1:cccfc461c61f 62
va009039 1:cccfc461c61f 63 int USBMSD2::writeable()
va009039 1:cccfc461c61f 64 {
va009039 1:cccfc461c61f 65 return _cdc->writeable();
va009039 1:cccfc461c61f 66 }
va009039 1:cccfc461c61f 67
va009039 1:cccfc461c61f 68 bool USBMSD2::readNB(HID_REPORT* report)
va009039 1:cccfc461c61f 69 {
va009039 1:cccfc461c61f 70 return _hid->readNB(report);
va009039 1:cccfc461c61f 71 }
va009039 1:cccfc461c61f 72
va009039 1:cccfc461c61f 73 bool USBMSD2::send(HID_REPORT* report)
va009039 1:cccfc461c61f 74 {
va009039 1:cccfc461c61f 75 return _hid->send(report);
va009039 1:cccfc461c61f 76 }
va009039 1:cccfc461c61f 77
va009039 1:cccfc461c61f 78 bool USBMSD2::connect()
va009039 1:cccfc461c61f 79 {
va009039 1:cccfc461c61f 80 if (_msd->connect()) {
va009039 1:cccfc461c61f 81 USBDevice::connect();
va009039 1:cccfc461c61f 82 return true;
va009039 1:cccfc461c61f 83 }
va009039 1:cccfc461c61f 84 return false;
va009039 1:cccfc461c61f 85 }
va009039 1:cccfc461c61f 86
va009039 1:cccfc461c61f 87 // Called in ISR context to process a class specific request
va009039 1:cccfc461c61f 88 bool USBMSD2::USBCallback_request(void) {
va009039 1:cccfc461c61f 89 CONTROL_TRANSFER* transfer = getTransferPtr();
va009039 1:cccfc461c61f 90 if (_msd->Request_callback(transfer)) {
va009039 1:cccfc461c61f 91 return true;
va009039 1:cccfc461c61f 92 }
va009039 1:cccfc461c61f 93 if (_cdc->Request_callback(transfer)) {
va009039 1:cccfc461c61f 94 return true;
va009039 1:cccfc461c61f 95 }
va009039 1:cccfc461c61f 96 // Find the HID descriptor, after the configuration descriptor
va009039 1:cccfc461c61f 97 uint8_t* hidDescriptor = findDescriptor(HID_DESCRIPTOR);
va009039 1:cccfc461c61f 98 if (_hid->Request_callback(transfer, hidDescriptor)) {
va009039 1:cccfc461c61f 99 return true;
va009039 1:cccfc461c61f 100 }
va009039 1:cccfc461c61f 101 return false;
va009039 1:cccfc461c61f 102 }
va009039 1:cccfc461c61f 103
va009039 1:cccfc461c61f 104 /* virtual */ void USBMSD2::USBCallback_requestCompleted(uint8_t* buf, uint32_t length)
va009039 1:cccfc461c61f 105 {
va009039 1:cccfc461c61f 106 CONTROL_TRANSFER* transfer = getTransferPtr();
va009039 1:cccfc461c61f 107 if (_cdc->RequestCompleted_callback(transfer, buf, length)) {
va009039 1:cccfc461c61f 108 return;
va009039 1:cccfc461c61f 109 }
va009039 1:cccfc461c61f 110 }
va009039 1:cccfc461c61f 111
va009039 1:cccfc461c61f 112 // Called in ISR context
va009039 1:cccfc461c61f 113 // Set configuration. Return false if the
va009039 1:cccfc461c61f 114 // configuration is not supported.
va009039 1:cccfc461c61f 115 bool USBMSD2::USBCallback_setConfiguration(uint8_t configuration) {
va009039 1:cccfc461c61f 116 if (configuration != DEFAULT_CONFIGURATION) {
va009039 1:cccfc461c61f 117 return false;
va009039 1:cccfc461c61f 118 }
va009039 1:cccfc461c61f 119
va009039 1:cccfc461c61f 120 // Configure endpoints > 0
va009039 1:cccfc461c61f 121 addEndpoint(EPBULK_IN, MAX_PACKET_SIZE_EPBULK);
va009039 1:cccfc461c61f 122 addEndpoint(EPBULK_OUT, MAX_PACKET_SIZE_EPBULK);
va009039 1:cccfc461c61f 123
va009039 1:cccfc461c61f 124 addEndpoint(CDC_EPINT_IN, MAX_PACKET_SIZE_EPINT);
va009039 1:cccfc461c61f 125 addEndpoint(CDC_EPBULK_IN, MAX_PACKET_SIZE_EPBULK);
va009039 1:cccfc461c61f 126 addEndpoint(CDC_EPBULK_OUT, MAX_PACKET_SIZE_EPBULK);
va009039 1:cccfc461c61f 127 addEndpoint(HID_EPINT_IN, MAX_PACKET_SIZE_EPINT);
va009039 1:cccfc461c61f 128 addEndpoint(HID_EPINT_OUT, MAX_PACKET_SIZE_EPINT);
va009039 1:cccfc461c61f 129
va009039 1:cccfc461c61f 130 //activate readings
va009039 1:cccfc461c61f 131 readStart(EPBULK_OUT, MAX_PACKET_SIZE_EPBULK);
va009039 1:cccfc461c61f 132 readStart(CDC_EPBULK_OUT, MAX_PACKET_SIZE_EPBULK);
va009039 1:cccfc461c61f 133 readStart(HID_EPINT_OUT, MAX_PACKET_SIZE_EPINT);
va009039 1:cccfc461c61f 134
va009039 1:cccfc461c61f 135 return true;
va009039 1:cccfc461c61f 136 }
va009039 1:cccfc461c61f 137
va009039 1:cccfc461c61f 138 /* virtual */ bool USBMSD2::EP2_OUT_callback()
va009039 1:cccfc461c61f 139 {
va009039 1:cccfc461c61f 140 return _msd->EPBULK_OUT_callback();
va009039 1:cccfc461c61f 141 }
va009039 1:cccfc461c61f 142
va009039 1:cccfc461c61f 143 /* virtual */ bool USBMSD2::EP2_IN_callback() {
va009039 1:cccfc461c61f 144 return _msd->EPBULK_IN_callback();
va009039 1:cccfc461c61f 145 }
va009039 1:cccfc461c61f 146
va009039 1:cccfc461c61f 147 /* virtual */ bool USBMSD2::EP3_OUT_callback()
va009039 1:cccfc461c61f 148 {
va009039 1:cccfc461c61f 149 return _cdc->EPBULK_OUT_callback();
va009039 1:cccfc461c61f 150 }
va009039 1:cccfc461c61f 151
va009039 1:cccfc461c61f 152 /* virtual */ bool USBMSD2::EP5_OUT_callback()
va009039 1:cccfc461c61f 153 {
va009039 1:cccfc461c61f 154 return _cdc->EPBULK_OUT_callback();
va009039 1:cccfc461c61f 155 }
va009039 1:cccfc461c61f 156
va009039 1:cccfc461c61f 157 uint8_t * USBMSD2::deviceDesc() {
va009039 1:cccfc461c61f 158 static uint8_t deviceDescriptor[] = {
va009039 1:cccfc461c61f 159 18, // bLength
va009039 1:cccfc461c61f 160 1, // bDescriptorType
va009039 1:cccfc461c61f 161 0x10, 0x01, // bcdUSB
va009039 1:cccfc461c61f 162 2, // bDeviceClass
va009039 1:cccfc461c61f 163 0, // bDeviceSubClass
va009039 1:cccfc461c61f 164 0, // bDeviceProtocol
va009039 1:cccfc461c61f 165 MAX_PACKET_SIZE_EP0, // bMaxPacketSize0
va009039 1:cccfc461c61f 166 (uint8_t)(LSB(VENDOR_ID)), (uint8_t)(MSB(VENDOR_ID)), // idVendor
va009039 1:cccfc461c61f 167 (uint8_t)(LSB(PRODUCT_ID)), (uint8_t)(MSB(PRODUCT_ID)),// idProduct
va009039 1:cccfc461c61f 168 0x00, 0x01, // bcdDevice
va009039 1:cccfc461c61f 169 1, // iManufacturer
va009039 1:cccfc461c61f 170 2, // iProduct
va009039 1:cccfc461c61f 171 3, // iSerialNumber
va009039 1:cccfc461c61f 172 1 // bNumConfigurations
va009039 1:cccfc461c61f 173 };
va009039 1:cccfc461c61f 174 return deviceDescriptor;
va009039 1:cccfc461c61f 175 }
va009039 1:cccfc461c61f 176
va009039 1:cccfc461c61f 177 uint8_t * USBMSD2::stringIinterfaceDesc() {
va009039 1:cccfc461c61f 178 static uint8_t stringIinterfaceDescriptor[] = {
va009039 1:cccfc461c61f 179 0x08, //bLength
va009039 1:cccfc461c61f 180 STRING_DESCRIPTOR, //bDescriptorType 0x03
va009039 1:cccfc461c61f 181 'H',0,'I',0,'D',0, //bString iInterface - HID
va009039 1:cccfc461c61f 182 };
va009039 1:cccfc461c61f 183 return stringIinterfaceDescriptor;
va009039 1:cccfc461c61f 184 }
va009039 1:cccfc461c61f 185
va009039 1:cccfc461c61f 186 uint8_t * USBMSD2::stringIproductDesc() {
va009039 1:cccfc461c61f 187 static uint8_t stringIproductDescriptor[] = {
va009039 1:cccfc461c61f 188 32, //bLength
va009039 1:cccfc461c61f 189 STRING_DESCRIPTOR, //bDescriptorType 0x03
va009039 1:cccfc461c61f 190 'K',0,'L',0,'2',0,'5',0,'Z',0,' ',0,'C',0,'M',0,'S',0,'I',0,'S',0,'-',0,'D',0,'A',0,'P',0 // KL25Z CMSIS-DAP
va009039 1:cccfc461c61f 191 };
va009039 1:cccfc461c61f 192 return stringIproductDescriptor;
va009039 1:cccfc461c61f 193 }
va009039 1:cccfc461c61f 194
va009039 1:cccfc461c61f 195 uint8_t * USBMSD2::configurationDesc() {
va009039 1:cccfc461c61f 196 static uint8_t configDescriptor[] = {
va009039 1:cccfc461c61f 197 // Configuration 1
va009039 1:cccfc461c61f 198 9, // bLength
va009039 1:cccfc461c61f 199 2, // bDescriptorType
va009039 1:cccfc461c61f 200 LSB(122), // wTotalLength
va009039 1:cccfc461c61f 201 MSB(122),
va009039 1:cccfc461c61f 202 4, // bNumInterfaces
va009039 1:cccfc461c61f 203 1, // bConfigurationValue: 0x01 is used to select this configuration
va009039 1:cccfc461c61f 204 0x00, // iConfiguration: no string to describe this configuration
va009039 1:cccfc461c61f 205 0x80, // bmAttributes
va009039 1:cccfc461c61f 206 250, // bMaxPower, device power consumption is 100 mA
va009039 1:cccfc461c61f 207
va009039 1:cccfc461c61f 208 // Interface 0, Alternate Setting 0, MSC Class
va009039 1:cccfc461c61f 209 INTERFACE_DESCRIPTOR_LENGTH, // bLength
va009039 1:cccfc461c61f 210 INTERFACE_DESCRIPTOR, // bDescriptorType
va009039 1:cccfc461c61f 211 0, // bInterfaceNumber
va009039 1:cccfc461c61f 212 0, // bAlternateSetting
va009039 1:cccfc461c61f 213 2, // bNumEndpoints
va009039 1:cccfc461c61f 214 0x08, // bInterfaceClass
va009039 1:cccfc461c61f 215 0x06, // bInterfaceSubClass
va009039 1:cccfc461c61f 216 0x50, // bInterfaceProtocol
va009039 1:cccfc461c61f 217 0x04, // iInterface
va009039 1:cccfc461c61f 218
va009039 1:cccfc461c61f 219 // endpoint descriptor, USB spec 9.6.6, page 269-271, Table 9-13
va009039 1:cccfc461c61f 220 ENDPOINT_DESCRIPTOR_LENGTH, // bLength
va009039 1:cccfc461c61f 221 ENDPOINT_DESCRIPTOR, // bDescriptorType
va009039 1:cccfc461c61f 222 PHY_TO_DESC(EPBULK_IN), // bEndpointAddress
va009039 1:cccfc461c61f 223 E_BULK, // bmAttributes (0x02=bulk)
va009039 1:cccfc461c61f 224 LSB(MAX_PACKET_SIZE_EPBULK),// wMaxPacketSize (LSB)
va009039 1:cccfc461c61f 225 MSB(MAX_PACKET_SIZE_EPBULK),// wMaxPacketSize (MSB)
va009039 1:cccfc461c61f 226 0, // bInterval
va009039 1:cccfc461c61f 227
va009039 1:cccfc461c61f 228 // endpoint descriptor, USB spec 9.6.6, page 269-271, Table 9-13
va009039 1:cccfc461c61f 229 ENDPOINT_DESCRIPTOR_LENGTH, // bLength
va009039 1:cccfc461c61f 230 ENDPOINT_DESCRIPTOR, // bDescriptorType
va009039 1:cccfc461c61f 231 PHY_TO_DESC(EPBULK_OUT), // bEndpointAddress
va009039 1:cccfc461c61f 232 E_BULK, // bmAttributes (0x02=bulk)
va009039 1:cccfc461c61f 233 LSB(MAX_PACKET_SIZE_EPBULK),// wMaxPacketSize (LSB)
va009039 1:cccfc461c61f 234 MSB(MAX_PACKET_SIZE_EPBULK),// wMaxPacketSize (MSB)
va009039 1:cccfc461c61f 235 0, // bInterval
va009039 1:cccfc461c61f 236
va009039 1:cccfc461c61f 237 // interface descriptor, USB spec 9.6.5, page 267-269, Table 9-12
va009039 1:cccfc461c61f 238 INTERFACE_DESCRIPTOR_LENGTH, // bLength
va009039 1:cccfc461c61f 239 INTERFACE_DESCRIPTOR, // bDescriptorType
va009039 1:cccfc461c61f 240 1, // bInterfaceNumber
va009039 1:cccfc461c61f 241 0, // bAlternateSetting
va009039 1:cccfc461c61f 242 1, // bNumEndpoints
va009039 1:cccfc461c61f 243 0x02, // bInterfaceClass
va009039 1:cccfc461c61f 244 0x02, // bInterfaceSubClass
va009039 1:cccfc461c61f 245 0x01, // bInterfaceProtocol
va009039 1:cccfc461c61f 246 0, // iInterface
va009039 1:cccfc461c61f 247
va009039 1:cccfc461c61f 248 // CDC Header Functional Descriptor, CDC Spec 5.2.3.1, Table 26
va009039 1:cccfc461c61f 249 5, // bFunctionLength
va009039 1:cccfc461c61f 250 0x24, // bDescriptorType
va009039 1:cccfc461c61f 251 0x00, // bDescriptorSubtype
va009039 1:cccfc461c61f 252 0x10, 0x01, // bcdCDC
va009039 1:cccfc461c61f 253
va009039 1:cccfc461c61f 254 // Call Management Functional Descriptor, CDC Spec 5.2.3.2, Table 27
va009039 1:cccfc461c61f 255 5, // bFunctionLength
va009039 1:cccfc461c61f 256 0x24, // bDescriptorType
va009039 1:cccfc461c61f 257 0x01, // bDescriptorSubtype
va009039 1:cccfc461c61f 258 0x03, // bmCapabilities
va009039 1:cccfc461c61f 259 2, // bDataInterface
va009039 1:cccfc461c61f 260
va009039 1:cccfc461c61f 261 // Abstract Control Management Functional Descriptor, CDC Spec 5.2.3.3, Table 28
va009039 1:cccfc461c61f 262 4, // bFunctionLength
va009039 1:cccfc461c61f 263 0x24, // bDescriptorType
va009039 1:cccfc461c61f 264 0x02, // bDescriptorSubtype
va009039 1:cccfc461c61f 265 0x06, // bmCapabilities
va009039 1:cccfc461c61f 266
va009039 1:cccfc461c61f 267 // Union Functional Descriptor, CDC Spec 5.2.3.8, Table 33
va009039 1:cccfc461c61f 268 5, // bFunctionLength
va009039 1:cccfc461c61f 269 0x24, // bDescriptorType
va009039 1:cccfc461c61f 270 0x06, // bDescriptorSubtype
va009039 1:cccfc461c61f 271 1, // bMasterInterface
va009039 1:cccfc461c61f 272 2, // bSlaveInterface0
va009039 1:cccfc461c61f 273
va009039 1:cccfc461c61f 274 // endpoint descriptor, USB spec 9.6.6, page 269-271, Table 9-13
va009039 1:cccfc461c61f 275 ENDPOINT_DESCRIPTOR_LENGTH, // bLength
va009039 1:cccfc461c61f 276 ENDPOINT_DESCRIPTOR, // bDescriptorType
va009039 1:cccfc461c61f 277 PHY_TO_DESC(CDC_EPINT_IN), // bEndpointAddress
va009039 1:cccfc461c61f 278 E_INTERRUPT, // bmAttributes (0x03=intr)
va009039 1:cccfc461c61f 279 LSB(MAX_PACKET_SIZE_EPINT), // wMaxPacketSize (LSB)
va009039 1:cccfc461c61f 280 MSB(MAX_PACKET_SIZE_EPINT), // wMaxPacketSize (MSB)
va009039 1:cccfc461c61f 281 2, // bInterval
va009039 1:cccfc461c61f 282
va009039 1:cccfc461c61f 283 // interface descriptor, USB spec 9.6.5, page 267-269, Table 9-12
va009039 1:cccfc461c61f 284 INTERFACE_DESCRIPTOR_LENGTH, // bLength
va009039 1:cccfc461c61f 285 INTERFACE_DESCRIPTOR, // bDescriptorType
va009039 1:cccfc461c61f 286 2, // bInterfaceNumber
va009039 1:cccfc461c61f 287 0, // bAlternateSetting
va009039 1:cccfc461c61f 288 2, // bNumEndpoints
va009039 1:cccfc461c61f 289 0x0A, // bInterfaceClass
va009039 1:cccfc461c61f 290 0x00, // bInterfaceSubClass
va009039 1:cccfc461c61f 291 0x00, // bInterfaceProtocol
va009039 1:cccfc461c61f 292 0, // iInterface
va009039 1:cccfc461c61f 293
va009039 1:cccfc461c61f 294 // endpoint descriptor, USB spec 9.6.6, page 269-271, Table 9-13
va009039 1:cccfc461c61f 295 ENDPOINT_DESCRIPTOR_LENGTH, // bLength
va009039 1:cccfc461c61f 296 ENDPOINT_DESCRIPTOR, // bDescriptorType
va009039 1:cccfc461c61f 297 PHY_TO_DESC(CDC_EPBULK_IN), // bEndpointAddress
va009039 1:cccfc461c61f 298 E_BULK, // bmAttributes (0x02=bulk)
va009039 1:cccfc461c61f 299 LSB(MAX_PACKET_SIZE_EPBULK),// wMaxPacketSize (LSB)
va009039 1:cccfc461c61f 300 MSB(MAX_PACKET_SIZE_EPBULK),// wMaxPacketSize (MSB)
va009039 1:cccfc461c61f 301 0, // bInterval
va009039 1:cccfc461c61f 302
va009039 1:cccfc461c61f 303 // endpoint descriptor, USB spec 9.6.6, page 269-271, Table 9-13
va009039 1:cccfc461c61f 304 ENDPOINT_DESCRIPTOR_LENGTH, // bLength
va009039 1:cccfc461c61f 305 ENDPOINT_DESCRIPTOR, // bDescriptorType
va009039 1:cccfc461c61f 306 PHY_TO_DESC(CDC_EPBULK_OUT),// bEndpointAddress
va009039 1:cccfc461c61f 307 E_BULK, // bmAttributes (0x02=bulk)
va009039 1:cccfc461c61f 308 LSB(MAX_PACKET_SIZE_EPBULK),// wMaxPacketSize (LSB)
va009039 1:cccfc461c61f 309 MSB(MAX_PACKET_SIZE_EPBULK),// wMaxPacketSize (MSB)
va009039 1:cccfc461c61f 310 0, // bInterval
va009039 1:cccfc461c61f 311
va009039 1:cccfc461c61f 312 INTERFACE_DESCRIPTOR_LENGTH, // bLength
va009039 1:cccfc461c61f 313 INTERFACE_DESCRIPTOR, // bDescriptorType
va009039 1:cccfc461c61f 314 3, // bInterfaceNumber
va009039 1:cccfc461c61f 315 0, // bAlternateSetting
va009039 1:cccfc461c61f 316 2, // bNumEndpoints
va009039 1:cccfc461c61f 317 HID_CLASS, // bInterfaceClass
va009039 1:cccfc461c61f 318 HID_SUBCLASS_NONE, // bInterfaceSubClass
va009039 1:cccfc461c61f 319 HID_PROTOCOL_NONE, // bInterfaceProtocol
va009039 1:cccfc461c61f 320 0, // iInterface
va009039 1:cccfc461c61f 321
va009039 1:cccfc461c61f 322 HID_DESCRIPTOR_LENGTH, // bLength
va009039 1:cccfc461c61f 323 HID_DESCRIPTOR, // bDescriptorType
va009039 1:cccfc461c61f 324 LSB(HID_VERSION_1_11), // bcdHID (LSB)
va009039 1:cccfc461c61f 325 MSB(HID_VERSION_1_11), // bcdHID (MSB)
va009039 1:cccfc461c61f 326 0x00, // bCountryCode
va009039 1:cccfc461c61f 327 1, // bNumDescriptors
va009039 1:cccfc461c61f 328 REPORT_DESCRIPTOR, // bDescriptorType
va009039 1:cccfc461c61f 329 LSB(_hid->reportDescLength()), // wDescriptorLength (LSB)
va009039 1:cccfc461c61f 330 MSB(_hid->reportDescLength()), // wDescriptorLength (MSB)
va009039 1:cccfc461c61f 331
va009039 1:cccfc461c61f 332 ENDPOINT_DESCRIPTOR_LENGTH, // bLength
va009039 1:cccfc461c61f 333 ENDPOINT_DESCRIPTOR, // bDescriptorType
va009039 1:cccfc461c61f 334 PHY_TO_DESC(HID_EPINT_IN), // bEndpointAddress
va009039 1:cccfc461c61f 335 E_INTERRUPT, // bmAttributes
va009039 1:cccfc461c61f 336 LSB(MAX_PACKET_SIZE_EPINT), // wMaxPacketSize (LSB)
va009039 1:cccfc461c61f 337 MSB(MAX_PACKET_SIZE_EPINT), // wMaxPacketSize (MSB)
va009039 1:cccfc461c61f 338 1, // bInterval (milliseconds)
va009039 1:cccfc461c61f 339
va009039 1:cccfc461c61f 340 ENDPOINT_DESCRIPTOR_LENGTH, // bLength
va009039 1:cccfc461c61f 341 ENDPOINT_DESCRIPTOR, // bDescriptorType
va009039 1:cccfc461c61f 342 PHY_TO_DESC(HID_EPINT_OUT), // bEndpointAddress
va009039 1:cccfc461c61f 343 E_INTERRUPT, // bmAttributes
va009039 1:cccfc461c61f 344 LSB(MAX_PACKET_SIZE_EPINT), // wMaxPacketSize (LSB)
va009039 1:cccfc461c61f 345 MSB(MAX_PACKET_SIZE_EPINT), // wMaxPacketSize (MSB)
va009039 1:cccfc461c61f 346 1, // bInterval (milliseconds)
va009039 1:cccfc461c61f 347 };
va009039 1:cccfc461c61f 348 return configDescriptor;
va009039 1:cccfc461c61f 349 }