|  | /* SPDX-License-Identifier: GPL-2.0 */ | 
|  | #ifndef _ISP1760_HCD_H_ | 
|  | #define _ISP1760_HCD_H_ | 
|  |  | 
|  | #include <linux/spinlock.h> | 
|  |  | 
|  | struct isp1760_qh; | 
|  | struct isp1760_qtd; | 
|  | struct resource; | 
|  | struct usb_hcd; | 
|  |  | 
|  | /* | 
|  | * 60kb divided in: | 
|  | * - 32 blocks @ 256  bytes | 
|  | * - 20 blocks @ 1024 bytes | 
|  | * -  4 blocks @ 8192 bytes | 
|  | */ | 
|  |  | 
|  | #define BLOCK_1_NUM 32 | 
|  | #define BLOCK_2_NUM 20 | 
|  | #define BLOCK_3_NUM 4 | 
|  |  | 
|  | #define BLOCK_1_SIZE 256 | 
|  | #define BLOCK_2_SIZE 1024 | 
|  | #define BLOCK_3_SIZE 8192 | 
|  | #define BLOCKS (BLOCK_1_NUM + BLOCK_2_NUM + BLOCK_3_NUM) | 
|  | #define MAX_PAYLOAD_SIZE BLOCK_3_SIZE | 
|  | #define PAYLOAD_AREA_SIZE 0xf000 | 
|  |  | 
|  | struct isp1760_slotinfo { | 
|  | struct isp1760_qh *qh; | 
|  | struct isp1760_qtd *qtd; | 
|  | unsigned long timestamp; | 
|  | }; | 
|  |  | 
|  | /* chip memory management */ | 
|  | struct isp1760_memory_chunk { | 
|  | unsigned int start; | 
|  | unsigned int size; | 
|  | unsigned int free; | 
|  | }; | 
|  |  | 
|  | enum isp1760_queue_head_types { | 
|  | QH_CONTROL, | 
|  | QH_BULK, | 
|  | QH_INTERRUPT, | 
|  | QH_END | 
|  | }; | 
|  |  | 
|  | struct isp1760_hcd { | 
|  | #ifdef CONFIG_USB_ISP1760_HCD | 
|  | struct usb_hcd		*hcd; | 
|  |  | 
|  | u32 hcs_params; | 
|  | spinlock_t		lock; | 
|  | struct isp1760_slotinfo	atl_slots[32]; | 
|  | int			atl_done_map; | 
|  | struct isp1760_slotinfo	int_slots[32]; | 
|  | int			int_done_map; | 
|  | struct isp1760_memory_chunk memory_pool[BLOCKS]; | 
|  | struct list_head	qh_list[QH_END]; | 
|  |  | 
|  | /* periodic schedule support */ | 
|  | #define	DEFAULT_I_TDPS		1024 | 
|  | unsigned		periodic_size; | 
|  | unsigned		i_thresh; | 
|  | unsigned long		reset_done; | 
|  | unsigned long		next_statechange; | 
|  | #endif | 
|  | }; | 
|  |  | 
|  | #ifdef CONFIG_USB_ISP1760_HCD | 
|  | int isp1760_hcd_register(struct isp1760_hcd *priv, void __iomem *regs, | 
|  | struct resource *mem, int irq, unsigned long irqflags, | 
|  | struct device *dev); | 
|  | void isp1760_hcd_unregister(struct isp1760_hcd *priv); | 
|  |  | 
|  | int isp1760_init_kmem_once(void); | 
|  | void isp1760_deinit_kmem_cache(void); | 
|  | #else | 
|  | static inline int isp1760_hcd_register(struct isp1760_hcd *priv, | 
|  | void __iomem *regs, struct resource *mem, | 
|  | int irq, unsigned long irqflags, | 
|  | struct device *dev) | 
|  | { | 
|  | return 0; | 
|  | } | 
|  |  | 
|  | static inline void isp1760_hcd_unregister(struct isp1760_hcd *priv) | 
|  | { | 
|  | } | 
|  |  | 
|  | static inline int isp1760_init_kmem_once(void) | 
|  | { | 
|  | return 0; | 
|  | } | 
|  |  | 
|  | static inline void isp1760_deinit_kmem_cache(void) | 
|  | { | 
|  | } | 
|  | #endif | 
|  |  | 
|  | #endif /* _ISP1760_HCD_H_ */ |