172 lines
6.4 KiB
C
172 lines
6.4 KiB
C
#ifndef _USB_H_
|
|
#define _USB_H_
|
|
#include "typedef.h"
|
|
#include "generic/ioctl.h"
|
|
|
|
|
|
#ifndef min
|
|
#define min(a,b) ((a)<(b) ? (a) : (b))
|
|
#endif
|
|
#ifndef USB_DIR_OUT
|
|
#define USB_DIR_OUT 0 /* to device */
|
|
#endif
|
|
#ifndef USB_DIR_IN
|
|
#define USB_DIR_IN 0x80 /* to host */
|
|
#endif
|
|
|
|
#define FUSB_MODE 1
|
|
#define EP0_SETUP_LEN 0x40
|
|
#define USB_MAX_HW_EPNUM 5
|
|
|
|
|
|
//USB_CON0
|
|
#define PHY_ON 0
|
|
#define LOW_SPEED 1
|
|
#define USB_NRST 2
|
|
#define TM1 3
|
|
#define CID 4
|
|
#define VBUS 5
|
|
#define USB_TEST 6
|
|
#define PDCHKDP 9
|
|
#define SOFIE 10
|
|
#define SIEIE 11
|
|
#define CLR_SOF_PND 12
|
|
#define SOF_PND 13
|
|
#define SIE_PND 14
|
|
#define CHKDPO 15
|
|
#define DM_SE 16
|
|
#define DP_SE 17
|
|
|
|
//USB_CON1
|
|
#define MC_RNW 14
|
|
#define MACK 15
|
|
|
|
//USB_IO_CON0
|
|
#define DPOUT 0
|
|
#define DMOUT 1
|
|
#define DPIE 2
|
|
#define DMIE 3
|
|
#define DPPD 4
|
|
#define DMPD 5
|
|
#define DPPU 6
|
|
#define DMPU 7
|
|
#define IO_PU_MODE 8
|
|
#define DPDIE 9
|
|
#define DMDIE 10
|
|
#define IO_MODE 11
|
|
#define SR 12
|
|
#define DPDIEH 13
|
|
#define DMDIEH 14
|
|
|
|
enum {
|
|
USB0,
|
|
};
|
|
|
|
#define USB_MAX_HW_NUM 1
|
|
|
|
|
|
struct usb_ep_addr_t {
|
|
u32 ep0_addr;
|
|
u32 ep_usage ;
|
|
u32 ep_taddr[4];
|
|
u32 ep_dual_taddr[4];
|
|
u32 ep_raddr[4];
|
|
u32 ep_dual_raddr[4];
|
|
u32 ep_tsize[4];
|
|
u32 ep_rsize[4];
|
|
} __attribute__((aligned(4)));
|
|
|
|
|
|
typedef u8 usb_dev;
|
|
|
|
u16 musb_read_sofframe(const usb_dev id);
|
|
u32 musb_read_usb(const usb_dev usb_id, u32 addr);
|
|
void musb_write_usb(const usb_dev usb_id, u32 addr, u32 data);
|
|
u32 usb_dev_con0(const usb_dev usb_id);
|
|
void usb_sie_enable(const usb_dev usb_id);
|
|
void usb_sie_disable(const usb_dev id);
|
|
void usb_write_ep_cnt(const usb_dev usb_id, u32 ep, u32 len);
|
|
u32 usb_g_dev_status(const usb_dev usb_id);
|
|
u32 usb_h_dev_status(const usb_dev usb_id);
|
|
void usb_set_low_speed(const usb_dev usb_id, u8 flag);
|
|
void usb_write_ep0(const usb_dev usb_id, const u8 *ptr, u32 len);
|
|
void usb_read_ep0(const usb_dev usb_id, u8 *ptr, u32 len);
|
|
void *usb_get_dma_taddr(const usb_dev usb_id, u32 ep);
|
|
u32 usb_get_dma_size(const usb_dev usb_id, u32 ep);
|
|
void usb_set_dma_tsize(const usb_dev usb_id, u32 ep, u32 size);
|
|
void usb_set_dma_rsize(const usb_dev usb_id, u32 ep, u32 size);
|
|
void usb_set_dma_taddr(const usb_dev usb_id, u32 ep, void *ptr);
|
|
void *usb_get_dma_raddr(const usb_dev usb_id, u32 ep);
|
|
void usb_set_dma_raddr(const usb_dev usb_id, u32 ep, void *ptr);
|
|
void usb_set_dma_dual_raddr(const usb_dev usb_id, u32 ep, void *ptr);
|
|
void musb_write_index(const usb_dev usb_id, u32 endpoint);
|
|
void usb_write_power(const usb_dev usb_id, u32 value);
|
|
u32 usb_read_power(const usb_dev usb_id);
|
|
u32 usb_read_devctl(const usb_dev usb_id);
|
|
void usb_write_devctl(const usb_dev usb_id, u32 value);
|
|
u32 usb_read_csr0(const usb_dev usb_id);
|
|
void usb_write_csr0(const usb_dev usb_id, u32 csr0);
|
|
void usb_ep0_ClrRxPktRdy(const usb_dev usb_id);
|
|
void usb_ep0_TxPktEnd(const usb_dev usb_id);
|
|
void usb_ep0_RxPktEnd(const usb_dev usb_id);
|
|
void usb_ep0_Set_Stall(const usb_dev usb_id);
|
|
u32 usb_read_count0(const usb_dev usb_id);
|
|
void usb_read_intre(const usb_dev usb_id,
|
|
u32 *const intr_usbe,
|
|
u32 *const intr_txe,
|
|
u32 *const intr_rxe);
|
|
|
|
void usb_read_intr(const usb_dev usb_id,
|
|
u32 *const intr_usb,
|
|
u32 *const intr_tx,
|
|
u32 *const intr_rx);
|
|
void usb_write_intr_usbe(const usb_dev usb_id, u32 intr_usbe);
|
|
void usb_set_intr_txe(const usb_dev usb_id, const u32 ep);
|
|
void usb_clr_intr_txe(const usb_dev usb_id, const u32 ep);
|
|
void usb_set_intr_rxe(const usb_dev usb_id, const u32 ep);
|
|
void usb_clr_intr_rxe(const usb_dev usb_id, const u32 ep);
|
|
void usb_write_faddr(const usb_dev usb_id, u32 addr);
|
|
void usb_write_txcsr(const usb_dev usb_id, const u32 ep, u32 txcsr);
|
|
u32 usb_read_txcsr(const usb_dev usb_id, const u32 ep);
|
|
void usb_write_rxcsr(const usb_dev usb_id, const u32 ep, u32 rxcsr);
|
|
u32 usb_read_rxcsr(const usb_dev usb_id, const u32 ep);
|
|
void usb_write_rxmaxp(const usb_dev usb_id, const u32 ep, u32 value);
|
|
void usb_write_txmaxp(const usb_dev usb_id, const u32 ep, u32 value);
|
|
void usb_write_rxtype(const usb_dev usb_id, const u32 ep, u32 value);
|
|
void usb_write_txtype(const usb_dev usb_id, const u32 ep, u32 value);
|
|
u32 usb_read_rxcount(const usb_dev usb_id, u32 ep);
|
|
u32 usb_g_ep_config(const usb_dev usb_id, const u32 ep, u32 type, u32 ie, u8 *ptr, u32 dma_size);
|
|
u32 usb_g_ep_read64byte_fast(const usb_dev usb_id, const u32 ep, u8 *ptr, u32 len);
|
|
u32 usb_g_ep_read(const usb_dev usb_id, const u32 ep, u8 *ptr, u32 len, u32 block);
|
|
u32 usb_g_ep_write(const usb_dev usb_id, u32 ep, const u8 *ptr, u32 len);
|
|
u32 usb_g_ep_config(const usb_dev usb_id, u32 ep, u32 type, u32 ie, u8 *ptr, u32 dma_size);
|
|
void usb_g_sie_init(const usb_dev usb_id);
|
|
void usb_g_hold(const usb_dev usb_id);
|
|
u32 usb_get_ep_num(const usb_dev usb_id, u32 ep_dir, u32 type);
|
|
u32 usb_h_ep_config(const usb_dev usb_id, u32 ep, u32 type, u32 ie, u32 interval, u8 *ptr, u32 dma_size);
|
|
void usb_mdelay(unsigned int ms);
|
|
u32 usb_h_ep_write(const usb_dev usb_id, u8 host_ep, u16 txmaxp, u8 target_ep, const u8 *ptr, u32 len, u32 xfer);
|
|
int usb_h_ep_write_async(const usb_dev id, u8 host_ep, u16 txmaxp, u8 target_ep, const u8 *ptr, u32 len, u32 xfer, u32 kstart);
|
|
u32 usb_h_ep_read(const usb_dev usb_id, u8 host_ep, u16 rxmaxp, u8 target_ep, u8 *ptr, u32 len, u32 xfer);
|
|
int usb_h_ep_read_async(const usb_dev id, u8 host_ep, u8 target_ep, u8 *ptr, u32 len, u32 xfer, u32 kstart);
|
|
void usb_h_sie_init(const usb_dev usb_id);
|
|
void usb_h_sie_close(const usb_dev usb_id);
|
|
void usb_h_sie_reset(const usb_dev usb_id);
|
|
void usb_hotplug_disable(const usb_dev usb_id);
|
|
void usb_hotplug_enable(const usb_dev usb_id, u32 mode);
|
|
void usb_sie_close(const usb_dev usb_id);
|
|
void usb_sie_close_all(void);
|
|
void usb_io_reset(const usb_dev usb_id);
|
|
void usb_var_init(const usb_dev usb_id, void *ptr);
|
|
void usb_var_release(const usb_dev usb_id);
|
|
void usb_enable_ep(const usb_dev usb_id, u32 eps);
|
|
void usb_disable_ep(const usb_dev usb_id, u32 eps);
|
|
u32 usb_get_ep_status(const usb_dev usb_id, u32 epx);
|
|
|
|
void usb_sofie_enable(const usb_dev id);
|
|
void usb_sofie_disable(const usb_dev id);
|
|
void usb_sof_clr_pnd(const usb_dev id);
|
|
void usb_ep0_Set_ignore(const usb_dev id, u32 addr);
|
|
void usb_recover_io_status(const usb_dev id);
|
|
#endif
|