?? usblib.c
字號:
/*********************************************************************************************
* File: usblib.c
* Author: embest
* Desc: S3C2410X USB library functions
* History:
* R.X.Huang, March 12, 2005
* Programming modify, style of the program: nomenclature, commentary
* Y.J.Guo, April 28, 2005
* Modifying and reusing of S3C2410X u24xmon
*********************************************************************************************/
/*------------------------------------------------------------------------------------------*/
/* include files */
/*------------------------------------------------------------------------------------------*/
#include <string.h>
#include "2410lib.h"
#include "2410usb.h"
#include "usbmain.h"
#include "usblib.h"
#include "usbsetup.h"
#include "usbmain.h"
/*********************************************************************************************
* name: ConfigUsbd
* func: configuration of USBD
* para: none
* ret: none
* modify:
* comment:
*********************************************************************************************/
void ConfigUsbd(void)
{
ReconfigUsbd();
rINTMSK &= ~(BIT_USBD);
}
void ReconfigUsbd(void)
{
// *** End point information ***
// EP0: control
// EP1: bulk in end point
// EP2: not used
// EP3: bulk out end point
// EP4: not used
rPWR_REG=PWR_REG_DEFAULT_VALUE; //disable suspend mode
rINDEX_REG=0;
rMAXP_REG=FIFO_SIZE_8; //EP0 max packit size = 8
rEP0_CSR=EP0_SERVICED_OUT_PKT_RDY|EP0_SERVICED_SETUP_END; //EP0:clear OUT_PKT_RDY & SETUP_END
rINDEX_REG=1;
#if (EP1_PKT_SIZE==32)
rMAXP_REG=FIFO_SIZE_32; //EP1:max packit size = 32
#else
rMAXP_REG=FIFO_SIZE_64; //EP1:max packit size = 64
#endif
rIN_CSR1_REG=EPI_FIFO_FLUSH|EPI_CDT;
rIN_CSR2_REG=EPI_MODE_IN|EPI_IN_DMA_INT_MASK|EPI_BULK; //IN mode, IN_DMA_INT=masked
rOUT_CSR1_REG=EPO_CDT;
rOUT_CSR2_REG=EPO_BULK|EPO_OUT_DMA_INT_MASK;
rINDEX_REG=2;
rMAXP_REG=FIFO_SIZE_64; //EP2:max packit size = 64
rIN_CSR1_REG=EPI_FIFO_FLUSH|EPI_CDT|EPI_BULK;
rIN_CSR2_REG=EPI_MODE_IN|EPI_IN_DMA_INT_MASK; //IN mode, IN_DMA_INT=masked
rOUT_CSR1_REG=EPO_CDT;
rOUT_CSR2_REG=EPO_BULK|EPO_OUT_DMA_INT_MASK;
rINDEX_REG=3;
#if (EP3_PKT_SIZE==32)
rMAXP_REG=FIFO_SIZE_32; //EP3:max packit size = 32
#else
rMAXP_REG=FIFO_SIZE_64; //EP3:max packit size = 64
#endif
rIN_CSR1_REG=EPI_FIFO_FLUSH|EPI_CDT|EPI_BULK;
rIN_CSR2_REG=EPI_MODE_OUT|EPI_IN_DMA_INT_MASK; //OUT mode, IN_DMA_INT=masked
rOUT_CSR1_REG=EPO_CDT;
//clear OUT_PKT_RDY, data_toggle_bit.
//The data toggle bit should be cleared when initialization.
rOUT_CSR2_REG=EPO_BULK|EPO_OUT_DMA_INT_MASK;
rINDEX_REG=4;
rMAXP_REG=FIFO_SIZE_64; //EP4:max packit size = 64
rIN_CSR1_REG=EPI_FIFO_FLUSH|EPI_CDT|EPI_BULK;
rIN_CSR2_REG=EPI_MODE_OUT|EPI_IN_DMA_INT_MASK; //OUT mode, IN_DMA_INT=masked
rOUT_CSR1_REG=EPO_CDT;
//clear OUT_PKT_RDY, data_toggle_bit.
//The data toggle bit should be cleared when initialization.
rOUT_CSR2_REG=EPO_BULK|EPO_OUT_DMA_INT_MASK;
rEP_INT_REG=EP0_INT|EP1_INT|EP2_INT|EP3_INT|EP4_INT;
rUSB_INT_REG=RESET_INT|SUSPEND_INT|RESUME_INT; //Clear all usbd pending bits
//EP0,1,3 & reset interrupt are enabled
rEP_INT_EN_REG=EP0_INT|EP1_INT|EP3_INT;
rUSB_INT_EN_REG=RESET_INT;
ep0State=EP0_STATE_INIT;
}
/*********************************************************************************************
* name: RdPktEp0
* func: read packet of EP0
* para: UINT8T *buf -- pointer to buffer
* int num -- buffer size
* ret: none
* modify:
* comment:
*********************************************************************************************/
void RdPktEp0(UINT8T *buf,int num)
{
int i;
for(i=0;i<num;i++)
{
buf[i]=(UINT8T)rEP0_FIFO;
}
}
/*********************************************************************************************
* name: WrPktEp0
* func: write packet of EP0 FIFO
* para: UINT8T *buf -- pointer to buffer
* int num -- buffer size
* ret: none
* modify:
* comment:
*********************************************************************************************/
void WrPktEp0(UINT8T *buf,int num)
{
int i;
for(i=0;i<num;i++)
{
rEP0_FIFO=buf[i];
}
}
/*********************************************************************************************
* name: WrPktEp1
* func: write packet of EP1 FIFO
* para: UINT8T *buf -- pointer to buffer
* int num -- buffer size
* ret: none
* modify:
* comment:
*********************************************************************************************/
void WrPktEp1(UINT8T *buf,int num)
{
int i;
for(i=0;i<num;i++)
{
rEP1_FIFO=buf[i];
}
}
/*********************************************************************************************
* name: WrPktEp2
* func: write packet of EP2 FIFO
* para: UINT8T *buf -- pointer to buffer
* int num -- buffer size
* ret: none
* modify:
* comment:
*********************************************************************************************/
void WrPktEp2(UINT8T *buf,int num)
{
int i;
for(i=0;i<num;i++)
{
rEP2_FIFO=buf[i];
}
}
/*********************************************************************************************
* name: RdPktEp3
* func: read packet of EP3
* para: UINT8T *buf -- pointer to buffer
* int num -- buffer size
* ret: none
* modify:
* comment:
*********************************************************************************************/
void RdPktEp3(UINT8T *buf,int num)
{
int i;
for(i=0;i<num;i++)
{
buf[i]=(UINT8T)rEP3_FIFO;
}
}
/*********************************************************************************************
* name: RdPktEp4
* func: read packet of EP4
* para: UINT8T *buf -- pointer to buffer
* int num -- buffer size
* ret: none
* modify:
* comment:
*********************************************************************************************/
void RdPktEp4(UINT8T *buf,int num)
{
int i;
for(i=0;i<num;i++)
{
buf[i]=(UINT8T)rEP4_FIFO;
}
}
/*********************************************************************************************
* name: ConfigEp3DmaMode
* func: Configure EP3 to DMA mode for bulking out
* para: UINT32T bufAddr -- buffer address
* UINT32T count -- buffer size
* ret: none
* modify:
* comment:
*********************************************************************************************/
void ConfigEp3DmaMode(UINT32T bufAddr,UINT32T count)
{
int i;
rINDEX_REG=3;
count=count&0xfffff; //transfer size should be <1MB
rDISRCC2=(1<<1)|(1<<0);
rDISRC2=ADDR_EP3_FIFO; //src=APB,fixed,src=EP3_FIFO
rDIDSTC2=(0<<1)|(0<<0);
rDIDST2=bufAddr; //dst=AHB,increase,dst=bufAddr
#if USBDMA_DEMAND
//demand,requestor=APB,CURR_TC int enable,unit transfer,
//single service,src=USBD,H/W request,autoreload,byte,CURR_TC
rDCON2=(count)|(0<<31)|(0<<30)|(1<<29)|(0<<28)|(0<<27)|(4<<24)|(1<<23)|(0<<22)|(0<<20);
#else
//handshake,requestor=APB,CURR_TC int enable,unit transfer,
//single service,src=USBD,H/W request,autoreload,byte,CURR_TC
rDCON2=(count)|(1<<31)|(0<<30)|(1<<29)|(0<<28)|(0<<27)|(4<<24)|(1<<23)|(0<<22)|(0<<20);
#endif
rDMASKTRIG2= (1<<1); //DMA 2 on
rEP3_DMA_TTC_L=0xff;
rEP3_DMA_TTC_M=0xff;
rEP3_DMA_TTC_H=0x0f;
rOUT_CSR2_REG=rOUT_CSR2_REG|EPO_AUTO_CLR|EPO_OUT_DMA_INT_MASK; //AUTO_CLR(OUT_PKT_READY is cleared automatically), interrupt_masking.
#if USBDMA_DEMAND
rEP3_DMA_UNIT=EP3_PKT_SIZE; //DMA transfer unit=64 bytes
rEP3_DMA_CON=UDMA_DEMAND_MODE|UDMA_OUT_DMA_RUN|UDMA_DMA_MODE_EN; // deamnd enable,out_dma_run=run,in_dma_run=stop,DMA mode enable
#else
rEP3_DMA_UNIT=0x01; //DMA transfer unit=1byte
rEP3_DMA_CON=UDMA_OUT_DMA_RUN|UDMA_DMA_MODE_EN; // deamnd disable,out_dma_run=run,in_dma_run=stop,DMA mode enable
#endif
//wait until DMA_CON is effective.
rEP3_DMA_CON;
for(i=0;i<10;i++);
}
/*********************************************************************************************
* name: ConfigEp3IntMode
* func: Configure EP3 to Interrupt mode for bulking out
* para: UINT32T bufAddr -- buffer address
* UINT32T count -- buffer size
* ret: none
* modify:
* comment:
*********************************************************************************************/
void ConfigEp3IntMode(void)
{
rINDEX_REG=3;
rDMASKTRIG2= (0<<1); // EP3=DMA ch 2 -- DMA channel off
rOUT_CSR2_REG=rOUT_CSR2_REG&~(EPO_AUTO_CLR/*|EPO_OUT_DMA_INT_MASK*/);
//AUTOCLEAR off,interrupt_enabled (???)
rEP3_DMA_UNIT=1;
rEP3_DMA_CON=0; // deamnd disable,out_dma_run=stop,in_dma_run=stop,DMA mode disable
//wait until DMA_CON is effective.
rEP3_DMA_CON;
}
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -