do { rc = smblib_read(chg, TYPE_C_STATUS_4_REG, &stat); if (rc < 0) { smblib_err(chg, "Couldn't read TYPE_C_STATUS_4 rc=%d\n", rc); goto try_sink_exit; } debounce_done = stat & TYPEC_DEBOUNCE_DONE_STATUS_BIT; vbus_detected = stat & TYPEC_VBUS_STATUS_BIT; /* Successfully transitioned to ATTACHED.SNK */ if (vbus_detected && debounce_done) { exit_mode = ATTACHED_SINK; goto try_sink_exit; } /* * Ensure sink since drp may put us in source if other * side switches back to Rd */ sink = !(stat & UFP_DFP_MODE_STATUS_BIT); usleep_range(1000, 2000); } while (debounce_done && sink);代码分析
时间: 2024-04-23 16:26:33 浏览: 192
这段代码是一个在Type-C设备中用于尝试作为sink的函数的主要实现部分。代码主要是通过读取Type-C状态寄存器中的状态位信息,来判断当前Type-C设备是否可以作为sink并进行后续的操作。
具体来说,代码首先通过使用smblib_read函数读取Type-C状态寄存器中的状态信息,并通过判断返回值rc是否小于0来判断读取操作是否成功。如果读取操作失败,则会输出错误信息并跳转到try_sink_exit标签处进行处理。
接着,代码会通过判断状态寄存器中的debounce_done和vbus_detected状态位来判断当前设备是否可以作为sink。如果两个状态位都为1,则表示Type-C设备已经完成debounce检测并检测到了VBUS电压,此时可以将设备设置为ATTACHED_SINK模式并跳转到try_sink_exit标签处。
如果当前设备不能作为sink,则需要确保设备为sink模式并等待一段时间后再次进行状态检测。具体来说,代码中通过判断UFP_DFP_MODE_STATUS_BIT状态位来判断设备是否为sink,并通过usleep_range函数等待一段时间后再次进行循环检测,直到检测到设备为sink或者debounce_done状态位为0时退出循环。
总体来说,该段代码的作用是尝试将Type-C设备设置为sink模式,并等待设备状态稳定后进行后续操作。
相关问题
typec_mode = smblib_get_prop_typec_mode(chg); if (chg->typec_present && (typec_mode != chg->typec_mode)) smblib_handle_rp_change(chg, typec_mode);代码分析
这段代码是针对 Android 系统中的充电管理模块的代码。其中,变量 `chg` 是一个指向充电管理器的指针。该代码段的作用是检测 Type-C 口的模式,并根据检测结果进行相应的处理。
首先,通过 `smblib_get_prop_typec_mode` 函数获取 Type-C 口的模式,并将结果存储在变量 `typec_mode` 中。然后,该代码段会判断 Type-C 口是否存在,如果存在且当前模式与之前的模式不同,则调用 `smblib_handle_rp_change` 函数进行相应的处理。`smblib_handle_rp_change` 函数的作用是根据新的 Type-C 模式更新充电管理器的配置。
需要注意的是,该代码段只是一个片段,无法确定整个程序的具体作用。如果需要进一步了解程序的作用,需要查看整个程序的代码。
static void smblib_handle_rp_change(struct smb_charger *chg, int typec_mode) { int rp_ua; const struct apsd_result *apsd = smblib_get_apsd_result(chg); if ((apsd->pst != POWER_SUPPLY_TYPE_USB_DCP) && (apsd->pst != POWER_SUPPLY_TYPE_USB_FLOAT)) return; /* * if APSD indicates FLOAT and the USB stack had detected SDP, * do not respond to Rp changes as we do not confirm that its * a legacy cable */ if (chg->real_charger_type == POWER_SUPPLY_TYPE_USB) return; /* * We want the ICL vote @ 100mA for a FLOAT charger * until the detection by the USB stack is complete. * Ignore the Rp changes unless there is a * pre-existing valid vote. */ if (apsd->pst == POWER_SUPPLY_TYPE_USB_FLOAT && get_client_vote(chg->usb_icl_votable, LEGACY_UNKNOWN_VOTER) <= 100000) return; /* * handle Rp change for DCP/FLOAT/OCP. * Update the current only if the Rp is different from * the last Rp value. */ smblib_dbg(chg, PR_MISC, "CC change old_mode=%d new_mode=%d\n", chg->typec_mode, typec_mode); rp_ua = get_rp_based_dcp_current(chg, typec_mode); vote(chg->usb_icl_votable, LEGACY_UNKNOWN_VOTER, true, rp_ua); }代码分析
这段代码是在 `smblib_handle_rp_change` 函数中的一段具体实现。该函数的作用是处理 Type-C 口模式变化时的操作,该代码段主要负责根据 Type-C 口模式更新充电器的电流限制值。
首先,通过 `smblib_get_apsd_result` 函数获取当前的充电状态信息,并将结果存储在变量 `apsd` 中。然后,该代码段会判断当前的充电状态是否为 USB DCP 或者 USB FLOAT,如果不是则直接返回。接着,该代码段会判断当前的充电类型是否为 USB,如果是则直接返回。最后,该代码段会根据 Type-C 口模式计算出新的电流限制值,并将其设置为充电器的电流限制值。
需要注意的是,该代码段只是一个片段,无法确定整个程序的具体作用。如果需要进一步了解程序的作用,需要查看整个程序的代码。
阅读全文