2018.07.26
Dependencies: FATFileSystem3 mbed-rtos
Fork of USBHost by
USBHostSerial/USBHostSerial.h@3:0f5c32575eb8, 2013-03-06 (annotated)
- Committer:
- samux
- Date:
- Wed Mar 06 17:50:07 2013 +0000
- Revision:
- 3:0f5c32575eb8
- Parent:
- 2:5e8fdc541b98
- Child:
- 4:b320d68e98e7
update doxygen
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
mbed_official | 0:a554658735bf | 1 | /* Copyright (c) 2010-2011 mbed.org, MIT License |
mbed_official | 0:a554658735bf | 2 | * |
mbed_official | 0:a554658735bf | 3 | * Permission is hereby granted, free of charge, to any person obtaining a copy of this software |
mbed_official | 0:a554658735bf | 4 | * and associated documentation files (the "Software"), to deal in the Software without |
mbed_official | 0:a554658735bf | 5 | * restriction, including without limitation the rights to use, copy, modify, merge, publish, |
mbed_official | 0:a554658735bf | 6 | * distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the |
mbed_official | 0:a554658735bf | 7 | * Software is furnished to do so, subject to the following conditions: |
mbed_official | 0:a554658735bf | 8 | * |
mbed_official | 0:a554658735bf | 9 | * The above copyright notice and this permission notice shall be included in all copies or |
mbed_official | 0:a554658735bf | 10 | * substantial portions of the Software. |
mbed_official | 0:a554658735bf | 11 | * |
mbed_official | 0:a554658735bf | 12 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING |
mbed_official | 0:a554658735bf | 13 | * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND |
mbed_official | 0:a554658735bf | 14 | * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, |
mbed_official | 0:a554658735bf | 15 | * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, |
mbed_official | 0:a554658735bf | 16 | * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
mbed_official | 0:a554658735bf | 17 | */ |
mbed_official | 0:a554658735bf | 18 | |
mbed_official | 0:a554658735bf | 19 | #ifndef USBHOSTSERIAL_H |
mbed_official | 0:a554658735bf | 20 | #define USBHOSTSERIAL_H |
mbed_official | 0:a554658735bf | 21 | |
mbed_official | 0:a554658735bf | 22 | #include "USBHostConf.h" |
mbed_official | 0:a554658735bf | 23 | |
mbed_official | 0:a554658735bf | 24 | #if USBHOST_SERIAL |
mbed_official | 0:a554658735bf | 25 | |
mbed_official | 0:a554658735bf | 26 | #include "USBHost.h" |
mbed_official | 0:a554658735bf | 27 | #include "Stream.h" |
mbed_official | 0:a554658735bf | 28 | #include "MtxCircBuffer.h" |
mbed_official | 0:a554658735bf | 29 | |
samux | 1:0a457e34fa9e | 30 | /** |
samux | 1:0a457e34fa9e | 31 | * A class to communicate a USB virtual serial port |
samux | 1:0a457e34fa9e | 32 | */ |
mbed_official | 0:a554658735bf | 33 | class USBHostSerial : public IUSBEnumerator, public Stream { |
mbed_official | 0:a554658735bf | 34 | public: |
mbed_official | 0:a554658735bf | 35 | /** |
mbed_official | 0:a554658735bf | 36 | * Constructor |
mbed_official | 0:a554658735bf | 37 | */ |
mbed_official | 0:a554658735bf | 38 | USBHostSerial(); |
mbed_official | 0:a554658735bf | 39 | |
mbed_official | 0:a554658735bf | 40 | enum IrqType { |
mbed_official | 0:a554658735bf | 41 | RxIrq, |
mbed_official | 0:a554658735bf | 42 | TxIrq |
mbed_official | 0:a554658735bf | 43 | }; |
mbed_official | 0:a554658735bf | 44 | |
mbed_official | 0:a554658735bf | 45 | /** |
mbed_official | 0:a554658735bf | 46 | * Check if a virtual serial port is connected |
mbed_official | 0:a554658735bf | 47 | * |
mbed_official | 0:a554658735bf | 48 | * @returns true if a serial device is connected |
mbed_official | 0:a554658735bf | 49 | */ |
mbed_official | 0:a554658735bf | 50 | bool connected(); |
mbed_official | 0:a554658735bf | 51 | |
mbed_official | 0:a554658735bf | 52 | /** |
mbed_official | 0:a554658735bf | 53 | * Try to connect a serial device |
mbed_official | 0:a554658735bf | 54 | * |
samux | 3:0f5c32575eb8 | 55 | * @return true if connection was successful |
mbed_official | 0:a554658735bf | 56 | */ |
mbed_official | 0:a554658735bf | 57 | bool connect(); |
mbed_official | 0:a554658735bf | 58 | |
mbed_official | 0:a554658735bf | 59 | /** |
mbed_official | 0:a554658735bf | 60 | * Check the number of bytes available. |
mbed_official | 0:a554658735bf | 61 | * |
mbed_official | 0:a554658735bf | 62 | * @returns the number of bytes available |
mbed_official | 0:a554658735bf | 63 | */ |
mbed_official | 0:a554658735bf | 64 | uint8_t available(); |
mbed_official | 0:a554658735bf | 65 | |
mbed_official | 0:a554658735bf | 66 | /** |
mbed_official | 0:a554658735bf | 67 | * Attach a member function to call when a packet is received. |
mbed_official | 0:a554658735bf | 68 | * |
mbed_official | 0:a554658735bf | 69 | * @param tptr pointer to the object to call the member function on |
mbed_official | 0:a554658735bf | 70 | * @param mptr pointer to the member function to be called |
samux | 2:5e8fdc541b98 | 71 | * @param irq irq type |
mbed_official | 0:a554658735bf | 72 | */ |
mbed_official | 0:a554658735bf | 73 | template<typename T> |
mbed_official | 0:a554658735bf | 74 | inline void attach(T* tptr, void (T::*mptr)(void), IrqType irq = RxIrq) { |
mbed_official | 0:a554658735bf | 75 | if ((mptr != NULL) && (tptr != NULL)) { |
mbed_official | 0:a554658735bf | 76 | if (irq == RxIrq) { |
mbed_official | 0:a554658735bf | 77 | rx.attach(tptr, mptr); |
mbed_official | 0:a554658735bf | 78 | } else { |
mbed_official | 0:a554658735bf | 79 | tx.attach(tptr, mptr); |
mbed_official | 0:a554658735bf | 80 | } |
mbed_official | 0:a554658735bf | 81 | } |
mbed_official | 0:a554658735bf | 82 | } |
mbed_official | 0:a554658735bf | 83 | |
mbed_official | 0:a554658735bf | 84 | /** |
mbed_official | 0:a554658735bf | 85 | * Attach a callback called when a packet is received |
mbed_official | 0:a554658735bf | 86 | * |
samux | 2:5e8fdc541b98 | 87 | * @param ptr function pointer |
mbed_official | 0:a554658735bf | 88 | */ |
mbed_official | 0:a554658735bf | 89 | inline void attach(void (*fn)(void), IrqType irq = RxIrq) { |
mbed_official | 0:a554658735bf | 90 | if (fn != NULL) { |
mbed_official | 0:a554658735bf | 91 | if (irq == RxIrq) { |
mbed_official | 0:a554658735bf | 92 | rx.attach(fn); |
mbed_official | 0:a554658735bf | 93 | } else { |
mbed_official | 0:a554658735bf | 94 | tx.attach(fn); |
mbed_official | 0:a554658735bf | 95 | } |
mbed_official | 0:a554658735bf | 96 | } |
mbed_official | 0:a554658735bf | 97 | } |
mbed_official | 0:a554658735bf | 98 | |
mbed_official | 0:a554658735bf | 99 | |
mbed_official | 0:a554658735bf | 100 | protected: |
mbed_official | 0:a554658735bf | 101 | //From IUSBEnumerator |
mbed_official | 0:a554658735bf | 102 | virtual void setVidPid(uint16_t vid, uint16_t pid); |
mbed_official | 0:a554658735bf | 103 | 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 |
mbed_official | 0:a554658735bf | 104 | virtual bool useEndpoint(uint8_t intf_nb, ENDPOINT_TYPE type, ENDPOINT_DIRECTION dir); //Must return true if the endpoint will be used |
mbed_official | 0:a554658735bf | 105 | |
mbed_official | 0:a554658735bf | 106 | virtual int _getc(); |
mbed_official | 0:a554658735bf | 107 | virtual int _putc(int c); |
mbed_official | 0:a554658735bf | 108 | |
mbed_official | 0:a554658735bf | 109 | private: |
mbed_official | 0:a554658735bf | 110 | USBHost * host; |
mbed_official | 0:a554658735bf | 111 | USBDeviceConnected * dev; |
mbed_official | 0:a554658735bf | 112 | USBEndpoint * bulk_in; |
mbed_official | 0:a554658735bf | 113 | USBEndpoint * bulk_out; |
mbed_official | 0:a554658735bf | 114 | uint32_t size_bulk_in; |
mbed_official | 0:a554658735bf | 115 | uint32_t size_bulk_out; |
mbed_official | 0:a554658735bf | 116 | |
mbed_official | 0:a554658735bf | 117 | bool dev_connected; |
mbed_official | 0:a554658735bf | 118 | |
mbed_official | 0:a554658735bf | 119 | void init(); |
mbed_official | 0:a554658735bf | 120 | |
mbed_official | 0:a554658735bf | 121 | MtxCircBuffer<uint8_t, 64> circ_buf; |
mbed_official | 0:a554658735bf | 122 | |
mbed_official | 0:a554658735bf | 123 | uint8_t buf[64]; |
mbed_official | 0:a554658735bf | 124 | |
mbed_official | 0:a554658735bf | 125 | void rxHandler(); |
mbed_official | 0:a554658735bf | 126 | void txHandler(); |
mbed_official | 0:a554658735bf | 127 | FunctionPointer rx; |
mbed_official | 0:a554658735bf | 128 | FunctionPointer tx; |
mbed_official | 0:a554658735bf | 129 | |
mbed_official | 0:a554658735bf | 130 | int serial_intf; |
mbed_official | 0:a554658735bf | 131 | bool serial_device_found; |
mbed_official | 0:a554658735bf | 132 | |
mbed_official | 0:a554658735bf | 133 | }; |
mbed_official | 0:a554658735bf | 134 | |
mbed_official | 0:a554658735bf | 135 | #endif |
mbed_official | 0:a554658735bf | 136 | |
mbed_official | 0:a554658735bf | 137 | #endif |
mbed_official | 0:a554658735bf | 138 |