isp1760-hcd.h 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. /* SPDX-License-Identifier: GPL-2.0 */
  2. #ifndef _ISP1760_HCD_H_
  3. #define _ISP1760_HCD_H_
  4. #include <linux/spinlock.h>
  5. #include <linux/regmap.h>
  6. #include "isp1760-regs.h"
  7. struct isp1760_qh;
  8. struct isp1760_qtd;
  9. struct resource;
  10. struct usb_hcd;
  11. struct isp1760_slotinfo {
  12. struct isp1760_qh *qh;
  13. struct isp1760_qtd *qtd;
  14. unsigned long timestamp;
  15. };
  16. /* chip memory management */
  17. #define ISP176x_BLOCK_MAX (32 + 20 + 4)
  18. #define ISP176x_BLOCK_NUM 3
  19. struct isp1760_memory_layout {
  20. unsigned int blocks[ISP176x_BLOCK_NUM];
  21. unsigned int blocks_size[ISP176x_BLOCK_NUM];
  22. unsigned int slot_num;
  23. unsigned int payload_blocks;
  24. unsigned int payload_area_size;
  25. };
  26. struct isp1760_memory_chunk {
  27. unsigned int start;
  28. unsigned int size;
  29. unsigned int free;
  30. };
  31. enum isp1760_queue_head_types {
  32. QH_CONTROL,
  33. QH_BULK,
  34. QH_INTERRUPT,
  35. QH_END
  36. };
  37. struct isp1760_hcd {
  38. struct usb_hcd *hcd;
  39. void __iomem *base;
  40. struct regmap *regs;
  41. struct regmap_field *fields[HC_FIELD_MAX];
  42. bool is_isp1763;
  43. const struct isp1760_memory_layout *memory_layout;
  44. spinlock_t lock;
  45. struct isp1760_slotinfo *atl_slots;
  46. int atl_done_map;
  47. struct isp1760_slotinfo *int_slots;
  48. int int_done_map;
  49. struct isp1760_memory_chunk memory_pool[ISP176x_BLOCK_MAX];
  50. struct list_head qh_list[QH_END];
  51. /* periodic schedule support */
  52. #define DEFAULT_I_TDPS 1024
  53. unsigned periodic_size;
  54. unsigned i_thresh;
  55. unsigned long reset_done;
  56. unsigned long next_statechange;
  57. };
  58. #ifdef CONFIG_USB_ISP1760_HCD
  59. int isp1760_hcd_register(struct isp1760_hcd *priv, struct resource *mem,
  60. int irq, unsigned long irqflags, struct device *dev);
  61. void isp1760_hcd_unregister(struct isp1760_hcd *priv);
  62. int isp1760_init_kmem_once(void);
  63. void isp1760_deinit_kmem_cache(void);
  64. #else
  65. static inline int isp1760_hcd_register(struct isp1760_hcd *priv,
  66. struct resource *mem,
  67. int irq, unsigned long irqflags,
  68. struct device *dev)
  69. {
  70. return 0;
  71. }
  72. static inline void isp1760_hcd_unregister(struct isp1760_hcd *priv)
  73. {
  74. }
  75. static inline int isp1760_init_kmem_once(void)
  76. {
  77. return 0;
  78. }
  79. static inline void isp1760_deinit_kmem_cache(void)
  80. {
  81. }
  82. #endif
  83. #endif /* _ISP1760_HCD_H_ */