struct dwc3
时间: 2023-10-14 18:06:45 浏览: 98
struct dwc3是一个数据结构,通常用于描述和控制设计的DWC3(DesignWare USB 3.0)IP核。DWC3是一个由Synopsys开发的USB 3.0控制器IP,用于在SoC(System-on-Chip)中实现USB 3.0功能。
struct dwc3包含了一系列的成员变量,用于存储和管理DWC3 IP的状态和配置信息。这些成员变量可能包括寄存器地址、中断号、传输配置等。通过操作这些成员变量,软件可以与DWC3 IP进行通信并控制其行为。
在使用DWC3 IP时,开发人员可以使用struct dwc3来访问和配置IP的各种属性和功能。它提供了一个方便的接口,使得开发人员可以轻松地与DWC3 IP进行交互,实现USB 3.0的各种操作和功能。
相关问题
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。
阅读全文