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

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

?? adc_pwm_no_pass_ch_2.c

?? 基于TMS320F2812的AMR+RS編解碼+OFDM調制解調源程序。是stand alone運行版本
?? C
字號:
#include "DSP28_Device.h"
#include "RS.H"
#include "setting.h"
#include "newamr3.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];                                 //調制后的數據發射
//extern int  Voltage3[2000];                                 //調制后的數據接收 
int 	Voltage4[320];                                  //音頻輸出
int    *pModuData = Voltage2;
int    *pADCModuData = Voltage2;                       //指示待調制數據
int    ModuFrame;
//int    ModuPreFrame = 5;
//int    DemoduFrame;                                    //解調的幀數 
extern int demodushift;

Uint16 volt2flag;	//voltage2 buffer pointer
int16 OFDM_frame;


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;

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;
    
    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;  
	
    
 
   // Configure ADC
    AdcRegs.ADCMAXCONV.all = 0x0000;       // 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)       


    EvaRegs.GPTCONA.bit.T2TOADC = 2;       // Enable EVASOC in EVA
	EvaRegs.T2CNT = 0x0000;   
    EvaRegs.T2PR =0x493E;                  // SOC 采樣頻率= 8K
    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;      
 */  	
   // 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;  
  */	
    asm(" nop");
    asm(" nop");
    asm(" nop");    
    asm(" nop");    
    asm(" setc 	 ovm,sxm");    
    asm(" spm	 1");    
    
    
    initiate(); //編碼初始化
    Speech_Decode_Frame_init();
    Init_RS();
	
	//初始化參數
	PWMOFDMStart = 0;
	EncFlag = 0;     
    EncNum = 0;
    ModuFrame = -1;
    pModuData = Voltage2;
  	OFDM_frame = 0;  
    volt2flag = 3200;  
    demodushift = 0;
    TestCnt = 0;
       
    /*Main function*/
    while (1)
    {
    	//語音編碼和調制
		if(EncFlag == 1)                    	//EncFlag為0表示接收數據不夠編碼,一直等待
		{
			for(i=0; i<160; i++)
   			{
   				buffer3[i] = Voltage1[160*EncNum + i] - 0x8D60;
   			//	buffer3[i] -= 0x08D6;
   			}	
			if(++EncNum == 3)
		  		EncNum = 0;
			EncFlag = 0; 			
			    
	  	 	codamr();                   //語音編碼
	  		for(i=0; i<103; i++,j++)
			{		
				buffer3[i] = CodeAmr[j];					
				if(j == 3090)
				{
					j = 0;				
				}
			}	  	 			
	  	 		
			//跟蹤voltage2的OFDM數據塊存儲位置
			ModuFrame = RS_OFDM_Mod();			
		
			 
			if(ModuFrame == 1)
			{				
				pModuData = Voltage2 + 1040;
				//FrameSyn = FindFrame(Voltage2);
				pADCModuData = Voltage2 + 176;
				DecFlag = Receive(pADCModuData, DecoData);
				demodushift = 0;
			}
			
			else if( ModuFrame == 2 )
			{
				pModuData = Voltage2 + 1760;
				pADCModuData += 864;
				DecFlag = Receive(pADCModuData, DecoData);
				demodushift = 0;
			}	
				
			else if( ModuFrame == 3)	
			{
				pModuData = Voltage2 + 2480;
				pADCModuData += 720;
				DecFlag = Receive(pADCModuData, DecoData);
				demodushift = 0;
			}	
				
			else if(ModuFrame == 4)
			{
				pModuData = Voltage2;
				pADCModuData += 720;
				DecFlag = Receive(pADCModuData, DecoData);		
				demodushift = 0;
			}	
	
		 	if(DecFlag)
  		 	{	
  		 		Speech_Decode_Frame();	
  				for(i=0; i<160; i++,pwmtestCount++)
     			{	     		     		
     				Voltage4[pwmtestCount] = ((synth[i]>>4) + 0x0800) & 0x0FFF;     				
       			}
       			DecFlag--;
       			demodushift += 103;
       			if(pwmtestCount == 320)
       				pwmtestCount = 0;       		
		 	}										
		}  		
	}
}

