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

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

?? adc_pwm_pass_channel.c

?? 基于TMS320F2812的AMR+RS編解碼+OFDM調制解調源程序。是stand alone運行版本
?? C
字號:
#include "DSP28_Device.h"
#include "RS.H"
#include "setting.h"
//#include "newamr3.h"
//#include "new3.h"

interrupt void eva_cmp1_isr(void);
interrupt void evb_cmp4_isr(void);
interrupt void adc_isr(void);

extern int16 buffer3[];
extern int16 buffer4[];
extern int16 synth[];


//WordType FrameTx = TotalFrame;
//WordType FrameRx = TotalFrame;
//WordType RxFirstFrame = 1;
WordType AdcFrame = 4;
//WordType PwmFrame = 1;
   
Uint16 i, j = 0;
Uint16 ConversionCount = 1;
Uint16 EncFlag = 0;
Uint16 DecFlag = 0;
//Uint16 PwmFlag = 1;
//Uint16 PwmConv = 0;
Uint16 DemoduFlag = 0;
Uint16 PWMOFDMStart = 0;    
Uint16 PwmoutStart = 0;                              
Uint16 PwmCount = 0;                                   //音頻輸出計數 
Uint16 pwmtestCount = 0;
Uint16 EncNum = 0;
Uint16 ModuDataOutNum = 0;                             //調制數據輸出計數
Uint16 ADCInputVoiceNum = 0;                              //音頻輸入采樣計數
Uint16 ADCModuDataNum = 88;                             //調制數據采樣輸入計數
Uint16 	Voltage1[480];                                  //音頻輸入采樣
extern int    Voltage2[3200];                                 //調制后的數據發射
int  Voltage3[3500];                                 //調制后的數據接收 
int 	Voltage4[1600];                                  //音頻輸出

int    *pModuData = Voltage2;
int    *pADCModuData = Voltage3;                       //指示待調制數據
int    ModuFrame;
//int    ModuPreFrame = 5;
//int    DemoduFrame;                                    //解調的幀數 
extern int demodushift;

int16 OFDM_frame = 0;

//extern int DataBuffer[];
Uint16 FrameSynFlag = 0; // OFDM demodulate frame synch starting flag
Uint16 FrameSyn;
Uint16 volt3flag;
int *DecoData = buffer4;
Uint16 OFDMSampleStart = 0;
Uint16 SampleDelay = 0;
Uint16 TestCnt = 0;
Uint16 Div2Flag = 1;
Uint16 BitConv = 1;

