• PDIUSBD12指令


    PDIUSBD12指令

     

    端点描述

    PDIUSBD12的端点适用于不同类型的设备,端点可通过[Set mode]命令配置为4种不同的模式,分别为:

    • 模式0(NON-ISO模式):非同步模式

    • 模式1(ISO-OUT模式):同步输出传输

    • 模式2(ISO-IN模式) :同步输入传输

    • 模式3(ISO-IO模式) :同步输入输出传输

    模式0
    端点号 端点索引 传输类型 端点类型 方向 最大信息包规格(字节)
    0 0 控制输出 默认 输出 16
    1 控制输入 默认 输入 16
    1 2 普通输出 普通 输出 16
    3 普通输入 普通 输入 16
    2 4 普通输出 普通 输出 644
    5 普通输入 普通 输入 644
    模式1
    端点号 端点索引 传输类型 端点类型 方向 最大信息包规格(字节)
    0和1 同模式0
    2 4 同步输出 同步 输出 1284
    模式2
    端点号 端点索引 传输类型 端点类型 方向 最大信息包规格(字节)
    0和1 同模式0
    2 4 同步输入 同步 输入 1284
    模式3
    端点号 端点索引 传输类型 端点类型 方向 最大信息包规格(字节)
    0和1 同模式0
    2 4 同步输出 同步 输出 644
    5 同步输入 同步 输入 644

    命令描述

    有3种基本类型命令:初始化、数据流和通用命令。

    初始化命令
    命令名 接收者 编码 数据
    设置地址/使能 设备 D0H 写1字节
    设置端点使能 设备 D8H 写1字节
    设置模式 设备 F3H 写2字节
    设置DMA 设备 FBH 写/读1字节
    数据流命令
    命令名 接收者 编码 数据
    选择端点 控制输出 00H 读1字节(可选)
    控制输入 01H
    端点1输出 02H
    端点2输入 03H
    端点2输出 04H
    端点2输入 05H
    读最后处理状态 控制输出 40H 读1字节
    控制输入 41H
    端点1输出 42H
    端点2输入 43H
    端点2输出 44H
    端点2输入 45H
    设置端点状态 控制输出 40H 写1字节
    控制输入 41H
    端点1输出 42H
    端点2输入 43H
    端点2输出 44H
    端点2输入 45H
    读中断寄存器 设备 F4H 读2字节
    读缓冲区 选择的端点 F0H 读n字节
    写缓冲区 选择的端点 F0H 写n字节
    应答设置 选择的端点 F1H
    缓冲区清零 选择的端点 F2H
    使缓冲区有效 选择的端点 FAH
    普通命令
    命令名 接收者 编码 数据
    发送恢复 F6H
    读当前帧数目 F5H 读1或2字节

    设置地址/使能

    命令:D0H

    数据:写1字节

    描述:该命令用于设置USB分配的地址和使能功能

    写1字节内容:

    位描述 描述 初始状态
    ADDRESS [6:0] 写入的值即为地址 0
    ENABLE [7] 1 = 使能该功能,0 = 禁止该功能 0

    设置端点使能

    命令:D8H

    数据:写1字节

    描述:通过设置地址/使能命令后才可使能普通/同步端点。

    写1字节内容:

    位描述 描述 初始状态
    GENERIC/ISOCHRONOUS ENDPOINTS [0] 1 = 使能普通/同步端点 0
    RESERVED [7:1] 保留 X

     

    设置模式

    命令:F3H

    数据:写2字节

    描述:设置模式命令后跟2个写入的数据,第一个字节包含配置字节信息,第二个字节是时钟分频因素字节。

    写第一字节内容

    位描述 描述 初始状态
    RESERVED [0] 保留 0
    NO LAZYCLOCK [1] 1 = CLKOUT不会切换到lazyclock
    0 = CLKOUT在Suspend脚变高后切换到lazyclock

    总线复位不改变
    1
    CLOCK RUNNING [2] 1 = 内部时钟和PLL即使在挂起状态下仍然运行
    0 = 不需要时,内部时钟、晶振和PLL停止运行

    总线复位不改变
    1
    INTERRUPT MODE [3] 1 = 所有错误和NAK都将产生中断请求
    0 = 只有正确发送接收数据才产生中断请求

    总线复位不改变
    1
    SOFTCONNECT [4] 1 = 若Vbus有效,会将上拉电阻连通
    0 = 上拉电阻被断开

    总线复位不改变
    0
    RESERVED [5] 保留 0
    ENDPOINT CONFIGURATION [7:6] 00 = 模式0(非同步模式)
    01 = 模式1(同步输出模式)
    10 = 模式2(同步输入模式)
    11 = 模式3(同步输入输出模式)
    00

     

    写第二字节内容

    位描述 描述 初始状态
    CLOCK DIVISION FACTOR [3:0] 时钟分频系数。假设值为N,那么CLKOUT端的频率等于48MHZ/(N+1)。
    通过设置该值,可以获得不同频率的CLKOUT时钟输出
    1011
    RESERVED [5:4] 保留 XX
    SET_TO_ONE [6] 该位必须设置为1 0
    SOFT-ONLY INTERRUPT MODE [7] 1 = 只有当帧起始(SOF)时,中断信号才产生。 1

    读中断寄存器

    命令:F4H

    数据:读2字节

    读第一字节内容

    通过读端点最后处理状态寄存器将端点中断位(0~5)清零,其它位在读中断寄存器后被清零。

    位描述 描述 初始状态
    CONTROL OUT ENDPOINT [0] 1 = 控制输出中断 0
    CONTROL IN ENDPOINT [1] 1 = 控制输入中断 0
    ENDPOINT 1 OUT [2] 1 = 端点1输出中断 0
    ENDPOINT 1 IN [3] 1 = 端点1输入中断 0
    MAIN OUT ENDPOINT [4] 1 = 主端点输出中断 0
    MAIN IN ENDPOINT [5] 1 = 主端点输入中断 0
    BUS RESET [6] 1 = 总线复位后发出中断 0
    SUSPEND CHANGE [7] 1 = 挂起状态改变后发出中断 0

    读第二字节内容

    位描述 描述 初始状态
    DMA EOT [0] 1 = DMA操作已经完成 0
    RESERVED [7:1] 保留 XXXXXXX

    选择端点

    命令:00H-05H

    数据:可选读1字节

    选择端点命令将内部指针初始化到选择的缓冲区起始位置。可选的,该命令可跟一个返回的字节。

    读1字节内容

    位描述 描述 初始状态
    FULL/EMPTY [0] 1 = 缓冲区已满,0 = 缓冲区为空 0
    STALL [1] 1 = 该端点处于停止状态 0
    RESERVED [7:2] 保留 XXXXXX

     

    读最后处理状态寄存器

    命令:40H-45H

    数据:读1字节

    读最后处理状态寄存器命令后跟一个数据返回端点最后处理的状态。该命令同时复位中断寄存器中的相应位并将状态清零表示已经读取。在每次新的通信之后会将原来的状态信息覆盖。

    读1字节内容

    位描述 描述 初始状态
    DATA RECEIVE/TRANSMIT SUCCESS [0] 1 = 数据成功接收或发送。 0
    ERROR CODE [4:1] 见下表 0000
    SETUP PACKET [5] 1 = 接收到的为SETUP包(对IN缓冲区进行读总为0) 0
    DATA 0/1 PACKET [6] 1 = 接收到的是DATA1包,0 = 接收到是DATA0包 0
    PREVIOUS STATUS NOT READ [7] 1 = 前一状态没有读取,而且已经被覆盖 0
    错误代码 结果
    0000 无错
    0001 PID编码错误
    0010 PID未知:编码有效,但PID不存在
    0011 不是所期望的包
    0100 标志CRC错误
    0101 数据CRC错误
    0110 时间溢出错误
    0111 串扰错误
    1000 不期望的包结束
    1001 发送或接收NAK
    1010 发送停止,已接收到标志,但端点已停用。
    1011 溢出错误。
    1101 Bitstuff错误
    1111 错误的DATA PID

     

    读缓冲区

    命令:F0H

    数据:读多个字节(最大130)

    读缓冲区命令后,返回一系列从选择的端点数据缓冲区读出的数据。每读一字节,内部缓冲区指针自动加一。读缓冲区命令不会将缓冲区指针复位到缓冲区起始端。这意味着可被其它的命令所中断(选择端点命令除外)。

    缓冲区数据结构如下:

    字节1:保留

    字节2:数据字节的长度

    字节3:数据字节1

    字节4:数据字节2

    … …

     

    写缓冲区

    命令:F0H

    数据:写多个字节(最大130)

    写缓冲区命令后跟一系列需要写入的端点缓冲区的数据。数据的结构必须与前面描述的读缓冲区命令一样。

     

    清缓冲区

    命令:F2H

    数据:

    当一个包完全接收之后,内部端点缓冲区满标志置位。所有后续的包将被返回的NAK拒绝。当缓冲区清空后,新的包可被接收。

     

    使缓冲区有效

    命令:FAH

    数据:

    当微控制器已将数据写入IN缓冲区,它应当通过缓冲区有效命令设置缓冲区满标志。这表示缓冲区内的数据有效并可在接收到下一个IN标志时将其送入主机。

     

    设置端点状态

    命令:40H-45H

    数据:写1字节

    当一个停止的控制端点接收到SETUP包时自动解除停止,而不管包的内容是什么。如果端点应当处于停止状态,微控制器可以重新停止它。

    当一个停止的端点解除了停止状态后(通过设置端点命令或接收到一个SETUP包),它同时被重新初始化。将缓冲区刷新,如果是OUT缓冲区就等待一个DATA0 PID,如果是IN缓冲区就写入一个DATA0 PID。即使在解除停止时,将设置端点状态写为0也将初始化端点。

    位描述 描述 初始状态
    STALLED [0] 1 = 端点处于停止状态 0
    RESERVED [7:1] 保留 XXXXXXX

     

    应答建立

    命令:F1H

    数据:

    接收到SETUP包时将刷新IN缓冲区并且禁用IN和OUT端点的使能和清空缓冲区这两条命令。

    这样就确保最后一个SETUP包一直留在缓冲区中,而且没有其他包可以发送到主机,直到微控制器通过应答建立命令来重启这些命令。

    微控制器必须对IN和OUT端点都发送应答建立命令。

     

    发送恢复

    命令:F6H

    数据:

    发送一个上行数据流恢复信号10ms。该命令通常用于器件处于挂起状态时。

  • 相关阅读:
    安装黑苹果的config.plist
    navicat for mysql 导出数据的坑
    js中的深层复制
    js写的一个HashMap
    js前台数据校验
    nginx对上传文件大小的限制
    tomcat用户配置,内存配置,pid配置
    redis安装及使用
    程序端口被占用分析
    zookeeper+dubbo-admin开发dubbo应用
  • 原文地址:https://www.cnblogs.com/sheshiji/p/3599477.html
Copyright © 2020-2023  润新知