亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 2410iis.c

?? S3C2410_TEST.rar
?? C
?? 第 1 頁 / 共 2 頁
字號:
        _WrL3Data(0xc4,0);      //1100 0,100  : Extended addr(3bits), 100 
        _WrL3Data(0x91,0);      //100,1 00,01 : DATA0, Enable AGC, 00, input amplifier gain channel 2 (2bits)                                  

//        _WrL3Addr(0x14 + 0);    //DATA0 (000101xx+00)
        _WrL3Data(0xc2,0);      //1100 0,010  : Extended addr(3bits), 010 
//        _WrL3Data(0x4d,0);      //010,0 11,01 : DATA0, MIC Amplifier Gain 9dB, input channel 1 select(input channel 2 off) 
        _WrL3Data(0x59,0);      //010,1 10,01 : DATA0, MIC Amplifier Gain 27dB, input channel 1 select(input channel 2 off)
//        _WrL3Data(0x41,0);      //010,0 00,01 : DATA0, MIC Amplifier Gain -3dB, input channel 1 select(input channel 2 off)
    }

}

//===================================================================
void ChangeDMA2(void)
{
    if(which_Buf)
    {
        rDISRCC2 = (0<<1) + (0<<0);                         //AHB, Increment
        rDISRC2  = (int)(Buf + 0x30);                       //0x31000030~(Remove header)
    }
    else
    {
        rDISRCC2 = (0<<1) + (0<<0);                         //AHB, Increment
        rDISRC2  = (int)(Buf + 0x30+(size/2));              //0x31000030 + size/2~
    }
}

//===================================================================
void IIS_PortSetting(void)
{
//----------------------------------------------------------
//   PORT B GROUP
//Ports  :   GPB4    GPB3   GPB2  
//Signal :  L3CLOCK L3DATA L3MODE
//Setting:   OUTPUT OUTPUT OUTPUT 
//           [9:8]   [7:6}  [5:4]
//Binary :     01  ,   01    01 
//----------------------------------------------------------    
    rGPBUP  = rGPBUP  & ~(0x7<<2) | (0x7<<2);   //The pull up function is disabled GPB[4:2] 1 1100    
    rGPBCON = rGPBCON & ~(0x3f<<4) | (0x15<<4); //GPB[4:2]=Output(L3CLOCK):Output(L3DATA):Output(L3MODE)

//----------------------------------------------------------
//   PORT E GROUP
//Ports  :  GPE4    GPE3   GPE2  GPE1    GPE0 
//Signal : I2SSDO  I2SSDI CDCLK I2SSCLK I2SLRCK 
//Binary :   10  ,   10     10 ,  10      10    
//----------------------------------------------------------
    rGPEUP  = rGPEUP  & ~(0x1f)  | 0x1f;    //The pull up function is disabled GPE[4:0] 1 1111
    rGPECON = rGPECON & ~(0x3ff) | 0x2aa;   //GPE[4:0]=I2SSDO:I2SSDI:CDCLK:I2SSCLK:I2SLRCK

    rGPFUP   = ((rGPFUP   & ~(1<<0)) | (1<<0));     //GPF0
    rGPFCON  = ((rGPFCON  & ~(3<<0)) | (1<<1));     //GPF0=EINT0    
    
    rEXTINT0 = ((rEXTINT0 & ~(7<<0)) | (2<<0));     //EINT0=falling edge triggered  
}

//===================================================================
void _WrL3Addr(U8 data)
{       
    S32 i,j;

    rGPBDAT  = rGPBDAT & ~(L3D | L3M | L3C) | L3C;      //L3D=L, L3M=L(in address mode), L3C=H

    for(j=0;j<4;j++);                   //tsu(L3) > 190ns

      //GPB[4:2]=L3C:L3D:L3M
    for(i=0;i<8;i++)                    //LSB first
    {
        if(data & 0x1)                  //If data's LSB is 'H'
        {
            rGPBDAT &= ~L3C;            //L3C=L
            rGPBDAT |= L3D;             //L3D=H             
            for(j=0;j<4;j++);           //tcy(L3) > 500ns
            rGPBDAT |= L3C;             //L3C=H
            rGPBDAT |= L3D;             //L3D=H
            for(j=0;j<4;j++);           //tcy(L3) > 500ns
        }
        else                            //If data's LSB is 'L'
        {
            rGPBDAT &= ~L3C;            //L3C=L
            rGPBDAT &= ~L3D;            //L3D=L
            for(j=0;j<4;j++);           //tcy(L3) > 500ns
            rGPBDAT |= L3C;             //L3C=H
            rGPBDAT &= ~L3D;            //L3D=L
            for(j=0;j<4;j++);           //tcy(L3) > 500ns            
        }
        data >>= 1;
    }
    rGPBDAT  = rGPBDAT & ~(L3D | L3M | L3C) | (L3C | L3M);       //L3M=H,L3C=H   
}