void main(void)
{
 
    DINT;
    InitSysCtrl();
    InitFlash();
       
   	EINT;
    EALLOW;
    SysCtrlRegs.HISPCP.all = 0x0000;	// HSPCLK = SYSCLKOUT = 150MHz
    EDIS;
    
    EALLOW;
    GpioMuxRegs.GPAMUX.all = 0x00FF;
    GpioMuxRegs.GPBMUX.all = 0x00FF; 
    EDIS;
   
   	DINT;
	IER = 0x0000;
	IFR = 0x0000;
	

	InitPieCtrl();
	
	InitPieVectTable();	

    InitAdc();
    
    AdcRegs.ADCTRL3.bit.ADCCLKPS = 0x0003;      //ADC clock =150/6=25M
    AdcRegs.ADCTRL1.bit.CPS = 0x0000;
   // AdcRegs.ADCTRL1.bit.ACQ_PS = 0x0009;      // SAM/HOLD = 400/10 = 40KHz  
    
    EALLOW;
	PieVectTable.ADCINT = &adc_isr;
	PieVectTable.CMP1INT  = &eva_cmp1_isr;
	PieVectTable.CMP4INT  = &evb_cmp4_isr;
	EDIS;
	
   // Configure ADC
    AdcRegs.ADCMAXCONV.all = 0x0001;       // Setup 2 conv's on SEQ1
    AdcRegs.ADCCHSELSEQ1.bit.CONV00 = 0x0000; // Setup ADCINA0 as 1st SEQ1 conv.
    AdcRegs.ADCCHSELSEQ1.bit.CONV01 = 0x0008; // Setup ADCINB0 as 2nd SEQ1 conv.
    AdcRegs.ADCTRL2.bit.EVA_SOC_SEQ1 = 1;  // Enable EVASOC to start SEQ1
    AdcRegs.ADCTRL2.bit.INT_ENA_SEQ1 = 1;  // Enable SEQ1 interrupt (every EOS)       

    // Configure EVA
	EvaRegs.EVAIMRA.all = 0x0002;
    EvaRegs.EVAIFRA.all = 0x0002;
    EvaRegs.ACTRA.all = 0x0666;
	EvaRegs.DBTCONA.all = 0x0000; // Disable Dead Band Unit
    EvaRegs.COMCONA.all = 0xA600;
    
    // Configure EVB
    EvbRegs.EVBIMRA.all = 0x0002;
    EvbRegs.EVBIFRA.all = 0x0002;
    EvbRegs.ACTRB.all = 0x0666;
    EvbRegs.DBTCONB.all = 0x0000; // Disable Dead Band Unit
    EvbRegs.COMCONB.all = 0xA600;  
   
    EvaRegs.GPTCONA.bit.T2TOADC = 2;       // Enable EVASOC in EVA
	EvaRegs.T2CNT = 0x0000;   
    EvaRegs.T2PR =0x249F;                  // SOC 采樣頻率= HSPCLK/9375 = 16K
    EvaRegs.T2CON.all = 0x1040;            // Enable timer 2 compare (upcount mode)   

	EvaRegs.T1PR = 0x249F;                 // PWM 輸出語音頻率= HSPCLK/9375=16KHz   
    EvaRegs.T1CNT = 0x0C35;   
    EvaRegs.CMPR1 = 0x0000;                // 調制后的數據發送   
    EvaRegs.T1CON.all = 0x1042;            // Enable timer 1 compare (upcount mode)       
   
    EvbRegs.T3PR = 0x249F;                 // PWM 輸出OFDM信號頻率= HSPCLK/9375=16KHz
    EvbRegs.T3CNT = 0x186A;   
    EvbRegs.CMPR4 = 0x0000;                // 解碼后的數據進行D/A
	EvbRegs.T3CON.all = 0x1042;      
   	
	PieCtrlRegs.PIEIFR1.all = 0;
	PieCtrlRegs.PIEIFR2.all = 0;
	PieCtrlRegs.PIEIFR4.all = 0;


	PieCtrlRegs.PIEIER1.bit.INTx6 = 1;//AD
	PieCtrlRegs.PIEIER2.bit.INTx1 = 1;//compare1 interrupt voice output
    PieCtrlRegs.PIEIER4.bit.INTx1 = 1;//compare4 interrupt OFDM signal output		
    	
	IER |= (M_INT1 | M_INT2 | M_INT4);	
	
	EINT;
	ERTM;	
      
    asm(" nop");
    asm(" nop");
    asm(" nop");    
    asm(" nop");    
    asm(" setc 	 ovm,sxm");    
    asm(" spm	 1");    
    
    load();
    initiate(); //編碼初始化
    Speech_Decode_Frame_init();
    Init_RS();

	/*the variable used 
	for judging first OFDM frame in Transmit.c */     
  	OFDM_frame = 0;  
     
    demodushift = 0;
    TestCnt = 0;
    
       
    for(i=0;i<88;i++)
    	Voltage3[i] = 0x03FF;	

	
	//初始化參數
	PWMOFDMStart = 0;
	EncFlag = 0;     
    EncNum = 0;
    ModuFrame = -1;
    pModuData = Voltage2;
    
    /*Main function*/
    while (1)
    {
    	//語音編碼和調制
		if(EncFlag == 1)                    	//EncFlag為0表示接收數據不夠編碼,一直等待
		{
			EncFlag = 0; 			
			
			for(i=0; i<160; i++)
   			{
   				buffer3[i] = Voltage1[160*EncNum + i] - 0x8B30;   			
   			}	
   			
			if(++EncNum == 3)	//30幀
				EncNum = 0;
		  						    
	  	 	codamr();                   //語音編碼	   			   		
	
			
			//跟蹤voltage2的OFDM數據塊存儲位置
			ModuFrame = RS_OFDM_Mod();
			
				if(ModuFrame == 1)
					pModuData = Voltage2 + 1040;
				else if(ModuFrame == 2 || ModuFrame == 3)
					pModuData += 720;
				else if(ModuFrame == 4)
					pModuData = Voltage2;								
	
			
		}

		//OFDM解調和語音解碼		
		if(FrameSynFlag == 1 )                    	
		{			
			if(DemoduFlag == 1)
				asm(" ESTOP0");
				
			FrameSyn = FindFrame(Voltage3);
			volt3flag = FrameSyn + 864;
			pADCModuData = Voltage3 + FrameSyn;
			FrameSynFlag = 0;
		}
		
		if(DemoduFlag == 1)								
		{
			if(FrameSynFlag == 1)
				asm(" ESTOP0");
			
			DecFlag = Receive(pADCModuData, DecoData);
			DemoduFlag = 0;
			demodushift = 0;
			
			if(AdcFrame == 1)
			{
				pADCModuData += 864;
	    	}
	    	else if(AdcFrame == 2)
	    	{
	    		pADCModuData += 720;
	      	}
	    	else if(AdcFrame == 3)
	    	{
	    		pADCModuData += 720;
	    	}
  		}
 
  		while(DecFlag)
  		{
  			Speech_Decode_Frame();	
  			for(i=0; i<160; i++,pwmtestCount++)
     		{	
     			Voltage4[pwmtestCount] = ((synth[i]>>4) + 0x0800) & 0x0FFF;
     			if(pwmtestCount+1 == PwmCount)
     				asm(" ESTOP0");					
       		}
       		DecFlag--;
       		demodushift += 103;
       		if(pwmtestCount == 1600)
       			pwmtestCount = 0;
       		
		}
	}
}

