ehci_regsRegular
4.4: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[1];
u32 reserved5[16];
u32 usbmode_ex;
};
4.8: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[0];
u32 reserved5[17];
u32 usbmode_ex;
};
4.10: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[0];
u32 reserved5[17];
u32 usbmode_ex;
};
4.13: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[0];
u32 reserved5[17];
u32 usbmode_ex;
};
4.15: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[0];
u32 reserved5[17];
u32 usbmode_ex;
};
4.18: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[0];
u32 reserved5[17];
u32 usbmode_ex;
};
5.0: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[0];
u32 reserved5[17];
u32 usbmode_ex;
};
5.3: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[0];
u32 reserved5[17];
u32 usbmode_ex;
};
5.4: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[0];
u32 reserved5[17];
u32 usbmode_ex;
};
5.8: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[0];
u32 reserved5[17];
u32 usbmode_ex;
};
5.11: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[0];
u32 reserved5[17];
u32 usbmode_ex;
};
5.13: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[0];
u32 reserved5[17];
u32 usbmode_ex;
};
5.15: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[15];
u32 reserved3[9];
u32 usbmode;
u32 reserved4;
u32 hostpc[15];
u32 brcm_insnreg[4];
u32 reserved5[2];
u32 usbmode_ex;
};
5.19: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[15];
u32 reserved3[9];
u32 usbmode;
u32 reserved4;
u32 hostpc[15];
u32 brcm_insnreg[4];
u32 reserved5[2];
u32 usbmode_ex;
};
6.2: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[15];
u32 reserved3[9];
u32 usbmode;
u32 reserved4;
u32 hostpc[15];
u32 brcm_insnreg[4];
u32 reserved5[2];
u32 usbmode_ex;
};
6.5: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[15];
u32 reserved3[9];
u32 usbmode;
u32 reserved4;
u32 hostpc[15];
u32 brcm_insnreg[4];
u32 reserved5[2];
u32 usbmode_ex;
};
6.8: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[15];
u32 reserved3[9];
u32 usbmode;
u32 reserved4;
u32 hostpc[15];
u32 brcm_insnreg[4];
u32 reserved5[2];
u32 usbmode_ex;
};
arm64: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[0];
u32 reserved5[17];
u32 usbmode_ex;
};
armhf: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[0];
u32 reserved5[17];
u32 usbmode_ex;
};
ppc64el: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[0];
u32 reserved5[17];
u32 usbmode_ex;
};
riscv64: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[0];
u32 reserved5[17];
u32 usbmode_ex;
};
aws: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[0];
u32 reserved5[17];
u32 usbmode_ex;
};
azure: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[0];
u32 reserved5[17];
u32 usbmode_ex;
};
gcp: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[0];
u32 reserved5[17];
u32 usbmode_ex;
};
lowlatency: ✅struct ehci_regs {
u32 command;
u32 status;
u32 intr_enable;
u32 frame_index;
u32 segment;
u32 frame_list;
u32 async_next;
u32 reserved1[2];
u32 txfill_tuning;
u32 reserved2[6];
u32 configured_flag;
u32 port_status[0];
u32 reserved3[9];
u32 usbmode;
u32 reserved4[6];
u32 hostpc[0];
u32 reserved5[17];
u32 usbmode_ex;
};
Regular
4.4 and 4.8 ⚠️u32 hostpc[1] ➡️ u32 hostpc[0]
u32 reserved5[16] ➡️ u32 reserved5[17]
4.8 and 4.10 ✅
4.10 and 4.13 ✅
4.13 and 4.15 ✅
4.15 and 4.18 ✅
4.18 and 5.0 ✅
5.0 and 5.3 ✅
5.3 and 5.4 ✅
5.4 and 5.8 ✅
5.8 and 5.11 ✅
5.11 and 5.13 ✅
5.13 and 5.15 ⚠️u32 brcm_insnreg[4]
u32 port_status[0] ➡️ u32 port_status[15]
u32 reserved4[6] ➡️ u32 reserved4
u32 hostpc[0] ➡️ u32 hostpc[15]
u32 reserved5[17] ➡️ u32 reserved5[2]
5.15 and 5.19 ✅
5.19 and 6.2 ✅
6.2 and 6.5 ✅
6.5 and 6.8 ✅
amd64 and arm64 ✅
amd64 and armhf ✅
amd64 and ppc64el ✅
amd64 and riscv64 ✅
generic and aws ✅
generic and azure ✅
generic and gcp ✅
generic and lowlatency ✅