123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 |
- /*
- * Copyright (c) 2022, sakumisu
- *
- * SPDX-License-Identifier: Apache-2.0
- */
- #ifndef _USB_EHCI_PRIV_H
- #define _USB_EHCI_PRIV_H
- #include "usbh_core.h"
- #include "usbh_hub.h"
- #include "usb_hc_ehci.h"
- #define EHCI_HCCR ((struct ehci_hccr *)(uintptr_t)(bus->hcd.reg_base + CONFIG_USB_EHCI_HCCR_OFFSET))
- #define EHCI_HCOR ((struct ehci_hcor *)(uintptr_t)(bus->hcd.reg_base + CONFIG_USB_EHCI_HCCR_OFFSET + g_ehci_hcd[bus->hcd.hcd_id].hcor_offset))
- #define EHCI_PTR2ADDR(x) ((uint32_t)(uintptr_t)(x) & ~0x1F)
- #define EHCI_ADDR2QH(x) ((struct ehci_qh_hw *)(uintptr_t)((uint32_t)(x) & ~0x1F))
- #define EHCI_ADDR2QTD(x) ((struct ehci_qtd_hw *)(uintptr_t)((uint32_t)(x) & ~0x1F))
- #define EHCI_ADDR2ITD(x) ((struct ehci_itd_hw *)(uintptr_t)((uint32_t)(x) & ~0x1F))
- #ifndef CONFIG_USB_EHCI_QH_NUM
- #define CONFIG_USB_EHCI_QH_NUM CONFIG_USBHOST_PIPE_NUM
- #endif
- #ifndef CONFIG_USB_EHCI_QTD_NUM
- #define CONFIG_USB_EHCI_QTD_NUM 3
- #endif
- #ifndef CONFIG_USB_EHCI_ITD_NUM
- #define CONFIG_USB_EHCI_ITD_NUM 5
- #endif
- #ifndef CONFIG_USB_EHCI_ISO_NUM
- #define CONFIG_USB_EHCI_ISO_NUM 4
- #endif
- extern uint8_t usbh_get_port_speed(struct usbh_bus *bus, const uint8_t port);
- struct ehci_qtd_hw {
- struct ehci_qtd hw;
- struct usbh_urb *urb;
- uint32_t length;
- } __attribute__((aligned(32)));
- struct ehci_qh_hw {
- struct ehci_qh hw;
- struct ehci_qtd_hw qtd_pool[CONFIG_USB_EHCI_QTD_NUM];
- uint32_t first_qtd;
- struct usbh_urb *urb;
- usb_osal_sem_t waitsem;
- uint8_t remove_in_iaad;
- } __attribute__((aligned(32)));
- struct ehci_itd_hw {
- struct ehci_itd hw;
- struct usbh_urb *urb;
- uint16_t start_frame;
- uint8_t mf_unmask;
- uint8_t mf_valid;
- uint32_t pkt_idx[8];
- } __attribute__((aligned(32)));
- struct ehci_iso_hw
- {
- struct ehci_itd_hw itd_pool[CONFIG_USB_EHCI_ITD_NUM];
- uint32_t itd_num;
- };
- struct ehci_hcd {
- bool ehci_qh_used[CONFIG_USB_EHCI_QH_NUM];
- bool ehci_iso_used[CONFIG_USB_EHCI_ISO_NUM];
- bool ppc; /* Port Power Control */
- bool has_tt; /* if use tt instead of Companion Controller */
- uint8_t n_cc; /* Number of Companion Controller */
- uint8_t n_pcc; /* Number of ports supported per companion host controller */
- uint8_t n_ports;
- uint8_t hcor_offset;
- };
- extern struct ehci_hcd g_ehci_hcd[CONFIG_USBHOST_MAX_BUS];
- extern uint32_t g_framelist[CONFIG_USBHOST_MAX_BUS][USB_ALIGN_UP(CONFIG_USB_EHCI_FRAME_LIST_SIZE, 1024)];
- int ehci_iso_urb_init(struct usbh_bus *bus, struct usbh_urb *urb);
- void ehci_kill_iso_urb(struct usbh_bus *bus, struct usbh_urb *urb);
- void ehci_scan_isochronous_list(struct usbh_bus *bus);
- #endif
|