dwc3_msm_resume 函数调用到 usb_add_hcd 中间经过哪些函数
时间: 2024-06-05 17:09:24 浏览: 20
在 Qualcomm SoC 上,dwc3_msm_resume 函数是用于激活 USB 控制器的。该函数会执行以下步骤:
1. 调用 dwc3_msm_hw_init 函数,该函数用于初始化 USB 控制器硬件。
2. 调用 dwc3_msm_set_mode 函数,该函数根据 USB 控制器的模式配置寄存器。
3. 调用 dwc3_msm_phy_init 函数,该函数用于初始化 USB PHY。
4. 调用 dwc3_msm_set_lpm_nyet 函数,该函数用于配置 USB 控制器的低功耗模式和 NYET 信号。
5. 调用 dwc3_msm_set_u1_u2 函数,该函数用于配置 USB 控制器的 U1/U2 电源管理模式。
6. 调用 dwc3_msm_set_lfps 函数,该函数用于配置 USB 控制器的 LFPS 信号。
7. 调用 usb_add_hcd 函数,该函数用于将 USB 控制器添加到 USB 主机控制器驱动中。
因此,dwc3_msm_resume 函数调用到 usb_add_hcd 函数中间经过了多个函数。
相关问题
dwc3_msm_pm_restore
dwc3_msm_pm_restore 是一个函数名,通常在 Linux 内核的 USB 驱动中使用。它用于在系统从睡眠模式恢复时,重新启用 USB 控制器的电源管理功能。DWC3 代表 DesignWare USB 3.0 控制器 IP,msm 表示 Qualcomm 的移动平台,pm_restore 是指电源管理的恢复。
struct dwc3_msm 结构体分析
`struct dwc3_msm` 是 Qualcomm 移动平台上用于 USB3.0 控制器的驱动程序中定义的结构体,其定义如下:
```c
struct dwc3_msm {
struct device *dev;
void __iomem *base;
struct reset_control *core_reset;
struct reset_control *iface_reset;
struct clk *iface_clk;
struct clk *iface_clk_ref;
struct regulator *vddio;
struct regulator *vdd;
struct gpio_desc *vbus_id_gpio;
struct gpio_desc *vbus_valid_gpio;
bool is_ulpi;
bool is_device;
bool is_host;
bool is_otg;
bool has_lpm_erratum;
bool has_lpm_exit_erratum;
bool has_req_exit_erratum;
bool has_lpm_nyet_erratum;
bool has_lpm_response_erratum;
bool has_lpm_retry_erratum;
bool has_lpm_ack_erratum;
bool has_lpm_sts_erratum;
bool has_lpm_incomplete_erratum;
u32 max_speed;
bool no_vbus;
bool no_p1u;
bool no_p2u;
bool no_p3u;
bool no_p3d;
bool no_hibernation;
bool no_lpm;
bool no_lpm_remote_wakeup;
bool no_lpm_erratum_wa;
bool no_lpm_exit_erratum_wa;
bool no_req_exit_erratum_wa;
bool no_lpm_nyet_erratum_wa;
bool no_lpm_response_erratum_wa;
bool no_lpm_retry_erratum_wa;
bool no_lpm_ack_erratum_wa;
bool no_lpm_sts_erratum_wa;
bool no_lpm_incomplete_erratum_wa;
bool no_lpm_erratum;
bool no_lpm_exit_erratum;
bool no_req_exit_erratum;
bool no_lpm_nyet_erratum;
bool no_lpm_response_erratum;
bool no_lpm_retry_erratum;
bool no_lpm_ack_erratum;
bool no_lpm_sts_erratum;
bool no_lpm_incomplete_erratum;
struct phy *phy;
struct dwc3_lpm_timing_parameters lpm_timing;
struct dwc3_lpm_parameters lpm_parameters;
bool force_b_host;
bool force_b_device;
bool force_b_srp;
};
```
其中,成员变量的含义如下:
- `struct device *dev`: 指向该设备的 struct device 结构体。
- `void __iomem *base`: USB3.0 控制器的寄存器基地址。
- `struct reset_control *core_reset`: 控制 USB3.0 核心复位的 reset 控制器。
- `struct reset_control *iface_reset`: 控制 USB3.0 接口复位的 reset 控制器。
- `struct clk *iface_clk`: USB3.0 接口时钟。
- `struct clk *iface_clk_ref`: USB3.0 接口参考时钟。
- `struct regulator *vddio`: 用于控制 USB3.0 VDDIO 电源的 regulator。
- `struct regulator *vdd`: 用于控制 USB3.0 VDD 电源的 regulator。
- `struct gpio_desc *vbus_id_gpio`: 用于检测 USB3.0 的 VBUS 和 ID 信号的 GPIO 描述符。
- `struct gpio_desc *vbus_valid_gpio`: 用于检测 USB3.0 的 VBUS_VALID 信号的 GPIO 描述符。
- `bool is_ulpi`: 表示 USB3.0 是否使用 ULPI 接口。
- `bool is_device`: 表示 USB3.0 是否为设备模式。
- `bool is_host`: 表示 USB3.0 是否为主机模式。
- `bool is_otg`: 表示 USB3.0 是否为 OTG 模式。
- `bool has_lpm_erratum`: 表示 USB3.0 控制器是否存在低功耗模式(LPM)的错误。
- `bool has_lpm_exit_erratum`: 表示 USB3.0 控制器是否存在 LPM 退出的错误。
- `bool has_req_exit_erratum`: 表示 USB3.0 控制器是否存在请求退出 LPM 的错误。
- `bool has_lpm_nyet_erratum`: 表示 USB3.0 控制器是否存在 LPM NYET 的错误。
- `bool has_lpm_response_erratum`: 表示 USB3.0 控制器是否存在 LPM 响应的错误。
- `bool has_lpm_retry_erratum`: 表示 USB3.0 控制器是否存在 LPM 重试的错误。
- `bool has_lpm_ack_erratum`: 表示 USB3.0 控制器是否存在 LPM ACK 的错误。
- `bool has_lpm_sts_erratum`: 表示 USB3.0 控制器是否存在 LPM 状态的错误。
- `bool has_lpm_incomplete_erratum`: 表示 USB3.0 控制器是否存在 LPM 不完整的错误。
- `u32 max_speed`: 表示 USB3.0 的最大速度。
- `bool no_vbus`: 表示 USB3.0 是否没有 VBUS。
- `bool no_p1u`: 表示 USB3.0 是否不支持 P1U。
- `bool no_p2u`: 表示 USB3.0 是否不支持 P2U。
- `bool no_p3u`: 表示 USB3.0 是否不支持 P3U。
- `bool no_p3d`: 表示 USB3.0 是否不支持 P3D。
- `bool no_hibernation`: 表示 USB3.0 是否不支持 Hibernation。
- `bool no_lpm`: 表示 USB3.0 是否不支持 LPM。
- `bool no_lpm_remote_wakeup`: 表示 USB3.0 是否不支持 LPM 远程唤醒。
- `bool no_lpm_erratum_wa`: 表示 USB3.0 是否不支持 LPM 错误的 Workaround。
- `bool no_lpm_exit_erratum_wa`: 表示 USB3.0 是否不支持 LPM 退出错误的 Workaround。
- `bool no_req_exit_erratum_wa`: 表示 USB3.0 是否不支持请求退出 LPM 的错误 Workaround。
- `bool no_lpm_nyet_erratum_wa`: 表示 USB3.0 是否不支持 LPM NYET 错误的 Workaround。
- `bool no_lpm_response_erratum_wa`: 表示 USB3.0 是否不支持 LPM 响应错误的 Workaround。
- `bool no_lpm_retry_erratum_wa`: 表示 USB3.0 是否不支持 LPM 重试错误的 Workaround。
- `bool no_lpm_ack_erratum_wa`: 表示 USB3.0 是否不支持 LPM ACK 错误的 Workaround。
- `bool no_lpm_sts_erratum_wa`: 表示 USB3.0 是否不支持 LPM 状态错误的 Workaround。
- `bool no_lpm_incomplete_erratum_wa`: 表示 USB3.0 是否不支持 LPM 不完整错误的 Workaround。
- `bool no_lpm_erratum`: 表示 USB3.0 是否不支持 LPM 错误。
- `bool no_lpm_exit_erratum`: 表示 USB3.0 是否不支持 LPM 退出错误。
- `bool no_req_exit_erratum`: 表示 USB3.0 是否不支持请求退出 LPM 的错误。
- `bool no_lpm_nyet_erratum`: 表示 USB3.0 是否不支持 LPM NYET 错误。
- `bool no_lpm_response_erratum`: 表示 USB3.0 是否不支持 LPM 响应错误。
- `bool no_lpm_retry_erratum`: 表示 USB3.0 是否不支持 LPM 重试错误。
- `bool no_lpm_ack_erratum`: 表示 USB3.0 是否不支持 LPM ACK 错误。
- `bool no_lpm_sts_erratum`: 表示 USB3.0 是否不支持 LPM 状态错误。
- `bool no_lpm_incomplete_erratum`: 表示 USB3.0 是否不支持 LPM 不完整错误。
- `struct phy *phy`: 指向 USB3.0 PHY 的结构体。
- `struct dwc3_lpm_timing_parameters lpm_timing`: LPM 时序参数。
- `struct dwc3_lpm_parameters lpm_parameters`: LPM 参数。
- `bool force_b_host`: 是否强制 USB3.0 为 B-Host。
- `bool force_b_device`: 是否强制 USB3.0 为 B-Device。
- `bool force_b_srp`: 是否强制 USB3.0 为 B-SRP。