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

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

?? 2410iis.c

?? ads開發s3c2410與uda1341源代碼,不同的開發板進行相應的修改即可
?? C
?? 第 1 頁 / 共 2 頁
字號:
//        _WrL3Addr(0x14 + 0);    //DATA0 (000101xx+00)        
        _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, j;
    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, j, k, count;
    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精品一区二区三区| 99久久精品免费看| 日韩女优电影在线观看| 亚洲第一电影网| 99国内精品久久| 国产免费成人在线视频| 久久99精品一区二区三区| 欧美日韩一区久久| 亚洲欧美另类小说视频| 东方欧美亚洲色图在线| 日韩精品中文字幕在线不卡尤物| 亚洲精品高清在线观看| 972aa.com艺术欧美| 久久人人爽人人爽| 久久99久久99| 欧美不卡一区二区三区四区| 图片区日韩欧美亚洲| a4yy欧美一区二区三区| 精品国产一区二区亚洲人成毛片 | 欧美激情一区在线| 久久99精品久久久久久国产越南 | 性做久久久久久免费观看欧美| 粉嫩在线一区二区三区视频| 精品av综合导航| 久久99国产精品免费网站| 欧美日韩国产a| 一区二区理论电影在线观看| 91丨porny丨中文| 国产精品毛片久久久久久| 成人一区二区在线观看| 国产精品美女一区二区在线观看| 国产乱对白刺激视频不卡| 欧美浪妇xxxx高跟鞋交| 五月天激情综合网| 日韩一区二区在线播放| 狠狠色丁香久久婷婷综合_中 | 欧美日韩国产一二三| 亚洲一区免费视频| 久久久av毛片精品| 国内成+人亚洲+欧美+综合在线| 欧美mv日韩mv国产网站app| 久久99热这里只有精品| 久久精品亚洲麻豆av一区二区 | 国产精品嫩草久久久久| 97久久超碰精品国产| 亚洲主播在线播放| 91精品国产免费久久综合| 狠狠色丁香九九婷婷综合五月| 国产亚洲欧洲一区高清在线观看| 不卡视频在线观看| 亚洲国产精品嫩草影院| 91精品国产欧美日韩| 国产91精品一区二区麻豆亚洲| 中文字幕一区二| 欧美日韩国产精品成人| 久88久久88久久久| 中文字幕一区二区三区精华液| 欧美三级日韩三级| 国产酒店精品激情| 亚洲自拍偷拍网站| 久久综合久久综合亚洲| 91女神在线视频| 精品在线免费观看| 亚洲色图丝袜美腿| 久久综合色婷婷| 欧美日韩一区精品| 高清不卡在线观看| 五月天欧美精品| 亚洲区小说区图片区qvod| 日韩三级.com| 91丨porny丨户外露出| 蜜桃久久久久久| 亚洲欧美一区二区三区久本道91 | 美女高潮久久久| 国产精品福利一区| 日韩你懂的电影在线观看| 99精品桃花视频在线观看| 九九九久久久精品| 亚洲综合av网| 日韩精品五月天| 亚洲国产高清在线| 日韩视频免费直播| 日本大香伊一区二区三区| 狠狠v欧美v日韩v亚洲ⅴ| 一区二区三区中文在线观看| 国产亚洲美州欧州综合国| 日韩一区二区三| 欧美在线一区二区| 99国产精品久久久| 国产二区国产一区在线观看| 亚洲大片精品永久免费| 17c精品麻豆一区二区免费| 精品动漫一区二区三区在线观看| 欧美色综合天天久久综合精品| 成人禁用看黄a在线| 精品一区二区三区免费播放 | 国产一区二区三区四区五区入口| 亚洲国产美女搞黄色| 亚洲欧美日韩小说| 1区2区3区精品视频| 国产精品久久久久一区二区三区共| 日韩欧美高清一区| 91精品欧美一区二区三区综合在 | 日韩一区中文字幕| 国产精品女上位| 久久精品视频免费观看| 久久毛片高清国产| 国产午夜亚洲精品午夜鲁丝片| 久久综合色播五月| 国产亚洲一区二区三区| 国产欧美一区二区三区在线老狼| 久久久久9999亚洲精品| 欧美国产97人人爽人人喊| 欧美极品aⅴ影院| 国产精品久久一级| 亚洲欧美日韩久久| 亚洲高清视频的网址| 日韩精品色哟哟| 久久www免费人成看片高清| 激情综合色播五月| 国产成人夜色高潮福利影视| 成人性生交大片| 一本久久a久久免费精品不卡| 欧洲亚洲精品在线| 7777精品伊人久久久大香线蕉的 | 亚洲国产日产av| 全国精品久久少妇| 国产精品一区二区果冻传媒| 国产99久久久国产精品| 91国偷自产一区二区三区成为亚洲经典 | 亚洲一区二区精品久久av| 香蕉成人啪国产精品视频综合网| 男女性色大片免费观看一区二区 | 97久久精品人人澡人人爽| 日本电影欧美片| 日韩欧美一级二级三级久久久| 久久久久久久久久美女| 中文字幕日韩精品一区| 亚洲成人在线免费| 国产麻豆精品在线| 色婷婷亚洲精品| 91精品国产品国语在线不卡 | 精品国产精品一区二区夜夜嗨 | 日韩精品一区二| 亚洲图片另类小说| 理论电影国产精品| 91免费视频网| 欧美电影免费观看高清完整版在 | 麻豆freexxxx性91精品| 国产91在线观看丝袜| 欧美久久久久久久久| 国产欧美一区二区精品久导航| 亚洲精品国产一区二区三区四区在线| 日本成人在线看| 99re亚洲国产精品| 91精品国产色综合久久ai换脸 | 欧美一区二区在线看| 欧美国产日韩亚洲一区| 奇米888四色在线精品| 成人精品国产福利| 日韩精品在线看片z| 亚洲欧美福利一区二区| 国产乱色国产精品免费视频| 7777精品伊人久久久大香线蕉超级流畅 | 亚洲黄色小视频| 国产一区二区三区久久悠悠色av| 欧美中文字幕一区二区三区亚洲 | 精品国产1区2区3区| 亚洲第一主播视频| 91麻豆成人久久精品二区三区| 精品国产伦一区二区三区免费| 一级日本不卡的影视| 丰满亚洲少妇av| 精品99999| 日韩国产欧美在线播放| 日本韩国欧美一区| 中文字幕一区二区三区四区不卡| 国产乱妇无码大片在线观看| 91精品国产91久久久久久最新毛片| 亚洲最大色网站| 一本久道中文字幕精品亚洲嫩| 亚洲国产精华液网站w| 99re在线视频这里只有精品| 久久精品视频在线免费观看| 奇米影视在线99精品| 51精品秘密在线观看| 亚洲国产日韩综合久久精品| 91成人看片片| 亚洲精品乱码久久久久| 91丝袜美女网| 亚洲欧美一区二区三区久本道91| 成人va在线观看| 国产精品美女久久久久久久| 岛国精品在线播放| 一区在线观看免费| 91色乱码一区二区三区| 最新国产の精品合集bt伙计|