Simple USBHost library for Nucleo F446RE/F411RE/F401RE FRDM-KL46Z/KL25Z/F64F LPC4088/LPC1768
Dependents: F401RE-BTstack_example F401RE-USBHostMSD_HelloWorld
Fork of KL46Z-USBHost by
簡易USBホストライブラリです。
official-USBHostの下位互換で対応プログラムを僅かな修正で動かすことが出来ます。
Platforms
- Nucleo F446RE
- Nucleo F411RE
- Nucleo F401RE
- FRDM-K64F
- FRDM-KL46Z
- FRDM-KL25Z
- LPC4088
- LPC1768
Nucleo F446RE/F411RE/F401REのUSB接続方法
| ST morpho | USB |
|---|---|
| U5V (CN10-8) | VBUS (1 RED) |
| PA11 (CN10-14) | DM (2 WHITE) |
| PA12 (CN10-12) | DP (3 GREEN) |
| GND (CN10-20) | GND (4 BLACK) |
Examples
Import programF446RE-USBHostMouse_HelloWorld
USBHostMouse Hello World for ST-Nucleo-F446RE
Import programF401RE-USBHostMSD_HelloWorld
Simple USBHost MSD(USB flash drive) for Nucleo F401RE/FRDM-KL46Z test program
Import programF401RE-USBHostC270_example
Simple USBHost WebCam test program
Import programK64F_USBHostC270_example
Simple USBHost C270 example
Import programF401RE-BTstack_example
BTstack for Nucleo F401RE/FRDM-KL46Z example program
Import programUSBHostRSSI_example
Bluetooth device discovery example program.
Import programKL46Z-USBHostGPS_HelloWorld
Simple USBHost GPS Dongle Receiver for FRDM-KL46Z test program
USBHost/USBEndpoint.h
- Committer:
- va009039
- Date:
- 2016-05-01
- Revision:
- 23:4ab8bc835303
- Parent:
- 18:61554f238584
File content as of revision 23:4ab8bc835303:
/* mbed USBHost Library
* Copyright (c) 2006-2013 ARM Limited
*
* 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.
*/
#pragma once
#include "FunctionPointer.h"
#include "USBHostTypes.h"
#include "USBDeviceConnected.h"
class USBDeviceConnected;
/**
* USBEndpoint class
*/
class USBEndpoint {
public:
/**
* Constructor
*/
USBEndpoint(USBDeviceConnected* _dev) {
init(CONTROL_ENDPOINT, IN, 8, 0);
dev = _dev;
pData = NULL;
}
/**
* Initialize an endpoint
*
* @param type endpoint type
* @param dir endpoint direction
* @param size endpoint size
* @param ep_number endpoint number
*/
void init(ENDPOINT_TYPE _type, ENDPOINT_DIRECTION _dir, uint32_t size, uint8_t ep_number) {
setState(USB_TYPE_FREE);
setType(_type);
dir = _dir;
MaxPacketSize = size;
address = ep_number;
data01_toggle = DATA0;
}
void ohci_init(uint8_t frameCount, uint8_t queueLimit) {
ohci.frameCount = frameCount;
ohci.queueLimit = queueLimit;
}
/**
* Attach a member function to call when a transfer is finished
*
* @param tptr pointer to the object to call the member function on
* @param mptr pointer to the member function to be called
*/
template<typename T>
inline void attach(T* tptr, void (T::*mptr)(void)) {
if((mptr != NULL) && (tptr != NULL)) {
rx.attach(tptr, mptr);
}
}
/**
* Attach a callback called when a transfer is finished
*
* @param fptr function pointer
*/
inline void attach(void (*fptr)(void)) {
if(fptr != NULL) {
rx.attach(fptr);
}
}
/**
* Call the handler associted to the end of a transfer
*/
inline void call() {
rx.call();
};
void setType(ENDPOINT_TYPE _type) { type = _type; }
void setState(USB_TYPE st) { state = st; }
void setDevice(USBDeviceConnected* _dev) { dev = _dev; }
void setBuffer(uint8_t* buf, int size) { buf_start = buf, buf_size = size; }
void setLengthTransferred(int len) { transferred = len; };
void setAddress(int addr) { address = addr; }
void setSize(int size) { MaxPacketSize = size; }
void setData01(uint8_t data01) { data01_toggle = data01; }
void setNextEndpoint(USBEndpoint* ep) { nextEp = ep; };
template<class T>
void setHALData(T data) { pData = data; }
USBDeviceConnected* getDevice() { return dev; }
ENDPOINT_TYPE getType() { return type; };
USB_TYPE getState() { return state; }
int getLengthTransferred() { return transferred; }
uint8_t *getBufStart() { return buf_start; }
int getBufSize() { return buf_size; }
uint8_t getAddress(){ return address; };
int getSize() { return MaxPacketSize; }
ENDPOINT_DIRECTION getDir() { return dir; }
uint8_t getData01() { return data01_toggle; }
void toggleData01() {
data01_toggle = (data01_toggle == DATA0) ? DATA1 : DATA0;
}
USBEndpoint* nextEndpoint() { return nextEp; };
template<class T>
T getHALData() { return reinterpret_cast<T>(pData); }
struct {
uint8_t queueLimit;
uint8_t frameCount; // 1-8
} ohci;
private:
USBEndpoint(){}
ENDPOINT_TYPE type;
USB_TYPE state;
ENDPOINT_DIRECTION dir;
USBDeviceConnected* dev;
uint8_t data01_toggle; // DATA0,DATA1
uint8_t address;
int transferred;
uint8_t * buf_start;
int buf_size;
FunctionPointer rx;
int MaxPacketSize;
USBEndpoint* nextEp;
void* pData;
};
class EndpointQueue {
public:
EndpointQueue():head(NULL),tail(NULL) {}
void push(USBEndpoint* ep) {
if (head) {
tail->setNextEndpoint(ep);
} else {
head = ep;
}
tail = ep;
ep->setNextEndpoint(NULL);
}
USBEndpoint* pop() {
USBEndpoint* ep = head;
if (ep) {
head = ep->nextEndpoint();
}
return ep;
}
bool empty() { return head == NULL; }
private:
USBEndpoint* head;
USBEndpoint* tail;
};

