static void __USBC_Host_Rx_ConfigEp(__u32 usbc_base_addr, __u32 ep_index, __u32 ts_mode, __u32 ts_type, __u32 is_double_fifo, __u32 ep_MaxPkt, __u32 interval) { __u16 reg_val = 0; __u16 temp = 0; //--<1>--config rx_csr USBC_Writew((1 << USBC_BP_RXCSR_H_CLEAR_DATA_TOGGLE) | (1 << USBC_BP_RXCSR_H_FLUSH_FIFO), USBC_REG_RXCSR(usbc_base_addr)); if(is_double_fifo){ USBC_Writew((1 << USBC_BP_RXCSR_H_CLEAR_DATA_TOGGLE) | (1 << USBC_BP_RXCSR_H_FLUSH_FIFO), USBC_REG_RXCSR(usbc_base_addr)); } //--<2>--config tx ep max packet reg_val = USBC_Readw(USBC_REG_RXMAXP(usbc_base_addr)); temp = ep_MaxPkt & ((1 << USBC_BP_RXMAXP_PACKET_COUNT) - 1); reg_val |= temp; USBC_Writew(reg_val, USBC_REG_RXMAXP(usbc_base_addr)); //--<3>--config ep transfer type __USBC_Host_Rx_EpType(usbc_base_addr, ep_index, ts_mode, ts_type); //--<4>--config polling interval USBC_Writeb(interval, USBC_REG_RXINTERVAL(usbc_base_addr)); }
static void __USBC_Dev_Rx_ConfigEp_Default(ulong usbc_base_addr) { //--<1>--clear tx csr USBC_Writew(0x00, USBC_REG_RXCSR(usbc_base_addr)); //--<2>--clear tx ep max packet USBC_Writew(0x00, USBC_REG_RXMAXP(usbc_base_addr)); //--<3>--config ep transfer type }
static void __USBC_Dev_Rx_ConfigEp(ulong usbc_base_addr, __u32 ts_type, __u32 is_double_fifo, __u32 ep_MaxPkt) { __u16 reg_val = 0; __u16 temp = 0; //--<1>--config tx csr USBC_Writew((1 << USBC_BP_RXCSR_D_CLEAR_DATA_TOGGLE) | (1 << USBC_BP_RXCSR_D_FLUSH_FIFO), USBC_REG_RXCSR(usbc_base_addr)); if(is_double_fifo){ USBC_Writew((1 << USBC_BP_RXCSR_D_CLEAR_DATA_TOGGLE) | (1 << USBC_BP_RXCSR_D_FLUSH_FIFO), USBC_REG_RXCSR(usbc_base_addr)); } //--<2>--config tx ep max packet reg_val = USBC_Readw(USBC_REG_RXMAXP(usbc_base_addr)); temp = ep_MaxPkt & ((1 << USBC_BP_RXMAXP_PACKET_COUNT) - 1); reg_val &= ~(0x1fff); //added by jerry reg_val |= temp; USBC_Writew(reg_val, USBC_REG_RXMAXP(usbc_base_addr)); //--<3>--config ep transfer type switch(ts_type){ case USBC_TS_TYPE_ISO: __USBC_Dev_Rx_EnableIsoEp(usbc_base_addr); break; case USBC_TS_TYPE_INT: __USBC_Dev_Rx_EnableIntEp(usbc_base_addr); break; case USBC_TS_TYPE_BULK: __USBC_Dev_Rx_EnableBulkEp(usbc_base_addr); break; default: __USBC_Dev_Rx_EnableBulkEp(usbc_base_addr); } }
static void __USBC_Host_Rx_ConfigEp_Default(__u32 usbc_base_addr) { //--<1>--config rx_csr, 先刷fifo, 有全部清零 USBC_Writew((1 << USBC_BP_RXCSR_H_CLEAR_DATA_TOGGLE) | (1 << USBC_BP_RXCSR_H_FLUSH_FIFO), USBC_REG_RXCSR(usbc_base_addr)); USBC_Writew(0x00, USBC_REG_RXCSR(usbc_base_addr)); //--<2>--config rx ep max packet USBC_Writew(0x00, USBC_REG_RXMAXP(usbc_base_addr)); //--<3>--config ep transfer type USBC_Writeb(0x00, USBC_REG_RXTYPE(usbc_base_addr)); //--<4>--config polling interval USBC_Writeb(0x00, USBC_REG_RXINTERVAL(usbc_base_addr)); }