本API分为四部分:Linux或Android内核 (主要是gadget驱动)、linux端API及其DEMO、Windows 驱动、Windows API及其Demo。

USB OTG to PC USB API简介-LMLPHP

一、linux、Android内核

  1、 安装MCU对应的linux或Android内核开发编译环境。
  2、 解压Linux、Adroind内核源代码。注:本软件可以根据用户需求定制适合各种MCU的指定版本Linux、Android内核源代码。
  3、在内核源码根目录执行:
      #make distclean
  4、把本API压缩包中的/linux-kernel/config/ZZKJ_u2u_config复制到内核源代码根目录并更名为.config。
  5、把/linux-kernel/gadget目录的内容复制到内核的/dirvers/usb/gadget目录内,覆盖掉原来的文件。
  6、把/linux-kernel/arm_config目录的内容复制到内核的/arch/arm/configs目录内,覆盖掉原来的文件。
  7、把/linux-kernel/arch-mcuXXXX目录的内容复制到内核的/arch/arm/ arch-mcuXXXX目录内,覆盖掉原来的文件。
  8、把/linux-kernel/arm_plat-mcuXXXX目录的内容复制到内核的/arch/arm/ plat-mcuXXXX,覆盖掉原来的文件。
  9、编译内核:
      #make zImage
  10、如果编译内核前需要配置内核:
      #make menuconfig
  有关本API的配置可参照下面的图(注:下面的图是linux2.6.25的截图,可根据用户需要提供任何linux、android版本)。完成配置内核,选择 exit 保存退出。
有关本API的配置:
 
USB OTG to PC USB API简介-LMLPHP

USB OTG to PC USB API简介-LMLPHP

USB OTG to PC USB API简介-LMLPHP

USB OTG to PC USB API简介-LMLPHP

二、linux 端API及其demo

  位于API压缩包的u2uAPI_linux目录,这里的代码是unicode,汉字在windows下可能不能正常显示,在ubuntu下可正常显示。
把本API压缩包的u2uAPI_linux目录解压到,工作目录,比如:/root/u2u,执行命令:
    #cd /root/u2u
    #make
  即可生成u2u可执行文件,把u2u可执行文件复制到sd卡中,插入OK210,执行:
    #sdcard/u2u
  即可启动API测试程序,程序启动后自动打开u2u设备,并进入接收状态。
  按‘Q'键退出,按‘S'键发送字符串“abcdefghijklmnopqrstuvwxyz”
  运行界面截图:
 USB OTG to PC USB API简介-LMLPHP

三、windows驱动的安装

  u2u设备的windows驱动为压缩包的u2u_driver_win目录,把它解压。
  在Linux或Android上启动u2u API 测试程序后,连接Linux或Android的usb OTG口和PC
USB口(也可在启动测试程序之前连接),PC端会提示发现新的设备,根据提示按常规在指定位置(驱动解压到的位置)安装u2u设备的驱动程序。

四、windows API及其demo

  windows API及其demo为压缩包中u2uAPI目录,可提供VC6.0、VS20003、VS2005、VS2008、VS2010及以上、VB、Delphi、Java各种版本。
  debug、release目录下有编译好的test_lib.exe文件。这个demo启动后的界面为:
 USB OTG to PC USB API简介-LMLPHP
  先点击“打开并接收”按钮,打开u2u设备并启动接收线程。
  点击“发送”按钮,发送字符串“1234567890abcdefghijk”
  “close”按钮关闭u2u设备。“退出”按钮退出程序。

五、API函数说明

int u2u_open(int *pktSize)
//
//功能描述:打开u2u设备。
//输入参数:*pktSize 用于返回保持寸。就收数据时,接收缓冲区应大于等于
//     包尺寸;发送数据时,一次发送的数据长度应小于等于
//     包尺寸。
//      无论u2u设备是否打开成功,本函数都会返回包尺寸。
//返回参数:0 成功
//     1 u2u设备不存
//     2 u2u设备配置失败
//     3 打开u2u设备失败
//

int u2u_RecvData(void *recvBuf,int recvBufLen);
//
//功能描述: 从u2u usb设备接收数据
//输入参数: recvBuf      接收数据的缓冲区指针。接收缓冲区的尺寸应当大
//     于等于最大包尺寸,否则有可能造成数据丢失。
//     recvBufLen    缓冲区的的长度
//输出参数:>0    成功接收到数据,返回值为接收数据的长度
//     0    没有数据可读
//     -1    出错,u2u设备没有打开。
//     -2    数据接收错误, 具体原因可调用strerror(errno)获取
//     -3    数据接收错误, 不是u2u数据
//     -4    包数据错误
//     -5    接收缓冲区太小
//

int u2u_SendData(char *sendBuf, int len );
//
//功能描述:从u2u usb设备发送数据。发送的数据长度必须小于等于包尺寸,
//     否则多出的数据会丢失。
//输入参数:lpBuf    发送数据的缓冲区指针,发送缓冲区的尺寸应当小于
//     等于包尺寸。
//     len        发送的数据长度。
//输出参数:>0         通过u2u设备发送的数据长度
//     -1      u2u设备没有打开。
//     -2    发送数据错误, 具体原因可调用strerror(errno)获取
//

void u2u_Close();
//
//关闭u2u设备
//

05-07 13:10