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

USBHost/myqueue.h

Committer:
va009039
Date:
2014-02-03
Revision:
9:7f9f64cf5ded

File content as of revision 9:7f9f64cf5ded:

#pragma once

template<class T>
class myqueue {
public:
    myqueue() {
        m_w = m_r = 0;
        m_size = 0;
        m_limit = 4;
        m_buf = new T[m_limit];
    }
    void push(T v) {
        if (m_size >= m_limit) {
            int new_limit = m_limit + 4;
            T* new_buf = new T[new_limit];
            for(int i = 0; i < m_size; i++) {
                new_buf[i] = m_buf[i];
            }
            delete[] m_buf;
            m_buf = new_buf;
            m_limit = new_limit;
        }
        m_buf[m_w++] = v;
        if (m_w >= m_limit) {
            m_w = 0;
        }
        m_size++;
    }
    T pop() {
        T v = m_buf[m_r++];
        if (m_r >= m_limit) {
            m_r = 0;
        }
        m_size--;
        return v;
    }
    bool empty() { return (m_w == m_r) ? true : false; }
    int size() { return m_size; }
    void clear() { m_size = 0; }
    T at(int i) { return m_buf[i]; }

private:
    int m_limit;
    int m_size;
    int m_w;
    int m_r;
    T *m_buf;
};