本文整理汇总了C++中USBC_Writew函数的典型用法代码示例。如果您正苦于以下问题:C++ USBC_Writew函数的具体用法?C++ USBC_Writew怎么用?C++ USBC_Writew使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了USBC_Writew函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: __USBC_Host_Rx_ConfigEp
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));
}
示例2: __USBC_Dev_Rx_ConfigEp_Default
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
}
示例3: __USBC_Host_ep0_DisablePing
static void __USBC_Host_ep0_DisablePing(__u32 usbc_base_addr)
{
u16 csr0 = 0;
csr0 = USBC_Readw(USBC_REG_CSR0(usbc_base_addr));
csr0 |= (1 << USBC_BP_CSR0_H_DisPing);
USBC_Writew(csr0, USBC_REG_CSR0(usbc_base_addr));
}
示例4: print_all_usb_reg
/*
*******************************************************************************
* print_all_usb_reg
*
* Description:
* void
*
* Parameters:
* void
*
* Return value:
* void
*
* note:
* void
*
*******************************************************************************
*/
void print_all_usb_reg(spinlock_t *lock, __u32 usbc_base, __s32 ep_start, __u32 ep_end, char *str)
{
__u32 i = 0;
__u32 old_ep_index = 0;
unsigned long flags = 0;
if(lock){
spin_lock_irqsave(lock, flags);
}
DMSG_INFO("\n");
DMSG_INFO("-------------------print_all_usb_reg: %s----------------\n", str);
old_ep_index = USBC_Readw(usbc_base + USBC_REG_o_EPIND);
for(i = ep_start; i <= ep_end; i++){
print_usb_reg_by_ep(lock, usbc_base, i, str);
}
USBC_Writew(old_ep_index, (usbc_base + USBC_REG_o_EPIND));
DMSG_INFO("---------------------------------------------------------------------------\n");
DMSG_INFO("\n");
if(lock){
spin_unlock_irqrestore(lock, flags);
}
return;
}
示例5: sw_hcd_write_fifo
/*
*******************************************************************************
* sw_hcd_write_fifo
*
* Description:
* Load an endpoint's FIFO
*
* Parameters:
* void
*
* Return value:
* void
*
* note:
* void
*
*******************************************************************************
*/
void sw_hcd_write_fifo(struct sw_hcd_hw_ep *hw_ep, u16 len, const u8 *src)
{
void __iomem *fifo = hw_ep->fifo;
__u32 old_ep_index = 0;
prefetch((u8 *)src);
DMSG_DBG_HCD("sw_hcd_write_fifo: %cX ep%d fifo %p count %d buf %p\n",
'T', hw_ep->epnum, fifo, len, src);
old_ep_index = USBC_GetActiveEp(hw_ep->sw_hcd->sw_hcd_io->usb_bsp_hdle);
USBC_SelectActiveEp(hw_ep->sw_hcd->sw_hcd_io->usb_bsp_hdle, hw_ep->epnum);
/* we can't assume unaligned reads work */
if (likely((0x01 & (unsigned long) src) == 0)) {
u16 index = 0;
/* best case is 32bit-aligned source address */
if ((0x02 & (unsigned long) src) == 0) {
if (len >= 4) {
sw_hcd_writesl(fifo, src + index, len >> 2);
index += len & ~0x03;
}
if (len & 0x02) {
USBC_Writew(*(u16 *)&src[index], fifo);
index += 2;
}
} else {
示例6: __USBC_Host_Tx_ConfigEp_Default
static void __USBC_Host_Tx_ConfigEp_Default(__u32 usbc_base_addr)
{
//--<1>--config tx_csr, flush fifo, clear all to 0
USBC_Writew((1 << USBC_BP_TXCSR_H_CLEAR_DATA_TOGGLE) | (1 << USBC_BP_TXCSR_H_FLUSH_FIFO),
USBC_REG_TXCSR(usbc_base_addr));
USBC_Writew(0x00, USBC_REG_TXCSR(usbc_base_addr));
//--<2>--config tx ep max packet
USBC_Writew(0x00, USBC_REG_TXMAXP(usbc_base_addr));
//--<3>--config ep transfer type
USBC_Writeb(0x00, USBC_REG_TXTYPE(usbc_base_addr));
//--<4>--config polling interval
USBC_Writeb(0x00, USBC_REG_TXINTERVAL(usbc_base_addr));
}
示例7: __USBC_Dev_Tx_ClearStall
static void __USBC_Dev_Tx_ClearStall(ulong usbc_base_addr)
{
__u32 reg_val;
reg_val = USBC_Readw(USBC_REG_TXCSR(usbc_base_addr));
reg_val &= ~((1 << USBC_BP_TXCSR_D_SENT_STALL)|(1 << USBC_BP_TXCSR_D_SEND_STALL));
USBC_Writew(reg_val, USBC_REG_TXCSR(usbc_base_addr));
}
示例8: __USBC_Host_Rx_ConfigEp_Default
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));
}
示例9: __USBC_Host_ep0_StatusAfterOut
static void __USBC_Host_ep0_StatusAfterOut(__u32 usbc_base_addr)
{
__u32 reg_val = 0;
reg_val = USBC_Readw(USBC_REG_CSR0(usbc_base_addr));
reg_val |= 1 << USBC_BP_CSR0_H_ReqPkt;
reg_val |= 1 << USBC_BP_CSR0_H_StatusPkt;
USBC_Writew(reg_val, USBC_REG_CSR0(usbc_base_addr));
}
示例10: __USBC_Host_ep0_SendSetupPkt
static void __USBC_Host_ep0_SendSetupPkt(__u32 usbc_base_addr)
{
__u32 reg_val = 0;
reg_val = USBC_Readw(USBC_REG_CSR0(usbc_base_addr));
reg_val |= 1 << USBC_BP_CSR0_H_SetupPkt;
reg_val |= 1 << USBC_BP_CSR0_H_TxPkRdy;
USBC_Writew(reg_val, USBC_REG_CSR0(usbc_base_addr));
}
示例11: __USBC_Dev_Tx_WriteDataComplete
static void __USBC_Dev_Tx_WriteDataComplete(ulong usbc_base_addr)
{
__u16 ep_csr = 0;
ep_csr = USBC_Readw(USBC_REG_TXCSR(usbc_base_addr));
ep_csr |= 1 << USBC_BP_TXCSR_D_TX_READY;
ep_csr &= ~(1 << USBC_BP_TXCSR_D_UNDER_RUN);
USBC_Writew(ep_csr, USBC_REG_TXCSR(usbc_base_addr));
}
示例12: USBC_Host_ClearRqPktCount
void USBC_Host_ClearRqPktCount(__hdle hUSB, __u32 ep_index)
{
__usbc_otg_t *usbc_otg = (__usbc_otg_t *)hUSB;
if(usbc_otg == NULL){
return;
}
USBC_Writew(0x00, USBC_REG_RPCOUNTx(usbc_otg->base_addr, ep_index));
}
示例13: __USBC_Dev_Rx_ReadDataComplete
static void __USBC_Dev_Rx_ReadDataComplete(ulong usbc_base_addr)
{
__u32 reg_val = 0;
//overrun, dataerr is used in iso transfer
reg_val = USBC_Readw(USBC_REG_RXCSR(usbc_base_addr));
reg_val &= ~(1 << USBC_BP_RXCSR_D_RX_PKT_READY);
reg_val &= ~(1 << USBC_BP_RXCSR_D_OVERRUN);
reg_val &= ~(1 << USBC_BP_RXCSR_D_DATA_ERROR);
USBC_Writew(reg_val, USBC_REG_RXCSR(usbc_base_addr));
}
示例14: __USBC_Host_ep0_ConfigEp_Default
static void __USBC_Host_ep0_ConfigEp_Default(__u32 usbc_base_addr)
{
//--<1>--config ep0 csr
USBC_Writew(1<<USBC_BP_CSR0_H_FlushFIFO, USBC_REG_CSR0(usbc_base_addr));
//--<2>--config polling interval
USBC_Writeb(0x00, USBC_REG_TXINTERVAL(usbc_base_addr));
/* config ep transfer type */
USBC_Writeb(0x00, USBC_REG_EP0TYPE(usbc_base_addr));
}
示例15: __USBC_Host_ep0_ConfigEp
static void __USBC_Host_ep0_ConfigEp(__u32 usbc_base_addr, __u32 ts_mode, __u32 interval)
{
//--<1>--config ep0 csr
USBC_Writew(1<<USBC_BP_CSR0_H_FlushFIFO, USBC_REG_CSR0(usbc_base_addr));
//--<2>--config polling interval
USBC_Writeb(interval, USBC_REG_NAKLIMIT0(usbc_base_addr));
/* config ep0 transfer type */
__USBC_Host_ep0_EpType(usbc_base_addr, ts_mode);
}