//===================================================================
void _WrL3Data(U8 data,int halt)
{
    S32 i,j;

    if(halt)
    {
        rGPBDAT  = rGPBDAT & ~(L3D | L3M | L3C) | L3C;   //L3C=H(while tstp, L3 interface halt condition)        
        for(j=0;j<4;j++);                                //tstp(L3) > 190ns
    }

    rGPBDAT  = rGPBDAT & ~(L3D | L3M | L3C) | (L3C | L3M);   //L3M=H(in data transfer mode)        
    for(j=0;j<4;j++);                                        //tsu(L3)D > 190ns

      //GPB[4:2]=L3C:L3D:L3M
    for(i=0;i<8;i++)
    {
        if(data & 0x1)                   //if data's LSB is 'H'
        {
           rGPBDAT &= ~L3C;              //L3C=L
           rGPBDAT |= L3D;               //L3D=H
           for(j=0;j<4;j++);             //tcy(L3) > 500ns
           rGPBDAT |= (L3C | L3D);       //L3C=H,L3D=H
           for(j=0;j<4;j++);             //tcy(L3) > 500ns
        }
        else                             //If data's LSB is 'L'
        {
           rGPBDAT &= ~L3C;              //L3C=L
           rGPBDAT &= ~L3D;              //L3D=L
           for(j=0;j<4;j++);             //tcy(L3) > 500ns
           rGPBDAT |= L3C;               //L3C=H
           rGPBDAT &= ~L3D;              //L3D=L
           for(j=0;j<4;j++);             //tcy(L3) > 500ns
        }
        data >>= 1;                      //For check next bit
    }
    rGPBDAT  = rGPBDAT & ~(L3D | L3M | L3C) | (L3C | L3M);    //L3M=H,L3C=H
}

//===================================================================
void __irq DMA2_Done(void)
{
    ClearPending(BIT_DMA2);     //Clear pending bit

    WrUTXH0('@');
    if(!which_Buf)
        which_Buf = 1;
    else
        which_Buf = 0;
}

//===================================================================
void __irq DMA2_Rec_Done(void)
{
    ClearPending(BIT_DMA2);     //Clear pending bit
    Rec_Done = 1;
}

//===================================================================
void __irq RxInt(void)
{
    rSUBSRCPND = BIT_SUB_RXD0;          //Clear pending bit (Requested)
    rSUBSRCPND;
    ClearPending(BIT_UART0);

    *_temp ++= RdURXH0(); 
}

//===================================================================
void __irq Muting(void)
{
    ClearPending(BIT_EINT0);            //Clear pending bit

    if(mute)    //Mute
    {
        _WrL3Addr(0x14 + 0);            //DATA0 (000101xx+00)
        _WrL3Data(0xa4,0);              //10,1,00,1,00 : after, no de-emp, mute, flat 
        mute = 0;
        Uart_Printf("= Mute =\n");
    }
    else        //No mute
    {
        _WrL3Addr(0x14 + 0);            //DATA0 (000101xx+00)
        _WrL3Data(0xa0,0);              //10,1,00,0,00 : after, no de-emp, no mute, flat 
        mute = 1;
        Uart_Printf("= No Mute =\n");
    }
}

//=======[ Added Slave mode Test Program as Bellow --> July 24, 2002 Tark, SOP ]=====

volatile int Tx_Done;
volatile int Rx_Done;

void __irq TR_Done(void)
{
    ClearPending(BIT_DMA2);     //Clear pending bit

    Rx_Done = 1;
    Tx_Done = 1;
//    WrUTXH0('.');
}