interrupt void  adc_isr(void)//adc中斷以16k速率進入
{   	
	//輸入語音采樣8k
   	if(ConversionCount)                                 
   	{
   		Voltage1[ADCInputVoiceNum] = AdcRegs.ADCRESULT0;
   		ADCInputVoiceNum++;
   		TestCnt++;
   		if(TestCnt == 720) 
			PWMOFDMStart = 1;
   		if(ADCInputVoiceNum == 160) 
		{
    		EncFlag = 1;
   		}	
    	else if(ADCInputVoiceNum == 320) 
		{
   		 	EncFlag = 1;
   		}
   		else if(ADCInputVoiceNum == 480)
   		{
   			ADCInputVoiceNum = 0;
   			EncFlag = 1;
   		}	
    }
    ConversionCount = !ConversionCount;
   
   //調制數據輸入的采樣16k  	
    if(OFDMSampleStart)
    {
   		Voltage3[ADCModuDataNum] = AdcRegs.ADCRESULT1 - 0x9100; 
   		
   		if(AdcFrame == 3 && ADCModuDataNum == volt3flag - 88 + j)
		{
			Voltage3[j] = Voltage3[ADCModuDataNum];
			j++;
			if(j == 88) 
				j=0;				
		}			
		
   		ADCModuDataNum++;
   		
   		if (ADCModuDataNum == 1608)
   			PwmoutStart = 1;//start outputing voice
   			
   		if(AdcFrame==4 && ADCModuDataNum == 480)
   		{
   			FrameSynFlag = 1;
   			AdcFrame = 0;  
   		}
   		else if(AdcFrame==0 && ADCModuDataNum == volt3flag)
   		{
   			DemoduFlag = 1; 
   			AdcFrame++; //AdcFrame = 1
   			volt3flag += 720;
   		}
   		else if(AdcFrame==1 && ADCModuDataNum == volt3flag)
   		{   			
   			DemoduFlag = 1;
   			AdcFrame++;   //AdcFrame = 2
   			volt3flag += 720;
   			   			
   		}	
   		else if(AdcFrame==2 && ADCModuDataNum == volt3flag)
   		{
  			DemoduFlag = 1; 
   			AdcFrame++;  //AdcFrame = 3	
   			volt3flag += 720;
   		}
		else if(AdcFrame==3 && ADCModuDataNum == volt3flag)
   		{
  			DemoduFlag = 1; 
   			AdcFrame++; //AdcFrame = 4   						
   			ADCModuDataNum = 88;	
   		}  	
   		
   	}
   	
    // Reinitialize for next ADC sequence
    AdcRegs.ADCTRL2.bit.RST_SEQ1 = 1;         // Reset SEQ1
    AdcRegs.ADCST.bit.INT_SEQ1_CLR = 1;		// Clear INT SEQ1 bit
    PieCtrlRegs.PIEACK.all = PIEACK_GROUP1;   // Acknowledge interrupt to PIE
    return;
}


