USB TCPM
USB TCPM(Type-C Port Manager)的主要作用是管理 USB Type-C 端口的连接和电源传输协议(USB Power Delivery, PD),确保设备正确识别、协商和切换数据传输和电源供应的角色。TCPM 在 USB Type-C 连接中起到关键管理作用,主要职责包括:
管理 USB Type-C 插拔检测:检测设备的插入和拔出事件,识别连接器的方向(翻转)和线缆类型,并做出相应的配置调整。
协商电力传输:与 USB PD 控制器(如 TCPC)配合,通过 PD 协议与对端设备协商电力供应,确定电压和电流等级,并动态调整电力配置以匹配设备的需求。
角色管理:决定设备在 USB 连接中的角色(主机或设备、供电方或受电方),并根据连接情况和协议协商结果,动态切换这些角色。
配合 PD 控制器(TCPC):TCPM 通常与 TCPC(Type-C Port Controller)协同工作。TCPC 是具体实现 PD 协议硬件通信的控制器,而 TCPM 作为软件部分,负责控制 TCPC 和处理高层的协议逻辑。
安全和错误处理:监控连接状态,处理异常情况(如过流、短路、异常拔插),确保连接的安全性和稳定性。
通过 TCPM 的管理,可以实现 USB Type-C 设备之间的智能互操作,确保数据传输和电力传输的安全、灵活和高效。
tcpm的工作细节
在我们平时工作中adb使用typec口,来进行调试是常有的事情,那么在typec插上的一瞬间是就是通过tcpm来建立最初的联系,然后通知到dwc3和gadget来进行交互的,后面的工作就完全交给dwc3那边进行处理。
可以从/sys/kernel/debug/usb/tcpm-xxx下,抓取一份tcpm的log,这里抓取了一份RK平台,从开机到adb数据线设备插拔的过程log,来分析整个数据流程:
1. 一些重要参数的初始化值
port->port_type = TYPEC_PORT_DRP
port->prefer_role = TYPEC_SINK
port->data_role = TYPEC_DEVICE;
port->pwr_role = TYPEC_SINK;
port->try_role = TYPEC_SINK;
port->state = SNK_UNATTACHED
port->vbus_never_low = false
port->pd_capable = false
tcpm_rp_cc(port) = TYPEC_CC_RP_3_0
2. 一些重要参数的变动
port->vbus_present = false -> _tcpm_pd_vbus_on() -> ture
port->vbus_vsafe0v = true -> _tcpm_pd_vbus_on() -> false
3. 状态机转变state的整个调用流程
tcpm_set_state -> kthread_queue_work(port->wq, &port->state_machine)
--> tcpm_state_machine_work -> run_state_machine
4. 抓取到的整个数据流程包含tcpm初始化,插入/拔出adb数据线
rk3568_s:/sys/kernel/debug/usb/tcpm-0-004e # cat log
// 开机时启动后,初始阶段的log
[ 3.169614] init extcon finished
[ 3.173249] Setting usb_comm capable false
[ 3.174716] Setting voltage/current limit 0 mV 0 mA
[ 3.174728] polarity 0
[ 3.176800] Requesting mux state 0, usb-role 0, orientation 0
[ 3.178567] state change INVALID_STATE -> SNK_UNATTACHED [rev1 NONE_AMS]
[ 3.179503] CC1: 0 -> 0, CC2: 0 -> 0 [state SNK_UNATTACHED, polarity 0, disconnected]
[ 3.179510] state change SNK_UNATTACHED -> PORT_RESET [rev1 NONE_AMS]
[ 3.179520] 0-004e: registered
[ 3.179530] Setting usb_comm capable false
[ 3.181007] Setting voltage/current limit 0 mV 0 mA
[ 3.181023] polarity 0
[ 3.183097] Requesting mux state 0, usb-role 0, orientation 0
[ 3.184351] cc:=0
[ 3.185144] pending state change PORT_RESET -> PORT_RESET_WAIT_OFF @ 100 ms [rev1 NONE_AMS]
[ 3.185154] state change PORT_RESET -> PORT_RESET_WAIT_OFF [delayed 100 ms]
[ 3.185159] state change PORT_RESET_WAIT_OFF -> SNK_UNATTACHED [rev1 NONE_AMS]
[ 3.185163] Start toggling
[ 3.185831] state change SNK_UNATTACHED -> TOGGLING [rev1 NONE_AMS]
//插入typec后,tcpm的log,其中"======>" 这种箭头的打印是我本人加的
[ 53.680304][ T152] =================> tcpci_irq -> status[0x02]
[ 53.681360] VBUS on
[ 53.705497][ T152] =================> tcpci_irq -> status[0x01]
[ 53.706613] CC1: 0 -> 3, CC2: 0 -> 0 [state TOGGLING, polarity 0, connected]
[ 53.706627] state change TOGGLING -> SNK_ATTACH_WAIT [rev1 NONE_AMS]
[ 53.706644] pending state change SNK_ATTACH_WAIT -> SNK_DEBOUNCED @ 200 ms [rev1 NONE_AMS]
[ 53.906677] state change SNK_ATTACH_WAIT -> SNK_DEBOUNCED [delayed 200 ms]
[ 53.906691] state change SNK_DEBOUNCED -> SNK_ATTACHED [rev1 NONE_AMS]
[ 53.906695] polarity 0
[ 53.908791][ T151] emdoor: tcpm_set_polarity typec positive
[ 53.908862] Requesting mux state 1, usb-role 2, orientation 1
[ 53.909477][ T151] husb311 0-004e: CC connected in CC1 as UFP
[ 53.909744] state change SNK_ATTACHED -> SNK_STARTUP [rev1 NONE_AMS]
[ 53.909755] state change SNK_STARTUP -> SNK_DISCOVERY [rev3 NONE_AMS]
[ 53.909759] Setting voltage/current limit 5000 mV 0 mA
[ 53.909775] vbus=0 charge:=1
[ 53.910560] state change SNK_DISCOVERY -> SNK_WAIT_CAPABILITIES [rev3 NONE_AMS]
[ 53.910951] pending state change SNK_WAIT_CAPABILITIES -> HARD_RESET_SEND @ 310 ms [rev3 NONE_AMS]
[ 54.221059] state change SNK_WAIT_CAPABILITIES -> HARD_RESET_SEND [delayed 310 ms]
[ 54.221080] AMS HARD_RESET start
[ 54.221083] PD TX, type: 0x5
[ 54.223648][ T152] =================> tcpci_irq -> status[0x50]
[ 54.223737] PD TX complete, status: 0
[ 54.223819] state change HARD_RESET_SEND -> HARD_RESET_START [rev3 HARD_RESET]
[ 54.225211] state change HARD_RESET_START -> SNK_HARD_RESET_SINK_OFF [rev3 HARD_RESET]
[ 54.225235] vconn:=0
[ 54.225747] Requesting mux state 1, usb-role 2, orientation 1
[ 54.226346] pending state change SNK_HARD_RESET_SINK_OFF -> SNK_HARD_RESET_SINK_ON @ 650 ms [rev3 HARD_RESET]
[ 54.876427] state change SNK_HARD_RESET_SINK_OFF -> SNK_HARD_RESET_SINK_ON [delayed 650 ms]
[ 54.876447] AMS HARD_RESET finished
[ 54.876850] state change SNK_HARD_RESET_SINK_ON -> SNK_STARTUP [rev3 NONE_AMS]
[ 54.876871] state change SNK_STARTUP -> SNK_DISCOVERY [rev3 NONE_AMS]
[ 54.876875] Setting voltage/current limit 5000 mV 0 mA
[ 54.876896] state change SNK_DISCOVERY -> SNK_WAIT_CAPABILITIES [rev3 NONE_AMS]
[ 54.877264] pending state change SNK_WAIT_CAPABILITIES -> HARD_RESET_SEND @ 310 ms [rev3 NONE_AMS]
[ 55.187319] state change SNK_WAIT_CAPABILITIES -> HARD_RESET_SEND [delayed 310 ms]
[ 55.187339] AMS HARD_RESET start
[ 55.187343] PD TX, type: 0x5
[ 55.189910][ T152] =================> tcpci_irq -> status[0x50]
[ 55.189982] PD TX complete, status: 0
[ 55.190020] state change HARD_RESET_SEND -> HARD_RESET_START [rev3 HARD_RESET]
[ 55.191474] state change HARD_RESET_START -> SNK_HARD_RESET_SINK_OFF [rev3 HARD_RESET]
[ 55.191494] vconn:=0
[ 55.192023] Requesting mux state 1, usb-role 2, orientation 1
[ 55.192727] pending state change SNK_HARD_RESET_SINK_OFF -> SNK_HARD_RESET_SINK_ON @ 650 ms [rev3 HARD_RESET]
[ 55.842808] state change SNK_HARD_RESET_SINK_OFF -> SNK_HARD_RESET_SINK_ON [delayed 650 ms]
[ 55.842828] AMS HARD_RESET finished
[ 55.843201] state change SNK_HARD_RESET_SINK_ON -> SNK_STARTUP [rev3 NONE_AMS]
[ 55.843214] state change SNK_STARTUP -> SNK_DISCOVERY [rev3 NONE_AMS]
[ 55.843217] Setting voltage/current limit 5000 mV 0 mA
[ 55.843238] state change SNK_DISCOVERY -> SNK_WAIT_CAPABILITIES [rev3 NONE_AMS]
[ 55.843604] pending state change SNK_WAIT_CAPABILITIES -> SNK_READY @ 310 ms [rev3 NONE_AMS]
[ 56.153719] state change SNK_WAIT_CAPABILITIES -> SNK_READY [delayed 310 ms]
// 拔出typec时,tcpm的打印
[ 2087.027300][ T152] =================> tcpci_irq -> status[0x01]
[ 2087.028556] CC1: 3 -> 0, CC2: 0 -> 0 [state SNK_READY, polarity 0, disconnected]
[ 2087.028574] state change SNK_READY -> SNK_UNATTACHED [rev3 NONE_AMS]
[ 2087.028585] disable BIST MODE TESTDATA
[ 2087.029540] Setting usb_comm capable false
[ 2087.031079] Setting voltage/current limit 0 mV 0 mA
[ 2087.031116] polarity 0
[ 2087.033294][ T151] emdoor: tcpm_set_polarity typec positive
[ 2087.033323] Requesting mux state 0, usb-role 0, orientation 0
[ 2087.034933] Start toggling
[ 2087.035701] state change SNK_UNATTACHED -> TOGGLING [rev3 NONE_AMS]
[ 2087.046906][ T152] =================> tcpci_irq -> status[0x02]
[ 2087.048083] VBUS off
[ 2087.048095] VBUS VSAFE0V
从log内,进一步分析整个tcpm的运行流程,总结了出如下流程图:
同样关于插入的过程也总结了如下流程图:
USB TCPM的更多相关文章
- Linux自动共享USB设备:udev+Samba
一.概述 公司最近要我实现USB设备插入Ubuntu后,自动共享到网络上,能像Windows共享一样(如\\192.168.1.10)访问里面的内容,不需要写入权限.当时听完这需求,我这新人表示惊呆了 ...
- OpenWrt中开启usb存储和samba服务
在从官网安装的WNDR3800 15.05.1版本OpenWrt中, 不带usb存储支持以及samba, 需要另外安装 1. 启用usb支持 USB Basic Support https://wik ...
- USB设备(移动硬盘、鼠标)掉电掉驱动的两种解决方案
症状: 当你发现"移动硬盘图标"经常无故消失,又自己出现时. 你可以把这个现象称之为"掉电" or "掉驱动". 遇到这种情况,相当不爽. ...
- 【.NET MF】.NET Micro Framework USB移植
1.开发环境 windows 7 32位 MDK 4.54 .Net Micro Framework Porting Kit 4.2(RTM QFE2) .Net Micro Framework ...
- USB Host的上拉下拉电阻
关于USB的上下拉电阻,不是随便接个任意阻值的电阻就ok了. 当你的USB为主设备的时候,D+.D-上分别接一个15K的下拉电阻,这样可以使得在没有设备插入的时候,D+.D-上始终保持低电平:当为 ...
- stm32 usb error : identifier "bool" is undefined
.\usb\USB\usb_pwr.h(54): error: #20: identifier "bool" is undefinedusb\USB\usb_pwr.h(54): ...
- 如果mac电脑的usb转接器连接wlan时不显示,也就是不识别usb此时的网络连接没有,解决办法就是如下
1.接上电源 关机 先按下shift +ctrl + opt + 开机键 ,等待10秒,这10秒是没有反应的,屏幕不会亮,系统不会跑起来, 10秒之后松开所有键,再按下opt + cmd ...
- UP Board USB无线网卡一贴通
前言 原创文章,转载引用务必注明链接,水平有限,欢迎指正. 本文环境:ubilinux 3.0 kernel 4.4.0 本文使用Markdown写成,为获得更好的阅读体验和正常的图片.链接,请访问我 ...
- AD域控制器通过组策略禁止USB设备
问题:域环境下如何禁用USB口设备? 第一种:用传统的办法,在Bios中禁用USB. 第二种: 微软技术支持回答:根据您的需求, Windows识别USB设备主要通过两个文件,一个是Usbstor.p ...
- 安卓手机USB网络共享,电脑卡顿、反应慢
1.首先需要把手机连接到电脑,在手机上打开USB网络共享. 2.打开设备管理器 3.在网络适配器中,找到Remote NDIS based Internet Sharing Device,右键更新驱动 ...
随机推荐
- 同时使用mp和mybatis,我的type-aliases-package失效了
mybatis: #mapper配置文件 mapper-locations: classpath:mapper/*.xml type-aliases-package: com.sky.entity c ...
- golang轻量级的代码复制粘贴检查器 cpd
golang轻量级的代码复制粘贴检查器 cpd 项目地址: https://github.com/dengjiawen8955/copy-paste-detector 快速开始 clone git c ...
- python adb 安卓app性能测试
主要是进行cpu.内存.冷启动.热启动.流量.电量的监测 可获取到相关数据,同竞类产品对比,或者同版本对比 cpustatus adb命令:adb shell "dumpsys cpuinf ...
- Python+selenium编写第一个UI自动化脚本
python UI自动化前提:①python需要安装selenium模块 ②下载浏览器驱动 1.安装selenium模块 先确认本地是否安装selenium模块,没有的话点击右边的添加按钮" ...
- VirtualBox扩容CentOS-7虚拟机磁盘
1.背景描述 如上图所示,根路径"/"所在的文件系统已没有可用的磁盘空间,需要扩容磁盘. df -h 2.VirtualBox操作 2.1.查看当前虚拟磁盘的大小 如上图所示,点击 ...
- 【爬虫】Python获取星巴克所有产品
视频只介绍了BS4的简单使用,但我想全部获取出来 其实翻看接口,直接有一个json资源提供了这些数据,但是没有分类 import re import urllib.request from bs4 i ...
- OneFlow计算框架的OneAgent是不是一个子虚乌有的东西?
自己是搞强化学习的,今天看了些OneFlow计算框架的一些资料,发现OneFlow官方一直有宣传自己的强化学习框架--OneAgent,但是十分诡异的是从了OneFlow的官方宣传可以看到这个词,但是 ...
- Streamlit运行出现ModuleNotFoundError: No module named ‘altair.vegalite.v4‘ —— ModuleNotFoundError: No module named 'altair.vegalite.v4'
参考: https://blog.csdn.net/ikun_King/article/details/131852167 解决方法: pip install altair=4.2.2
- mpi4py.MPI.COMM_WORLD.Get_size失败——mpiexec and python mpi4py gives rank 0 and size 1 —— MPI.COMM_WORLD.Get_size() is always resulting '1'
参考: https://stackoverflow.com/questions/29264640/mpiexec-and-python-mpi4py-gives-rank-0-and-size-1 = ...
- mybatis-plus详细的图文教程(含视频讲解)
1.课程大纲 2.目录链接 1.简介与CRUD快速使用 https://www.cnblogs.com/newAndHui/p/13938754.html 2.注解的使用 https://www.cn ...