Library to use Arduino USB host shield on mbed
ArduinoのUSB Host Shield 2.0をmbedで使えるようにしたライブラリです。
大体のコードがArduinoからそのまま移植可能です。
Arduino UNOやMega用のホストシールド以外にもミニサイズのホストシールドでも使用可能です
シールドについて
3.3VのI/O用にシールドの改造が必要になりますがネット上に記事がたくさんあるのでそちらを参考にしてください
接続例
使い方
Arduinoのコードと違うのはUSBのインスタンスの宣言部分のみです。
ピンを自分で指定できるようにしたので使いやすくなりました。
仕様
- Arduinoのmillis関数、micros関数の移植のために内部でTimerクラスを使用しています。
main.cpp
#include "mbed.h" #include <PS3BT.h> #include <usbhub.h> Serial pc(USBTX, USBRX, 115200); //Nucleo f303k8用 USB Usb(A6, A5, A4, A3, A2); // mosi, miso, sclk, ssel, intr BTD Btd(&Usb); PS3BT PS3(&Btd); int main() { bool printAngle = false; if (Usb.Init() == -1) { pc.printf("\r\nOSC did not start"); while (1); // Halt } pc.printf("\r\nPS3 USB Library Started"); while (1) { Usb.Task(); if (PS3.PS3Connected || PS3.PS3NavigationConnected) { if (PS3.getAnalogHat(LeftHatX) > 137 || PS3.getAnalogHat(LeftHatX) < 117 || PS3.getAnalogHat(LeftHatY) > 137 || PS3.getAnalogHat(LeftHatY) < 117 || PS3.getAnalogHat(RightHatX) > 137 || PS3.getAnalogHat(RightHatX) < 117 || PS3.getAnalogHat(RightHatY) > 137 || PS3.getAnalogHat(RightHatY) < 117) { pc.printf("\r\nLeftHatX: %d", PS3.getAnalogHat(LeftHatX)); pc.printf("\tLeftHatY: %d", PS3.getAnalogHat(LeftHatY)); if (PS3.PS3Connected) { // The Navigation controller only have one joystick pc.printf("\tRightHatX: %d", PS3.getAnalogHat(RightHatX)); pc.printf("\tRightHatY: %d", PS3.getAnalogHat(RightHatY)); } } // Analog button values can be read from almost all buttons if (PS3.getAnalogButton(L2) || PS3.getAnalogButton(R2)) { pc.printf("\r\nL2: %d", PS3.getAnalogButton(L2)); if (!PS3.PS3NavigationConnected) { pc.printf("\tR2: %d", PS3.getAnalogButton(R2)); } } if (PS3.getButtonClick(PS)) { PS3.disconnect(); pc.printf("\r\nPS"); } if (PS3.getButtonClick(TRIANGLE)) pc.printf("\r\nTriangle"); if (PS3.getButtonClick(CIRCLE)) pc.printf("\r\nCircle"); if (PS3.getButtonClick(CROSS)) pc.printf("\r\nCross"); if (PS3.getButtonClick(SQUARE)) pc.printf("\r\nSquare"); if (PS3.getButtonClick(UP)) { pc.printf("\r\nUp"); PS3.setLedOff(); PS3.setLedOn(CONTROLLER_LED4); } if (PS3.getButtonClick(RIGHT)) { pc.printf("\r\nRight"); PS3.setLedOff(); PS3.setLedOn(CONTROLLER_LED1); } if (PS3.getButtonClick(DOWN)) { pc.printf("\r\nDown"); PS3.setLedOff(); PS3.setLedOn(CONTROLLER_LED2); } if (PS3.getButtonClick(LEFT)) { pc.printf("\r\nLeft"); PS3.setLedOff(); PS3.setLedOn(CONTROLLER_LED3); } if (PS3.getButtonClick(L1)) pc.printf("\r\nL1"); if (PS3.getButtonClick(L3)) pc.printf("\r\nL3"); if (PS3.getButtonClick(R1)) pc.printf("\r\nR1"); if (PS3.getButtonClick(R3)) pc.printf("\r\nR3"); if (PS3.getButtonClick(SELECT)) { pc.printf("\r\nSelect - "); PS3.printStatusString(); } if (PS3.getButtonClick(START)) { pc.printf("\r\nStart"); printAngle = !printAngle; } if (printAngle) { pc.printf("\r\nPitch: %.3lf", PS3.getAngle(Pitch)); pc.printf("\tRoll: %.3lf", PS3.getAngle(Roll)); } } else { pc.printf("not connect\n"); } } }
USB_Host/usbh_midi.h@1:da31140f2a1c, 2020-05-02 (annotated)
- Committer:
- robo_ichinoseki_a
- Date:
- Sat May 02 05:56:48 2020 +0000
- Revision:
- 1:da31140f2a1c
- Parent:
- 0:b1ce54272580
update
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
kotakku | 0:b1ce54272580 | 1 | /* |
kotakku | 0:b1ce54272580 | 2 | ******************************************************************************* |
kotakku | 0:b1ce54272580 | 3 | * USB-MIDI class driver for USB Host Shield 2.0 Library |
kotakku | 0:b1ce54272580 | 4 | * Copyright (c) 2012-2018 Yuuichi Akagawa |
kotakku | 0:b1ce54272580 | 5 | * |
kotakku | 0:b1ce54272580 | 6 | * Idea from LPK25 USB-MIDI to Serial MIDI converter |
kotakku | 0:b1ce54272580 | 7 | * by Collin Cunningham - makezine.com, narbotic.com |
kotakku | 0:b1ce54272580 | 8 | * |
kotakku | 0:b1ce54272580 | 9 | * for use with USB Host Shield 2.0 from Circuitsathome.com |
kotakku | 0:b1ce54272580 | 10 | * https://github.com/felis/USB_Host_Shield_2.0 |
kotakku | 0:b1ce54272580 | 11 | ******************************************************************************* |
kotakku | 0:b1ce54272580 | 12 | * This program is free software; you can redistribute it and/or modify |
kotakku | 0:b1ce54272580 | 13 | * it under the terms of the GNU General Public License as published by |
kotakku | 0:b1ce54272580 | 14 | * the Free Software Foundation; either version 2 of the License, or |
kotakku | 0:b1ce54272580 | 15 | * (at your option) any later version. |
kotakku | 0:b1ce54272580 | 16 | * |
kotakku | 0:b1ce54272580 | 17 | * This program is distributed in the hope that it will be useful, |
kotakku | 0:b1ce54272580 | 18 | * but WITHOUT ANY WARRANTY; without even the implied warranty of |
kotakku | 0:b1ce54272580 | 19 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
kotakku | 0:b1ce54272580 | 20 | * GNU General Public License for more details. |
kotakku | 0:b1ce54272580 | 21 | * |
kotakku | 0:b1ce54272580 | 22 | * You should have received a copy of the GNU General Public License |
kotakku | 0:b1ce54272580 | 23 | * along with this program. If not, see <http://www.gnu.org/licenses/> |
kotakku | 0:b1ce54272580 | 24 | ******************************************************************************* |
kotakku | 0:b1ce54272580 | 25 | */ |
kotakku | 0:b1ce54272580 | 26 | |
kotakku | 0:b1ce54272580 | 27 | #if !defined(_USBH_MIDI_H_) |
kotakku | 0:b1ce54272580 | 28 | #define _USBH_MIDI_H_ |
kotakku | 0:b1ce54272580 | 29 | //#define DEBUG_USB_HOST |
kotakku | 0:b1ce54272580 | 30 | #include "Usb.h" |
kotakku | 0:b1ce54272580 | 31 | |
kotakku | 0:b1ce54272580 | 32 | #define MIDI_MAX_ENDPOINTS 5 //endpoint 0, bulk_IN(MIDI), bulk_OUT(MIDI), bulk_IN(VSP), bulk_OUT(VSP) |
kotakku | 0:b1ce54272580 | 33 | #define USB_SUBCLASS_MIDISTREAMING 3 |
kotakku | 0:b1ce54272580 | 34 | #define DESC_BUFF_SIZE 256 |
kotakku | 0:b1ce54272580 | 35 | #define MIDI_EVENT_PACKET_SIZE 64 |
kotakku | 0:b1ce54272580 | 36 | #define MIDI_MAX_SYSEX_SIZE 256 |
kotakku | 0:b1ce54272580 | 37 | class USBH_MIDI; |
kotakku | 0:b1ce54272580 | 38 | |
kotakku | 0:b1ce54272580 | 39 | class USBH_MIDI : public USBDeviceConfig |
kotakku | 0:b1ce54272580 | 40 | { |
kotakku | 0:b1ce54272580 | 41 | protected: |
kotakku | 0:b1ce54272580 | 42 | static const uint8_t epDataInIndex; // DataIn endpoint index(MIDI) |
kotakku | 0:b1ce54272580 | 43 | static const uint8_t epDataOutIndex; // DataOUT endpoint index(MIDI) |
kotakku | 0:b1ce54272580 | 44 | static const uint8_t epDataInIndexVSP; // DataIn endpoint index(Vendor Specific Protocl) |
kotakku | 0:b1ce54272580 | 45 | static const uint8_t epDataOutIndexVSP; // DataOUT endpoint index(Vendor Specific Protocl) |
kotakku | 0:b1ce54272580 | 46 | |
kotakku | 0:b1ce54272580 | 47 | /* mandatory members */ |
kotakku | 0:b1ce54272580 | 48 | USB *pUsb; |
kotakku | 0:b1ce54272580 | 49 | uint8_t bAddress; |
kotakku | 0:b1ce54272580 | 50 | uint8_t bConfNum; // configuration number |
kotakku | 0:b1ce54272580 | 51 | uint8_t bNumEP; // total number of EP in the configuration |
kotakku | 0:b1ce54272580 | 52 | bool bPollEnable; |
kotakku | 0:b1ce54272580 | 53 | bool isMidiFound; |
kotakku | 0:b1ce54272580 | 54 | uint16_t pid, vid; // ProductID, VendorID |
kotakku | 0:b1ce54272580 | 55 | uint8_t bTransferTypeMask; |
kotakku | 0:b1ce54272580 | 56 | /* Endpoint data structure */ |
kotakku | 0:b1ce54272580 | 57 | EpInfo epInfo[MIDI_MAX_ENDPOINTS]; |
kotakku | 0:b1ce54272580 | 58 | /* MIDI Event packet buffer */ |
kotakku | 0:b1ce54272580 | 59 | uint8_t recvBuf[MIDI_EVENT_PACKET_SIZE]; |
kotakku | 0:b1ce54272580 | 60 | uint8_t readPtr; |
kotakku | 0:b1ce54272580 | 61 | |
kotakku | 0:b1ce54272580 | 62 | uint8_t parseConfigDescr(uint8_t addr, uint8_t conf); |
kotakku | 0:b1ce54272580 | 63 | uint16_t countSysExDataSize(uint8_t *dataptr); |
kotakku | 0:b1ce54272580 | 64 | void setupDeviceSpecific(); |
kotakku | 0:b1ce54272580 | 65 | #ifdef DEBUG_USB_HOST |
kotakku | 0:b1ce54272580 | 66 | void PrintEndpointDescriptor( const USB_ENDPOINT_DESCRIPTOR* ep_ptr ); |
kotakku | 0:b1ce54272580 | 67 | #endif |
kotakku | 0:b1ce54272580 | 68 | public: |
kotakku | 0:b1ce54272580 | 69 | USBH_MIDI(USB *p); |
kotakku | 0:b1ce54272580 | 70 | // Misc functions |
kotakku | 0:b1ce54272580 | 71 | operator bool() { return (pUsb->getUsbTaskState()==USB_STATE_RUNNING); } |
kotakku | 0:b1ce54272580 | 72 | uint16_t idVendor() { return vid; } |
kotakku | 0:b1ce54272580 | 73 | uint16_t idProduct() { return pid; } |
kotakku | 0:b1ce54272580 | 74 | // Methods for recieving and sending data |
kotakku | 0:b1ce54272580 | 75 | uint8_t RecvData(uint16_t *bytes_rcvd, uint8_t *dataptr); |
kotakku | 0:b1ce54272580 | 76 | uint8_t RecvData(uint8_t *outBuf, bool isRaw=false); |
kotakku | 0:b1ce54272580 | 77 | uint8_t RecvRawData(uint8_t *outBuf); |
kotakku | 0:b1ce54272580 | 78 | uint8_t SendData(uint8_t *dataptr, uint8_t nCable=0); |
kotakku | 0:b1ce54272580 | 79 | uint8_t lookupMsgSize(uint8_t midiMsg, uint8_t cin=0); |
kotakku | 0:b1ce54272580 | 80 | uint8_t SendSysEx(uint8_t *dataptr, uint16_t datasize, uint8_t nCable=0); |
kotakku | 0:b1ce54272580 | 81 | uint8_t extractSysExData(uint8_t *p, uint8_t *buf); |
kotakku | 0:b1ce54272580 | 82 | uint8_t SendRawData(uint16_t bytes_send, uint8_t *dataptr); |
kotakku | 0:b1ce54272580 | 83 | // backward compatibility functions |
kotakku | 0:b1ce54272580 | 84 | inline uint8_t RcvData(uint16_t *bytes_rcvd, uint8_t *dataptr) { return RecvData(bytes_rcvd, dataptr); }; |
kotakku | 0:b1ce54272580 | 85 | inline uint8_t RcvData(uint8_t *outBuf) { return RecvData(outBuf); }; |
kotakku | 0:b1ce54272580 | 86 | |
kotakku | 0:b1ce54272580 | 87 | // USBDeviceConfig implementation |
kotakku | 0:b1ce54272580 | 88 | virtual uint8_t Init(uint8_t parent, uint8_t port, bool lowspeed); |
kotakku | 0:b1ce54272580 | 89 | virtual uint8_t Release(); |
kotakku | 0:b1ce54272580 | 90 | virtual uint8_t GetAddress() { return bAddress; }; |
kotakku | 0:b1ce54272580 | 91 | }; |
kotakku | 0:b1ce54272580 | 92 | #endif //_USBH_MIDI_H_ |
kotakku | 0:b1ce54272580 | 93 |