interrupt void eva_cmp1_isr(void)                  //音頻輸出
{
	if(PwmoutStart)
	{
		if( Div2Flag)
		{
			EvaRegs.CMPR1 = Voltage4[PwmCount];
			PwmCount++;
			if(PwmCount == 1600)
  	   			PwmCount = 0;
  	   	
		}
		Div2Flag = !Div2Flag;
	}	
	
	
	EvaRegs.EVAIMRA.all = 0x0002;
    EvaRegs.EVAIFRA.all = 0x0002;	
	// Acknowledge interrupt to recieve more interrupts from PIE group 2
	PieCtrlRegs.PIEACK.all = PIEACK_GROUP2;
	return;

}


interrupt void evb_cmp4_isr(void)                //調制后數據輸出
{
	if(PWMOFDMStart)
	{
	
		EvbRegs.CMPR4 = ((Voltage2[ModuDataOutNum]>>3)+0x1000) & 0x1FFF;
	
    	ModuDataOutNum++;
    	SampleDelay++;
    	if(SampleDelay == 9600)
    		OFDMSampleStart = 1; //OFDM sample start
    	if( ModuDataOutNum == 3200 )
    	{
    		ModuDataOutNum = 0;
   		}   	
   	}
   	
    EvbRegs.EVBIMRA.all = 0x0002;  
    EvbRegs.EVBIFRA.all = 0x0002;	
	// Acknowledge interrupt to recieve more interrupts from PIE group 2
	PieCtrlRegs.PIEACK.all = PIEACK_GROUP4;   	
	return;
}


