MC33665 + MC33774 控制流程及 TPL3 帧结构介绍

一. 概述:
 

MC33665A:通用电池管理通信网关和变压器物理层 (TPL) 收发器。该设备通过标准通信协议转发来自不同 TPL(NXP 的隔离菊花链协议)端口的消息,标准通信协议可确保与市场上可用的微控制器兼容。

MC33774:AFE 模拟前端,可管理 4~18 串电池,采用 TPL3 菊花链协议,兼容了高精度电池电压和温度测量以及各种电池电压平衡策略。

MC33665A 提供了四个隔离的 TPL 菊花链端口,可用于与菊花链中的其他隔离 BMS 设备(如MC33771C、MC33772C 和 MC33775A)进行通信,具有单链模式及回环模式。本文将简要介绍在单条链上 MC33665 与 MC33774 的控制流程,其余菊花链控制流程相似。
 

二. TPL3 协议
 

1. MCU 与 MC33665 之间使用 SPI:在介绍控制流程之前首先需要了解其使用的通信协议。对于 MC33665ATS4AE 此 SPI 网关来说,它与 MCU 通过 SPI 连接,相应的还有 UART 网关和 CAN 网关,分别以 UART 和 CAN 方式连接,本文以 SPI 网关为例。

2. MC33665 与 MC33774 之间使用 TPL3:MCU 通过 SPI 发送或接收 TPL3 结构的帧来与 MC33665 通信,修改帧中的菊花链地址(CADD)和设备地址(DADD)可以选择进行 MC33665 内部寄存器配置 ,还是在匹配配置的 TPL 端口上发送消息,若是选择在 TPL 端口上发送消息,信号则以 TPL3 差分形式进行传输,通过双绞线到达链上的 MC33774 电池管理单元。

如图 1 所示为基于 MC33665A 的 BMS 架构示例,其采用了回环模式。
 

图 1 基于 MC33665A 的 BMS 架构示例
 

3. TPL3 协议:接下来将通过三个问题了解 TPL3 协议
(1)什么是 TPL?
    TPL:NXP 专有的菊花链协议,利用脉冲变压器实现的高速差分隔离通讯。
(2)TPL3的编码符号是什么样?

图 2 TPL3 编码符号

     (3)TPL3 帧包括哪些内容?

如图3 所示为 TPL3 的帧结构,TPL3 协议支持 64 位、80 位、96 位和 112 位的消息长度,在发送前要将消息打包为上述结构的帧,MCU 与 MC33665 之间通过 SPI 来收发该 TPL 帧,接收到的 TPL 帧需要在 MCU 进行解码。MC33665 与 MC33774 之间则通过 TPL 端口来收发 TPL3 帧格式的差分信号。

以下为 TPL3 帧结构主要内容:

图 3 TPL3 帧结构
 

MADD:主节点地址(默认 0)。

CADD:菊花链地址(MC33665A 有四条菊花链)。

DADD:链上的设备地址(每条链 62 个节点)。

RADD:寄存器访问起始地址。

MSGCNT:记录 MC33665A 的响应消息数量。

DATALEN:有效 data 的数目。

PAD:指定是否响应消息需要填充。

RESPLEN:一个响应帧中要传输的寄存器数。

NUMREG:请求的寄存器总数。

Padded:可选消息填充。
 

三. MC33665 与 MC33774 通信过程
 

1. MCU 配置
MC33665 分为请求 SPI 和响应 SPI,进行 MCU 配置前,需要通过硬件接线选择 MC33665 使用的是单路 SPI 还是双路 SPI ,本文以单路 SPI 为例。首先根据 MC33665 的默认配置来进行 MCU SPI 配置,默认情况下 MCU SPI 需要先作为主机,其 CPHA = 1,CPOL = 0,在 SPI 可以读写 MC33665 内部寄存器后再修改所需模式。
 

 图 4 MCU初始配置
 

     2. MC33665 配置

     2.1 复位和唤醒

图 5 MC33665 运行模式及过渡
 

      如图 5 所示为 MC33665 操作模式和转换,在 MCU 配置完成后,需要对 MC33665 进行复位和唤醒,步骤如下:

(1) 启动:检查 VDDD > 4V。

(2) 复位引脚高电平(100us)后转低电平(延时 500 us 以上)。

(3) 唤醒事件唤醒:

① MCU 侧唤醒(发送 TPL3 64 bit NOP 帧):
    a. SPI CSN_REQ 上升沿
    b. SDAT_REQ_RXD 下降沿

② 唤醒引脚:
    a. WAKE_IN 高电平(最小激活时间30微秒)

③ TPL 接口上唤醒:
    a. TPL PORT0~3 (EVH_WAKEUP_CFG.PORTx == 1 && SYS_PORTx_CFG.EN == 1)

写入 EVH_WAKEUP_CFG.WAKEUPMSG.寄存器可以配置唤醒源,读取唤醒原因寄存器 EVH_WAKEUP_REASON 可清楚唤醒原因

(4) 检查 STB_OUT 和 STB_N_OUT 引脚:从 STB_OUT 和 STB_N_OUT 可以看出当前所处模式,当 STB_OUT 为低电平、 STB_N_OUT 为高电平时说明当前处于主动模式;当 STB_OUT 为高电平、 STB_N_OUT 为低电平时说明当前处于睡眠或过渡模式。
 

      2.2 SPI 发送打包成 TPL3 格式的帧读写寄存器

发送 TPL3 帧前需要根据 TPL3 帧格式将所需内容进行打包,TPL3 打包方式如下:

(1)无前缀:分别打包为 64 位、80 位、96 位和 112 位帧,如图 3 所示。

(2)启动前缀:将 TPL3 打包为固定长度的 128 bit,消息前缀用于在不触及消息的情况下为消息提供附加信息,固定的帧长度可以帮助 MCU 中的处理(例如,DMA 传输)。前缀启用时,允许 MCU 添加一个或多个零填充字节。MC33665A忽略这个填充。如图 6、7 分别为请求前缀和响应前缀。

图 6 请求前缀
 

图 7 响应前缀
 

2.3  MC33665 内部寄存器配置
在打包后发送链地址等于 0 (CADD = 0)和设备地址等于 1 (DADD = 1)的命令将提供对 MC33665A内部寄存器的访问。以下为 MC33665 的主要配置寄存器:

① SYS_COM_TO_CFG 配置系统通信超时。

② SYS_PORTx_CFG 配置链上传输 TPL2/3、配置 CADD 等 …

③ SYS_HOST_COM_CFG 启用前缀。
 

     3. MC33774 配置

     3.1 发送 MC33774 唤醒消息

① 发送唤醒帧。

② 延时 2.4 ms。

③ 再次发送唤醒帧。

④ 延时 4 * 设备个数 ms。

唤醒帧格式可如图 8 所示,该时序为启用了前缀后的 128 bit TPL3 帧,data 为 0xFFEE,主机地址为 0 ,唤醒全部 TPL 端口及链上设备。

图 8 唤醒帧结构
 

      3.2 ID 分配

初始化配置 MC33774 设备地址 DADD:首先 MCU 要由 MC33665 内部寄存器配置转换为匹配配置的 TPL 端口上发送,修改 CADD 为 MC33665 SYS_PORTx_CFG 寄存器设定的值。例如启用端口 PORT0,在 MC33665 内部寄存器配置时将 SYS_PORT0_CFG 的 CADD 位设置为 001 (自定义菊花链编号, CADD ≠ 0),将 TPL 帧中的设备地址 DADD 修改为 0 ,此时数据在 TPL 端口 PORT0 上传输,只有一个设备时,即可配置链上的第一个 MC33774 设备寄存器。
将 TPL 帧中 MC33665 寄存器地址修改为 MC33774 SYS_COM_CFG 寄存器地址,CADD = 0001,DADD =0,MC33774 SYS_COM_CFG 寄存器用来进行初始配置,应给第一个设备分配其 ID。如图 9 为 SYS_COM_CFG 寄存器可进行配置的内容。

图 9 SYS_COM_CFG 寄存器
 

① NUMNODES:菊花链中的节点数。

② BUSFW:是否 TPL 总线转发。

③ CADD:链地址(与 MC33665 配置一致,如菊花链 001)。

④ DADD:设备地址(给定第一个设备 ID,如给定第一个设备地址为 000001)。

 当给定第一个设备地址 DADD = 000001 后,接下来的 TPL 帧中的 DADD 则修改为对应的  DADD = 000001,才可进行第一个设备其他寄存器的配置。如若一条链上有多个 MC33774,则首先需要给链上所有设备分配 DADD。如图 10 所示为 3 个 MC33774 的地址分配流程, BUSFW 位为 1 提供总线的转发,DADD 等于 0 可按链上设备顺序依次进行 DADD 分配,给第一个设备 DADD 写 1,第二个设备 DADD 写 2,第三个设备 DADD 写 3。地址分配结束后通过修改 TPL 帧中的 DADD 即可读写对应 MC33774。

图 10 DADD 分配过程
 

四. 总结
 

本文主要介绍了 TPL3 帧结构及 MC33665、MC33774 的控制流程,实际上 MC33665 还可使用 TPL2 协议,具有双路 SPI,可使用回环模式等可提供选择。
 

五. 参考资料
 

MC33665A Datasheet (3.0)

MC33774A Datasheet (2.0)

登录大大通,了解更多详情,解锁1500+完整应用方案,更有大联大700+FAE在线答疑解惑! 

  • 11
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值