Simple USBHost library for Nucleo F446RE/F411RE/F401RE FRDM-KL46Z/KL25Z/F64F LPC4088/LPC1768

Dependencies:   FATFileSystem

Dependents:   F401RE-BTstack_example F401RE-USBHostMSD_HelloWorld

Fork of KL46Z-USBHost by Norimasa Okamoto

簡易USBホストライブラリです。
official-USBHostの下位互換で対応プログラムを僅かな修正で動かすことが出来ます。

Platforms

  • Nucleo F446RE
  • Nucleo F411RE
  • Nucleo F401RE
  • FRDM-K64F
  • FRDM-KL46Z
  • FRDM-KL25Z
  • LPC4088
  • LPC1768

Nucleo F446RE/F411RE/F401REのUSB接続方法

ST morphoUSB
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

Committer:
va009039
Date:
Mon Jun 23 20:30:04 2014 +0900
Revision:
16:981c3104f6c0
Parent:
10:40c7f6788902
add FRDM-K64F.(not tested)

Who changed what in which revision?

UserRevisionLine numberNew contents of line
va009039 10:40c7f6788902 1 #pragma once
va009039 10:40c7f6788902 2
va009039 10:40c7f6788902 3 template<class T>
va009039 10:40c7f6788902 4 class myvector {
va009039 10:40c7f6788902 5 public:
va009039 10:40c7f6788902 6 myvector() {
va009039 10:40c7f6788902 7 m_size = 0;
va009039 10:40c7f6788902 8 m_buf = NULL;
va009039 10:40c7f6788902 9 }
va009039 16:981c3104f6c0 10 ~myvector() {
va009039 16:981c3104f6c0 11 if (m_buf) {
va009039 16:981c3104f6c0 12 delete[] m_buf;
va009039 16:981c3104f6c0 13 }
va009039 16:981c3104f6c0 14 }
va009039 10:40c7f6788902 15 void push_back(T v) {
va009039 10:40c7f6788902 16 T* new_buf = new T[m_size+1];
va009039 10:40c7f6788902 17 if (m_size > 0) {
va009039 10:40c7f6788902 18 for(int i = 0; i < m_size; i++) {
va009039 10:40c7f6788902 19 new_buf[i] = m_buf[i];
va009039 10:40c7f6788902 20 }
va009039 10:40c7f6788902 21 delete[] m_buf;
va009039 10:40c7f6788902 22 }
va009039 10:40c7f6788902 23 m_buf = new_buf;
va009039 10:40c7f6788902 24 m_buf[m_size++] = v;
va009039 10:40c7f6788902 25 }
va009039 10:40c7f6788902 26 T& operator[](const int index) {
va009039 10:40c7f6788902 27 return m_buf[index];
va009039 10:40c7f6788902 28 }
va009039 10:40c7f6788902 29 int size() { return m_size; }
va009039 10:40c7f6788902 30
va009039 10:40c7f6788902 31 private:
va009039 10:40c7f6788902 32 int m_size;
va009039 10:40c7f6788902 33 T *m_buf;
va009039 10:40c7f6788902 34 };