?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品 欧美精品| 56国语精品自产拍在线观看| 色综合久久66| 精品久久久影院| 亚洲一区二区三区不卡国产欧美| 国产麻豆精品theporn| 欧美日韩视频一区二区| 亚洲欧洲无码一区二区三区| 精品影视av免费| 在线成人免费视频| 亚洲国产一区二区在线播放| 成人精品电影在线观看| 久久影院午夜论| 蜜臀av一区二区| 欧美久久免费观看| 亚洲国产精品久久久久婷婷884 | 奇米精品一区二区三区在线观看一| 国产成人8x视频一区二区| 日韩欧美电影在线| 五月综合激情网| 欧美日韩不卡一区| 午夜精品久久久久久久99水蜜桃 | 成人性生交大片免费看在线播放| 日韩一级视频免费观看在线| 天天操天天色综合| 制服丝袜亚洲色图| 日韩中文字幕亚洲一区二区va在线| 色视频欧美一区二区三区| 中文字幕中文字幕在线一区 | 亚洲天堂福利av| 91视视频在线直接观看在线看网页在线看| 国产三级精品视频| 成人动漫视频在线| 亚洲色图都市小说| 在线精品视频一区二区| 亚洲一区二区三区四区在线| 欧美视频在线不卡| 石原莉奈在线亚洲三区| 91麻豆精品国产91久久久久| 蜜桃视频一区二区| 久久久久久电影| 99久久精品免费精品国产| 亚洲免费在线视频一区 二区| 99久久er热在这里只有精品66| 亚洲欧洲成人自拍| 色八戒一区二区三区| 亚洲成a人v欧美综合天堂| 91精品国产综合久久精品app| 免费成人在线观看视频| 久久综合九色综合欧美亚洲| 成人精品在线视频观看| 亚洲精品视频免费观看| 91精品国产综合久久精品麻豆| 精品午夜一区二区三区在线观看| 亚洲国产成人私人影院tom| 91丝袜美腿高跟国产极品老师| 婷婷综合另类小说色区| 久久久综合九色合综国产精品| 99国产欧美久久久精品| 三级一区在线视频先锋| 精品蜜桃在线看| 日本精品视频一区二区| 久久精品国产在热久久| 国产精品国产三级国产普通话三级| 在线观看三级视频欧美| 国产自产视频一区二区三区| 亚洲乱码日产精品bd| 日韩欧美高清dvd碟片| 91麻豆国产精品久久| 免费看精品久久片| 亚洲天堂成人网| 精品日韩在线一区| 欧美色窝79yyyycom| 国产精品系列在线播放| 亚洲国产精品久久艾草纯爱| 久久精品网站免费观看| 欧美日韩午夜在线| 91亚洲国产成人精品一区二区三| 日本aⅴ亚洲精品中文乱码| 亚洲欧洲成人自拍| 久久久午夜电影| 91精品国产一区二区三区香蕉 | 国产在线观看免费一区| 一区二区三区欧美| 国产精品女主播av| 精品入口麻豆88视频| 欧美高清激情brazzers| 色婷婷精品久久二区二区蜜臂av| 国产在线精品一区二区不卡了 | 国产亚洲精品福利| 91精品国产综合久久精品app| 91免费看片在线观看| 国产一区在线不卡| 九色|91porny| 日韩av中文在线观看| 亚洲一区二区三区四区在线免费观看| 国产精品乱码一区二三区小蝌蚪| 日韩免费成人网| 91精品国产麻豆国产自产在线| 欧美性猛交xxxx乱大交退制版| 成人av在线资源网站| 国产一区二区0| 狠狠色丁香久久婷婷综合_中 | 亚洲成人激情av| 亚洲午夜精品17c| 亚洲黄色av一区| 亚洲激情六月丁香| 一区二区三区四区在线| 亚洲精品伦理在线| 一区二区三区色| 无吗不卡中文字幕| 亚洲成人777| 蜜臀va亚洲va欧美va天堂 | 一区二区不卡在线播放 | 欧美一区二区视频观看视频| 欧美日韩国产免费| 欧美人体做爰大胆视频| 欧美电影在哪看比较好| 91麻豆精品国产无毒不卡在线观看| 欧美片在线播放| 在线不卡免费av| 精品国内二区三区| 久久天天做天天爱综合色| 久久色中文字幕| 欧美精彩视频一区二区三区| 国产精品久久久久一区| 有坂深雪av一区二区精品| 亚洲动漫第一页| 美女脱光内衣内裤视频久久影院| 久久精品国产澳门| 国产黄色精品网站| 99精品视频中文字幕| 欧美亚洲国产bt| 欧美精品欧美精品系列| 久久看人人爽人人| 亚洲视频小说图片| 丝袜美腿亚洲一区| 国产精品一二三四五| 97久久人人超碰| 91麻豆精品91久久久久同性| 久久天天做天天爱综合色| 国产精品家庭影院| 青青草国产成人99久久| 成人免费高清在线观看| 欧美色综合网站| 久久久久国产精品厨房| 一区二区三区免费看视频| 久久99精品视频| 日本韩国一区二区三区视频| 91精品国产综合久久精品性色| 国产欧美视频在线观看| 五月婷婷综合在线| 成人免费av资源| 911精品国产一区二区在线| 久久久国产精品麻豆 | 亚洲欧洲日韩综合一区二区| 亚洲成av人片| 不卡电影免费在线播放一区| 7777精品伊人久久久大香线蕉最新版| 国产色爱av资源综合区| 亚洲成av人片www| 99久久国产综合色|国产精品| 欧美一区二区在线视频| 亚洲美女屁股眼交3| 国产一级精品在线| 欧美日韩一级二级| 国产精品久久久久桃色tv| 免费观看一级欧美片| 在线观看www91| 欧美国产日韩亚洲一区| 久久99蜜桃精品| 欧美日韩成人在线一区| 日韩理论片中文av| 国产精品亚洲综合一区在线观看| 欧美日韩国产高清一区二区三区| 国产精品免费av| 国产在线一区二区| 91精品欧美福利在线观看| 亚洲丝袜制服诱惑| 懂色av噜噜一区二区三区av| 日韩欧美中文一区二区| 午夜精品成人在线视频| 色视频一区二区| 亚洲视频一二三区| 成人91在线观看| 欧美激情中文不卡| 国产乱码精品一区二区三区五月婷| 正在播放一区二区| 偷拍与自拍一区| 欧美日韩一本到| 日韩精品亚洲专区| 欧美三区在线观看| 亚洲成av人**亚洲成av**| 欧美综合欧美视频| 亚洲一区在线观看免费 | 久久精品亚洲精品国产欧美| 看片网站欧美日韩| 精品国产一区二区精华| 国产米奇在线777精品观看| 国产日韩欧美精品一区|