interrupt void  adc_isr(void)//adc中斷以16k速率進入
{   	
	//輸入語音采樣8k
 //  	if(ConversionCount)                                 
  // 	{
   		Voltage1[ADCInputVoiceNum] = AdcRegs.ADCRESULT0;
   		ADCInputVoiceNum++;
   		TestCnt++;
   		if(TestCnt == 640)
			PwmoutStart = 1;
			
   		if(ADCInputVoiceNum == 160) 
		{
    		EncFlag = 1;
   		}	
    	else if(ADCInputVoiceNum == 320) 
		{
   		 	EncFlag = 1;
   		}
   		else if(ADCInputVoiceNum == 480)
   		{
   			ADCInputVoiceNum = 0;
   			EncFlag = 1;
   		}	
   // }
   // ConversionCount = !ConversionCount;
   
  
    // 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 == 320)
  	   			PwmCount = 0;  	   	
		}
		
		if(Div2Flag == 1) 
			Div2Flag = 0;		
		else if(Div2Flag == 0) 
			Div2Flag = 1;
		else
			asm(" ESTOP0");
	}	
	
	
	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)
	{

		Voltage2[ModuDataOutNum] = ((Voltage2[ModuDataOutNum]>>4)+0x0800) & 0x0FFF;
		EvbRegs.CMPR4 = Voltage2[ModuDataOutNum];
    	ModuDataOutNum++;
    	SampleDelay++;
    	if(SampleDelay == 9600)
    		OFDMSampleStart = 1; //OFDM sample start
    	if( ModuDataOutNum == volt2flag )
    	{
    		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一区二区三区免费野_久草精品视频
亚洲欧美日韩国产综合| 亚洲国产精品麻豆| 亚洲成av人综合在线观看| 日韩电影一区二区三区四区| 国产成人精品影视| 欧美精品乱人伦久久久久久| 欧美国产乱子伦| 日韩精品每日更新| 91在线视频免费91| 精品国产制服丝袜高跟| 亚洲综合在线视频| 成人h精品动漫一区二区三区| 91精品国产欧美一区二区18 | 日韩伦理免费电影| 久久国产福利国产秒拍| 欧美日韩免费高清一区色橹橹 | 成人免费视频app| 欧美一二三区在线观看| 一区二区免费视频| av不卡在线播放| 国产欧美日本一区视频| 久久av资源网| 欧美一级夜夜爽| 亚洲国产毛片aaaaa无费看| jvid福利写真一区二区三区| 久久亚洲一区二区三区明星换脸 | 国产精品久久久久影院| 精品一区在线看| 欧美一二三在线| 日本免费在线视频不卡一不卡二| 91视频xxxx| 亚洲丝袜美腿综合| 91小视频免费观看| 亚洲欧美日韩在线| 一本到三区不卡视频| 成人欧美一区二区三区小说| a在线播放不卡| 1024成人网| 97久久精品人人做人人爽 | 99久久精品国产导航| 国产情人综合久久777777| 国产一区二区三区综合| 精品国产一区二区三区不卡 | 日韩黄色一级片| 91精品国产丝袜白色高跟鞋| 日韩精品福利网| 日韩午夜激情av| 国产高清在线精品| 亚洲色图视频网| 欧美又粗又大又爽| 首页综合国产亚洲丝袜| 日韩一区二区三区三四区视频在线观看| 日韩av网站在线观看| 欧美精品一区二区不卡| 国产精品一级在线| 亚洲欧美一区二区三区极速播放 | 亚洲国产另类精品专区| 日韩一区二区免费高清| 韩国女主播成人在线| 国产精品国产三级国产| 欧美性视频一区二区三区| 蜜臀av性久久久久av蜜臀妖精| 久久综合中文字幕| 成人av电影在线网| 亚洲电影激情视频网站| 精品国精品自拍自在线| 色哟哟欧美精品| 奇米777欧美一区二区| 国产欧美日韩在线看| 精品视频免费在线| 国产成人啪午夜精品网站男同| 亚洲欧美另类久久久精品2019| 欧美精品久久一区二区三区| 国产伦精品一区二区三区视频青涩| 一色桃子久久精品亚洲| 91精品综合久久久久久| 成人免费毛片片v| 香蕉影视欧美成人| 国产精品麻豆欧美日韩ww| 欧美丰满一区二区免费视频| 国产v综合v亚洲欧| 天堂久久一区二区三区| 中文字幕中文字幕在线一区| 日韩视频免费直播| 91理论电影在线观看| 激情国产一区二区| 亚洲成国产人片在线观看| 日本一区二区三区久久久久久久久不| 欧美无乱码久久久免费午夜一区| 国产精品自拍在线| 热久久久久久久| 一区二区三区四区视频精品免费 | 91麻豆精品国产91久久久久久| 国产黄色精品视频| 久久aⅴ国产欧美74aaa| 一区二区三区四区在线播放 | 欧美大胆人体bbbb| 欧美在线观看一区| 91丝袜呻吟高潮美腿白嫩在线观看| 免费成人结看片| 视频一区二区中文字幕| 亚洲视频免费在线| 亚洲国产激情av| 久久欧美一区二区| 日韩一区二区免费高清| 欧美一区三区二区| 欧美三级韩国三级日本三斤| 91在线国产观看| www.99精品| eeuss影院一区二区三区| 国产精品888| 国产成人在线视频网站| 精品在线免费视频| 精品一区二区久久| 久草中文综合在线| 麻豆专区一区二区三区四区五区| 亚洲gay无套男同| 亚洲综合色视频| 亚洲午夜在线视频| 亚洲第一狼人社区| 午夜精品久久久久久久| 午夜精品福利一区二区三区蜜桃| 香港成人在线视频| 免费观看成人av| 国产精品一区免费视频| 国产精品69毛片高清亚洲| 成人一道本在线| 一本一道久久a久久精品| 色偷偷久久人人79超碰人人澡| 在线观看av一区| 5月丁香婷婷综合| 日韩午夜激情av| 中文在线资源观看网站视频免费不卡 | 97国产一区二区| 欧美主播一区二区三区美女| 欧美男男青年gay1069videost| 欧美理论在线播放| 精品日韩在线观看| 亚洲国产成人午夜在线一区 | 亚洲电影一区二区| 日韩二区在线观看| 国产一区二区美女诱惑| www.66久久| 91超碰这里只有精品国产| 日韩午夜av一区| 欧美极品aⅴ影院| 亚洲一区二区三区视频在线播放| 三级在线观看一区二区| 国产高清精品在线| 欧美在线不卡视频| 久久女同互慰一区二区三区| 亚洲精品视频免费观看| 天天综合色天天综合色h| 国产精品影音先锋| 欧美视频一区二区三区四区| 欧美r级电影在线观看| 成人免费在线播放视频| 日韩电影在线观看电影| 成人黄色一级视频| 欧美一区二区三区爱爱| 国产精品国产自产拍高清av王其| 亚洲一区二区在线免费观看视频 | 日本午夜一区二区| www.久久精品| 日韩精品一区二区三区在线| 亚洲精品美国一| 国产麻豆视频一区| 欧美日韩国产天堂| 国产精品国模大尺度视频| 麻豆成人免费电影| 91在线看国产| 国产日韩欧美综合一区| 日韩高清不卡一区二区| 91免费看视频| 国产午夜精品一区二区三区视频 | 亚洲一区二区高清| 国产福利精品一区二区| 欧美一级免费大片| 亚洲一级在线观看| caoporm超碰国产精品| 久久综合色综合88| 美女诱惑一区二区| 欧美日韩免费不卡视频一区二区三区| 国产精品私人影院| 国产一区二区电影| 欧美一级欧美三级在线观看 | 日韩无一区二区| 亚洲午夜电影在线| 97精品视频在线观看自产线路二| 久久综合九色综合97婷婷| 日本视频中文字幕一区二区三区| 91国产免费看| 亚洲精品国产品国语在线app| 成人美女视频在线观看18| 2017欧美狠狠色| 国产精品一区在线观看你懂的| 欧美白人最猛性xxxxx69交| 日本三级亚洲精品| 91精品国产综合久久久久久久久久 | 国产麻豆视频精品|