105 lines
2.1 KiB
C
105 lines
2.1 KiB
C
|
/* SPDX-License-Identifier: GPL-2.0 */
|
||
|
#ifndef _ISP1760_HCD_H_
|
||
|
#define _ISP1760_HCD_H_
|
||
|
|
||
|
#include <linux/spinlock.h>
|
||
|
#include <linux/regmap.h>
|
||
|
|
||
|
#include "isp1760-regs.h"
|
||
|
|
||
|
struct isp1760_qh;
|
||
|
struct isp1760_qtd;
|
||
|
struct resource;
|
||
|
struct usb_hcd;
|
||
|
|
||
|
struct isp1760_slotinfo {
|
||
|
struct isp1760_qh *qh;
|
||
|
struct isp1760_qtd *qtd;
|
||
|
unsigned long timestamp;
|
||
|
};
|
||
|
|
||
|
/* chip memory management */
|
||
|
#define ISP176x_BLOCK_MAX (32 + 20 + 4)
|
||
|
#define ISP176x_BLOCK_NUM 3
|
||
|
|
||
|
struct isp1760_memory_layout {
|
||
|
unsigned int blocks[ISP176x_BLOCK_NUM];
|
||
|
unsigned int blocks_size[ISP176x_BLOCK_NUM];
|
||
|
|
||
|
unsigned int slot_num;
|
||
|
unsigned int payload_blocks;
|
||
|
unsigned int payload_area_size;
|
||
|
};
|
||
|
|
||
|
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 {
|
||
|
struct usb_hcd *hcd;
|
||
|
|
||
|
void __iomem *base;
|
||
|
|
||
|
struct regmap *regs;
|
||
|
struct regmap_field *fields[HC_FIELD_MAX];
|
||
|
|
||
|
bool is_isp1763;
|
||
|
const struct isp1760_memory_layout *memory_layout;
|
||
|
|
||
|
spinlock_t lock;
|
||
|
struct isp1760_slotinfo *atl_slots;
|
||
|
int atl_done_map;
|
||
|
struct isp1760_slotinfo *int_slots;
|
||
|
int int_done_map;
|
||
|
struct isp1760_memory_chunk memory_pool[ISP176x_BLOCK_MAX];
|
||
|
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;
|
||
|
};
|
||
|
|
||
|
#ifdef CONFIG_USB_ISP1760_HCD
|
||
|
int isp1760_hcd_register(struct isp1760_hcd *priv, 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,
|
||
|
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_ */
|