1 /* Copyright (c) 2010-2012 mbed.org, MIT License
3 * Permission is hereby granted, free of charge, to any person obtaining a copy of this software
4 * and associated documentation files (the "Software"), to deal in the Software without
5 * restriction, including without limitation the rights to use, copy, modify, merge, publish,
6 * distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the
7 * Software is furnished to do so, subject to the following conditions:
9 * The above copyright notice and this permission notice shall be included in all copies or
10 * substantial portions of the Software.
12 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
13 * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
14 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
15 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
16 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
22 #include "USBHostConf.h"
24 #ifdef USBHOST_3GMODULE
27 #include "IUSBHostSerial.h"
31 #include "WANDongleSerialPort.h"
32 #include "WANDongleInitializer.h"
33 #include "IUSBEnumerator.h"
35 #define WANDONGLE_MAX_OUTEP_SIZE 64
36 #define WANDONGLE_MAX_INEP_SIZE 64
38 /** A class to use a WAN (3G/LTE) access dongle
41 class WANDongle
: public IUSBEnumerator
{
46 * @param rootdir mount name
56 * Check if a serial port device is connected
58 * @return true if a serial device is connected
63 * Try to connect device
65 * * @return true if connection was successful
72 * * @return true if disconnection was successful
78 IUSBHostSerial
& getSerial(int index
);
80 bool addInitializer(WANDongleInitializer
* pInitializer
);
84 virtual void setVidPid(uint16_t vid
, uint16_t pid
);
86 virtual bool parseInterface(uint8_t intf_nb
, uint8_t intf_class
, uint8_t intf_subclass
, uint8_t intf_protocol
); //Must return true if the interface should be parsed
88 virtual bool useEndpoint(uint8_t intf_nb
, ENDPOINT_TYPE type
, ENDPOINT_DIRECTION dir
); //Must return true if the endpoint will be used
92 USBDeviceConnected
* dev
;
95 WANDongleInitializer
* m_pInitializer
;
99 WANDongleSerialPort m_serial
[WANDONGLE_MAX_SERIAL_PORTS
];
102 int m_totalInitializers
;
103 WANDongleInitializer
* m_Initializers
[WANDONGLE_MAX_INITIALIZERS
];
106 #endif /* USBHOST_3GMODULE */