//===================================================================
void Iis_Tx(void)
{
    unsigned int i ;
    unsigned short *txdata;

    Tx_Done = 0;
    Uart_TxEmpty(0);

    Uart_Printf("[ IIS Slave Tx test ]\n");

    IIS_PortSetting();

      //Tx DATA initialize 
    txdata = (unsigned short *)0x31000000;
    
    for(i=0;i<DataCount;i++)
        *(txdata+i) = i;    

      //IIS Initialize
      //Slave[8],Tx[7:6],L-ch=low[5],MSB[4],16bit ch[3],CDCLK[2]=256fs,IISCLK[1:0]=32fs
    rIISMOD  = (1<<8) + (2<<6) + (0<<5) + (1<<4) + (1<<3) + (0<<2) + (1<<0);
    rIISPSR  = (2<<5) + 2;              //Prescaler_A/B=2 <- FCLK 135.4752MHz(1:2:4),11.2896MHz(256fs),44.1KHz
    rIISFCON = (0<<15) + (1<<13);       //Tx Normal[15],Tx FIFO Enable[13] --> start piling....  
      //Tx DMA disable[5],Rx DMA disable[4],Tx not idle[3],Rx idle[2],prescaler enable[1],stop[0]
    rIISCON  = (0<<5) + (0<<4) + (0<<3) + (1<<2) + (1<<1) + (0<<0);            
   
      //Tx start
    rIISCON |=0x1;
    
    for(i=0;i<DataCount;i++)
    {
        while( (rIISCON & 0x080) == 0x80 );     //wait when fifo is not empty.
        *IISFIFO = *(txdata+i);                 // put the data into fifo        
    }

      //Tx Stop(Slave)
    Delay(10);
    rIISCON     = 0x0;          //IIS stop
    rDMASKTRIG2 = (1<<2);       //DMA2 stop
    rIISFCON    = 0x0;          //for FIFO flush

    Uart_Printf("\nTx End...\n");

    Uart_Printf("Last 256 Half-Word in 65KBytes transferred data\n");
    
    for(i=0;i<DataDisplay;i++)
    {
        Uart_Printf("0x%x=",(txdata+0xff00+i));
        Uart_Printf("%04x   ",*(txdata+0xff00+i));        
    }
}
  
//===================================================================
void Iis_Rx(void)
{
    unsigned int i ;
    unsigned short *rxdata;

    Rx_Done = 0;
    Uart_TxEmpty(0);

#if PollMode
    Uart_Printf("[ IIS Master Rx Polling mode test ]\n");
#endif

#if DMA2Mode
    Uart_Printf("[ IIS Master Rx DMA2 mode test ]\n");
#endif
    
    IIS_PortSetting();

    pISR_DMA2= (unsigned)TR_Done;
    rINTMSK  = ~(BIT_DMA2);

      //Rx Buf initialize
    rxdata=(unsigned short *)0x31000000;
    
    for(i=0;i<DataCount;i++)
        *(rxdata+i)=0x0;
        
#if DMA2Mode
      //DMA2 Initialize
    rDISRCC2 = (1<<1) + (1<<0);     //The source is in the system bus(APB), address Fixed
    rDISRC2  = ((U32)IISFIFO);      //Base address (start address) of source to transfer(IISFIFO)
    rDIDSTC2 = (0<<1) + (0<<0);     //The destination is in the system bus (AHB), address Increment.
    rDIDST2  = (int)rxdata;         //Base address (start address) of destination to transfer(0x31000000)
    rDCON2   = (1<<31)+(0<<30)+(1<<29)+(0<<28)+(0<<27)+(1<<24)+(1<<23)+(1<<22)+(1<<20)+(DataCount);
      //Handshake[31], sync PCLK[30], TC int[29], single tx[28], single service[27], I2SSDI[24], I2S request[23], 
      //off-reload[22], half-word[20], Initial transfer count=DataCount      
    rDMASKTRIG2 = (0<<2)+(1<<1)+0;  //No-stop, DMA2 channel on, No-sw trigger 
 
      //IIS Initialize (DMA Mode)
      //Master[8],Rx[7:6],L-ch=low[5],MSB[4],16bit ch[3],CDCLK[2]=256fs,IISCLK[1:0]=32fs
    rIISMOD  = (0<<8) + (1<<6) + (0<<5) + (1<<4) + (1<<3) + (0<<2) + (1<<0);
    rIISPSR  = (2<<5) + 2;            //Prescaler_A/B=2 <- FCLK 135.4752MHz(1:2:4),11.2896MHz(256fs),44.1KHz
    rIISFCON = (1<<14) + (1<<12);     //Rx DMA[14],Rx FIFO Enable[12]--> start piling....    
      //Tx DMA disable[5],Rx DMA enable[4],Tx idle[3],Rx not idle[2],prescaler enable[1],stop[0]
    rIISCON  = (0<<5) + (1<<4) + (1<<3) + (0<<2) + (1<<1) + (0<<0);    
#endif

#if PollMode
      //IIS Initialize (Polling Mode)
      //Master[8],Rx[7:6],L-ch=low[5],MSB[4],16bit ch[3],CDCLK[2]=256fs,IISCLK[1:0]=32fs
    rIISMOD  = (0<<8) + (1<<6) + (0<<5) + (1<<4) + (1<<3) + (0<<2) + (1<<0);
    rIISPSR  = (2<<5) + 2;            //Prescaler_A/B=2 <- FCLK 135.4752MHz(1:2:4),11.2896MHz(256fs),44.1KHz
    rIISFCON = (0<<14) + (1<<12);     //Rx normal[14],Rx FIFO Enable[12]--> start piling.... 
      //Tx DMA disable[5],Rx DMA disable[4],Tx idle[3],Rx not idle[2],prescaler enable[1],stop[0]
    rIISCON  = (0<<5) + (0<<4) + (1<<3) + (0<<2) + (1<<1) + (0<<0);    
#endif

      //Rx start
    rIISCON |= 0x1;

#if PollMode       //*** Need to Polling mode ***
    count = DataCount;                 
    while(0<count) 
    {
        j = rIISFCON & 0x1f;            //Rx FIFO data count(Read only)=31
        if(j == 0)
        {
            while(!j)
                j = rIISFCON & 0x1f;    //Rx FIFO data count(Read only)=31
         }
        
        for(i=0;i<j;i++)
        {
            count--;
            *rxdata++ = *IISFIFO;                   
        }
    }
#endif    

#if DMA2Mode  
    while(!Rx_Done);
#endif

      //Rx Stop(Master)
    Delay(10);
    rIISCON     = 0x0;          //IIS stop
    rDMASKTRIG2 = (1<<2);       //DMA2 stop
    rIISFCON    = 0x0;          //for FIFO flush

    Uart_Printf("Last 256 Half-Word in 65KBytes received data\n");

    rxdata=(unsigned short *)0x31000000;  
    
    for(i=0;i<DataDisplay;i++)
    {
        Uart_Printf("0x%x=", (rxdata+0xff00+i));        
        Uart_Printf("%04x   ",*(rxdata+0xff00+i));                
    }
    rINTMSK = (BIT_DMA2);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩一区二区免费在线观看| 国产欧美一区二区精品性色| 精品国产一区二区三区四区四| 国产欧美精品一区二区色综合朱莉| 亚洲欧美二区三区| 久久99国产精品免费网站| 91美女在线视频| 国产日韩欧美亚洲| 精品一区二区三区免费| 欧美精品123区| 一区二区三区在线观看国产| 国产一区二区h| 日本高清免费不卡视频| 精品久久久久香蕉网| 亚洲精品视频观看| 国产成人欧美日韩在线电影| 欧美午夜一区二区三区免费大片| 国产日韩精品一区二区三区在线| 蜜臀久久99精品久久久久久9| 日本高清无吗v一区| 亚洲欧洲一区二区三区| 国产精品99久久久| 久久久噜噜噜久久人人看| 日韩 欧美一区二区三区| 欧美三级蜜桃2在线观看| 亚洲色图欧洲色图| 色狠狠色噜噜噜综合网| 亚洲男同性视频| 99国产精品国产精品毛片| 国产精品国产a| 91免费版在线| 欧美高清视频在线高清观看mv色露露十八| 怡红院av一区二区三区| 久久婷婷久久一区二区三区| 欧美精品一二三| caoporm超碰国产精品| 国产麻豆精品在线观看| 国产自产v一区二区三区c| 亚洲欧美另类久久久精品| 国产女同互慰高潮91漫画| 日韩女优电影在线观看| 欧美日精品一区视频| 欧美最猛性xxxxx直播| 色妞www精品视频| www.激情成人| 高清不卡一区二区在线| 成人少妇影院yyyy| 成人午夜精品在线| 韩国成人福利片在线播放| 26uuu另类欧美亚洲曰本| 99久久久久久| 成人激情动漫在线观看| 一本色道亚洲精品aⅴ| 国产日韩欧美在线一区| 粉嫩绯色av一区二区在线观看| 欧美一级精品在线| 亚洲精品写真福利| 欧美三级视频在线| 狠狠色丁香久久婷婷综| 国产精品久久久久影视| 欧美视频一区二| 国产在线精品一区在线观看麻豆| 国产精品无遮挡| 欧美色区777第一页| 国模大尺度一区二区三区| 中文字幕在线不卡| 91精品久久久久久久91蜜桃| 国产乱人伦偷精品视频免下载| 亚洲欧美国产77777| 日韩一级在线观看| proumb性欧美在线观看| 日韩成人av影视| 国产精品毛片久久久久久| 欧美精品欧美精品系列| 不卡的av中国片| 日本成人中文字幕在线视频| 国产精品污www在线观看| 欧美日韩电影在线| 处破女av一区二区| 日韩av电影一区| 亚洲欧美日韩久久| 国产亚洲综合av| 欧美伦理影视网| 色呦呦一区二区三区| 寂寞少妇一区二区三区| 亚洲超碰97人人做人人爱| 欧美国产精品久久| 日韩欧美在线123| 色av成人天堂桃色av| 国产丶欧美丶日本不卡视频| 日韩精品一区第一页| 亚洲色图都市小说| 国产清纯美女被跳蛋高潮一区二区久久w | 久久综合中文字幕| 欧美老肥妇做.爰bbww视频| 不卡的av中国片| 国产成人精品一区二区三区四区| 天涯成人国产亚洲精品一区av| 亚洲欧洲av在线| 国产午夜精品一区二区三区视频| 日韩一区二区三区四区五区六区| 欧美丝袜丝交足nylons图片| 色综合天天在线| jiyouzz国产精品久久| 国产乱淫av一区二区三区 | 亚洲精品免费在线观看| 国产精品视频一二三区| 国产情人综合久久777777| 久久久久亚洲蜜桃| 国产亚洲一区二区三区四区| 26uuu亚洲综合色| 久久综合久久综合久久| 26uuu精品一区二区在线观看| 日韩一区二区三区在线视频| 欧美一区二区二区| 9191精品国产综合久久久久久| 欧美在线不卡一区| 欧美吻胸吃奶大尺度电影| 欧美日韩国产综合一区二区| 精品视频一区二区三区免费| 欧美夫妻性生活| 日韩视频免费直播| 精品国产sm最大网站免费看| 久久蜜桃av一区精品变态类天堂 | 国产精品一二三| 经典三级一区二区| 成人综合婷婷国产精品久久| 成人av网站在线观看| 91蜜桃视频在线| 欧美片网站yy| 精品国产一区二区精华| 国产亚洲综合在线| 亚洲女与黑人做爰| 爽好多水快深点欧美视频| 麻豆成人免费电影| 国产精品一区二区久激情瑜伽 | 秋霞电影一区二区| 久久久国产精华| 国产喷白浆一区二区三区| 国产日本欧美一区二区| 亚洲精品日韩专区silk| 日韩精品视频网站| 国产a久久麻豆| 欧美午夜不卡视频| 精品播放一区二区| 亚洲乱码国产乱码精品精小说| 性久久久久久久久| 国产精品香蕉一区二区三区| 91久久人澡人人添人人爽欧美| 91麻豆精品国产| 中文字幕不卡三区| 日韩中文欧美在线| 高清在线不卡av| 这里只有精品视频在线观看| 久久蜜桃香蕉精品一区二区三区| 亚洲天堂成人网| 六月丁香婷婷色狠狠久久| www.欧美.com| 精品处破学生在线二十三| 一区二区视频在线| 国产主播一区二区三区| 日韩精品综合一本久道在线视频| 日韩一区欧美一区| 国产精品996| 精品污污网站免费看| 国产性色一区二区| 天堂成人免费av电影一区| 国产suv精品一区二区6| 91精品欧美久久久久久动漫| 日韩一区日韩二区| 国产一区二区三区四| 538prom精品视频线放| 18涩涩午夜精品.www| 国产高清亚洲一区| 91精品中文字幕一区二区三区| 亚洲三级小视频| 国产成人小视频| 精品对白一区国产伦| 午夜a成v人精品| 日本道免费精品一区二区三区| 日本一区二区三级电影在线观看 | 91久久精品国产91性色tv| 欧美大度的电影原声| 国内精品伊人久久久久av影院 | 亚洲欧洲综合另类| 岛国一区二区三区| 亚洲视频在线一区二区| 成人精品国产一区二区4080| 久久久久久免费毛片精品| 激情丁香综合五月| 国产农村妇女毛片精品久久麻豆 | 精品成人免费观看| 蜜桃在线一区二区三区| 久久青草国产手机看片福利盒子| 精品一区二区三区香蕉蜜桃| 亚洲精品第1页| 91精品国产91久久久久久一区二区| 国产福利91精品一区| 欧美精品 日韩| 国产一区二区剧情av在线|