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

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

?? ac97.c

?? 嵌入式系統(tǒng)關于串口傳輸、觸摸屏、定時器、控制器、中斷處理、音頻控制等實驗代碼
?? C
字號:
#ifndef DEBUG_AC97
#define DEBUG_AC97
#endif

#include "stdio.h"
#include "stdlib.h"
#include "XsAc97CtrlApi.h"
#include "XsAc97Ctrl.h"
#include "dma.h"
#include "pcm.h"
#include "CS4201.h"

#include "UtilFunc.h"
#include "XsUartDrv.h"

extern unsigned char ppcm[];	// PCM data

void * Make16BytesAlign(void * ptr)
{
	unsigned p = (UINT32)ptr;
    void *ptr2;
	if (p & 0x0F)	
		ptr2 = (void *)((p & 0xFFFFFFF0) + 16);
	else			
		ptr2 = (void *)(p & 0xFFFFFFF0);
	return ptr2;
}
#ifndef DEBUG_AC97

#define LENGTH_OF_TRANS		0x00001000
#define PCMLength			470016
#define n8k					115  //(PCMLength/LENGTH_OF_TRANS)

XsDmaDescriptorGroupT  		PCMDesGrp[n8k+1];
#else
#define LENGTH_OF_TRANS		0x00001000
#define PCMLength			0x2000
#define n8k					2
    char DesArea[256]; //leave space for DMA descriptor
    XsDmaDescriptorGroupT *PCMDesGrp;
#endif

XsDmaDescriptorGroupT * initdesc()
{
#ifndef DEBUG_AC97    
	INT32 i;
	XsDmaDescriptorGroupT * pdesc;
	unsigned char * ppcmout = (unsigned char *)Make16BytesAlign(ppcm);	// 16 byte align

    print_string("In initdesc\r\n");
	pdesc = (XsDmaDescriptorGroupT *)Make16BytesAlign(&PCMDesGrp);	

	for (i=0; i<n8k; i++)
	{
		pdesc->DDADR = (UINT32)(pdesc + 1);
		pdesc->DSADR = (UINT32)ppcmout;
		pdesc->DTADR = (UINT32)&(XsAc97CtrlRegsP->PCDR);		// audio transmit FIFO (0x40500040)
		// [31]		increment Src Addr
		// [28]		FLOWTRG
		// [17:16]	11b - 32 bytes Maxim Burst Size of each transfer
		// [15:14]	11b - Word Width
		// [12,0]	Length of transfer in bytes
		pdesc->DCMD = 0x9003C000 | LENGTH_OF_TRANS;
		pdesc ++;
		ppcmout += LENGTH_OF_TRANS;	// skip 8k bytes
	}
	pdesc --;
	pdesc->DDADR = (UINT32)pdesc;

    print_string("Dumping descriptor in initdesc\r\n");
    Dump_Bin((unsigned)pdesc,n8k*4);
	return (XsDmaDescriptorGroupT *)Make16BytesAlign(&PCMDesGrp);
#else
    INT32 i,j;
	XsDmaDescriptorGroupT * pdesc;
	unsigned short * ppcmout = (unsigned short *)Make16BytesAlign(ppcm);	// 16 byte align
    for (i=0,j=0;i<0x2000/sizeof(unsigned short);i++,j=(j+10)%1000)
    {
        ppcmout[i] = SampleTable[j]; //16K 480KHz sine data
    }
        

	PCMDesGrp = (XsDmaDescriptorGroupT *)Make16BytesAlign(DesArea);	
    pdesc = PCMDesGrp;
    
	for (i=0; i<n8k; i++)
	{
		pdesc->DDADR = (UINT32)(pdesc + 1);
		pdesc->DSADR = (UINT32)ppcmout;
		pdesc->DTADR = (UINT32)&(XsAc97CtrlRegsP->PCDR);		// audio transmit FIFO (0x40500040)
		// [31]		increment Src Addr
		// [28]		FLOWTRG
		// [17:16]	11b - 32 bytes Maxim Burst Size of each transfer
		// [15:14]	11b - Word Width
		// [12,0]	Length of transfer in bytes
		pdesc->DCMD = 0x9003C000 | LENGTH_OF_TRANS;
		pdesc++;
		ppcmout += LENGTH_OF_TRANS/sizeof(unsigned short);	// skip 8k bytes
	}
	pdesc--;
	pdesc->DDADR = (UINT32)PCMDesGrp;
	
	return PCMDesGrp;
#endif    
}

void initpcmoutdma(UINT32 channel, XsDmaDescriptorGroupT * pdesc)
{
}
#define	LENGTH_OF_PCMINBUF	1024
unsigned char szpcmin[LENGTH_OF_PCMINBUF];
UINT32 initpcmindma(UINT32 channel)
{
	XsDmaDescriptorGroupT * ppcmindesc 
		= (XsDmaDescriptorGroupT *)malloc(sizeof(XsDmaDescriptorGroupT) * 2);
	if (!ppcmindesc)	return 1;
	ppcmindesc = (XsDmaDescriptorGroupT *)Make16BytesAlign(ppcmindesc);
	
	// build descriptor for pcm in
	{
		ppcmindesc->DDADR = (UINT32)ppcmindesc;
		ppcmindesc->DSADR = (UINT32)&(XsAc97CtrlRegsP->PCDR);		// audio receive FIFO (0x40500040)
		ppcmindesc->DTADR = (UINT32)Make16BytesAlign(szpcmin);
		// [30]		increment Trg Addr
		// [29]		FLOWSRC
		// [17:16]	11b - 32 bytes Maxim Burst Size of each transfer
		// [15:14]	11b - Word Width
		// [12,0]	Length of transfer in bytes
		ppcmindesc->DCMD = 0x6003C000 | (LENGTH_OF_PCMINBUF & 0xFFFFFFE0);
	}
	
	XsDmaControlRegsP->DCSR[channel] &= 0x7FFFFFFF;	// RUN = 0
	while (!(XsDmaControlRegsP->DCSR[channel] & 0x08))	
		Util_DelayUs(1);
	XsDmaControlRegsP->DCSR[channel] = 0x0;
	XsDmaControlRegsP->DRCMR[XSDMA_DRCMR_ID_AC97_AUDIO_RX] = channel | 0x080u;
	XsDmaControlRegsP->DDG[channel].DDADR = ((UINT32)ppcmindesc);
	
	return 0;
}

void startdma(UINT32 channel)
{
	XsDmaControlRegsP->DCSR[channel] |= 0x80000000;	// RUN = 1
}

UINT32 intiac97ctrlfifo()
{
	return 0;
}

UINT32 initac97audiocodec()
{
	UINT32 status;
	
	// disable loopback mode
	status = XsAc97CtrlWriteCodecReg(XS_AC97CTRL_CM_ID_PRI_CODEC, 
		UCB_GPR, 0);
	if (status)	return status;

	// SL[10:8] 100=Line In L; SR[2:0] 100=Line In R
	status = XsAc97CtrlWriteCodecReg(XS_AC97CTRL_CM_ID_PRI_CODEC, 
		UCB_RSR, UCB_RSR_SR_LINE | UCB_RSR_SL_LINE);
	if (status)	return status;
	
	//set record gain
	status = XsAc97CtrlWriteCodecReg(XS_AC97CTRL_CM_ID_PRI_CODEC, 
		UCB_RGR, 0);
	if (status)	return status;

	//enable Variable Rate Audio mode
	status = XsAc97CtrlWriteCodecReg(XS_AC97CTRL_CM_ID_PRI_CODEC, 
		UCB_EASCR, UCB_EAIDR_VRA);
	if (status)	return status;

	//48 kHz
	status = XsAc97CtrlWriteCodecReg(XS_AC97CTRL_CM_ID_PRI_CODEC, 
		UCB_ADR, UCB_DR_48000);
	if (status)	return status;
	
	//set volume: bit13~8 - ML; bit5~0 - MR
	status = XsAc97CtrlWriteCodecReg(XS_AC97CTRL_CM_ID_PRI_CODEC, 
		UCB_MVR, 0x303); 
	if (status)	return status;
	
	status = XsAc97CtrlWriteCodecReg(XS_AC97CTRL_CM_ID_PRI_CODEC, 
		UCB_HVR, 0x303); 
	if (status)	return status;
	
	status = XsAc97CtrlWriteCodecReg(XS_AC97CTRL_CM_ID_PRI_CODEC, 
		UCB_MNVR, 0x303); 
	if (status)	return status;
	
	status = XsAc97CtrlWriteCodecReg(XS_AC97CTRL_CM_ID_PRI_CODEC, 
		UCB_POUTVR, 0x303); 
	if (status)	return status;

	return status;
}

void playpcm(void)
{
	UINT32 DDADR, DSADR, DTADR, DCMD, tmp;
	UINT32 channel = 3;
	XsDmaDescriptorGroupT * pdesc;
    
    PrintfUartDef("In playpcm!\r\n");
    pdesc = initdesc();
	if (!pdesc)	
		return;
	
	if (intiac97ctrlfifo())	
		return;
	
	PrintfUartDef("     To init AC97 codec\r\n");
	initac97audiocodec();

	PrintfUartDef("     To init AC97 dma\r\n");
	
	initpcmoutdma(channel, pdesc); 

	//Waiting for current DMA End	
  	tmp = XsDmaControlRegsP->DCSR[channel];
	XsDmaControlRegsP->DCSR[channel] &= 0x7FFFFFFF;	// RUN = 0

	tmp = 0;
    PrintfUartDef("     Waiting channel to be not busy (channel %d)\r\n",channel);
	while (!tmp)
	{
		tmp = XsDmaControlRegsP->DCSR[channel] & 0x08;
		Util_DelayUs(1);
	}
	PrintfUartDef("     Channel vacant\r\n");
	XsDmaControlRegsP->DCSR[channel] = 0x00000008;
	XsDmaControlRegsP->DDG[channel].DDADR = ((UINT32)pdesc);// | 0xA0000001;
	XsDmaControlRegsP->DRCMR[XSDMA_DRCMR_ID_AC97_AUDIO_TX] = channel | 0x080u;
	
	XsAc97CtrlRegsP->POSR |= 0x00000010;
	
	PrintfUartDef("     To start dma\r\n");
	startdma(channel);
	
	PrintfUartDef("Exit playpcm\r\n");
	return;
	while (1);
	
	// The below code is for debug
restart:
	XsAc97CtrlRegsP->POSR |= 0x00000010;
	tmp = XsDmaControlRegsP->DCSR[channel];
	tmp = XsDmaControlRegsP->DCSR[channel] & 0x08;
	if (tmp)
	{
		startdma(channel);
		while (XsDmaControlRegsP->DCSR[channel] & 0x08)
		{
			DDADR = XsDmaControlRegsP->DDG[channel].DDADR;
			DSADR = XsDmaControlRegsP->DDG[channel].DSADR;
			DTADR = XsDmaControlRegsP->DDG[channel].DTADR;
			DCMD = XsDmaControlRegsP->DDG[channel].DCMD;
			PrintfUartDef("dma not run\n\t[DDADR]0x%x\n\t[DSADR]0x%x\n\t[DTADR]0x%x\n\t[DCMD]0x%x\n", DDADR, DSADR, DTADR, DCMD);
		}
	}
	
	Util_DelayUs(1);
	if (XsDmaControlRegsP->DCSR[channel] & 0x08)
	{
		DDADR = XsDmaControlRegsP->DDG[channel].DDADR;
		PrintfUartDef("dma stops: [DDADR]0x%x\n", DDADR);
	}
	if (XsAc97CtrlRegsP->POSR & 0x00000010)
	{
		//XsDmaControlRegsP->DCSR[channel] &= 0x7FFFFFFF;	// RUN = 0
		//while (!(XsDmaControlRegsP->DCSR[channel] & 0x08))	DM_WaitUs(1);
		DDADR = XsDmaControlRegsP->DDG[channel].DDADR;
		DSADR = XsDmaControlRegsP->DDG[channel].DSADR;
		DTADR = XsDmaControlRegsP->DDG[channel].DTADR;
		DCMD = XsDmaControlRegsP->DDG[channel].DCMD;
		tmp = XsDmaControlRegsP->DCSR[channel];
		PrintfUartDef("fifo error:\n\t[DDADR]0x%x\n\t[DSADR]0x%x\n\t[DTADR]0x%x\n\t[DCMD]0x%x\n", DDADR, DSADR, DTADR, DCMD);
	}goto restart;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩黄色一级片| 欧美一卡二卡三卡四卡| 久久精品网站免费观看| 久久精品国产**网站演员| 日韩欧美一卡二卡| 狠狠色丁香婷综合久久| 久久久综合精品| 国产传媒欧美日韩成人| 国产精品三级在线观看| 不卡的av在线播放| 有码一区二区三区| 欧美日韩国产美女| 狠狠色丁香久久婷婷综| 久久精品一区二区三区四区| 高清不卡一区二区| 亚洲久草在线视频| 4438成人网| 国产一区二区三区在线看麻豆| 久久久久久电影| 色吊一区二区三区| 亚洲 欧美综合在线网络| 日韩欧美国产一区在线观看| 成人性生交大片免费看中文网站| 国产精品激情偷乱一区二区∴| 在线免费观看成人短视频| 日韩av中文在线观看| 国产亚洲欧美一级| 91国在线观看| 麻豆一区二区三区| 国产精品狼人久久影院观看方式| 欧美色网站导航| 狠狠色丁香婷婷综合| 亚洲男女一区二区三区| 91精品啪在线观看国产60岁| 国产成人在线视频播放| 亚洲色图一区二区三区| 欧美一级视频精品观看| 成人app在线| 美国欧美日韩国产在线播放| 国产精品毛片高清在线完整版| 欧美日韩国产在线观看| 成人av影视在线观看| 日本午夜一本久久久综合| 国产精品国产自产拍高清av王其| 欧美日韩第一区日日骚| eeuss国产一区二区三区| 日本在线不卡一区| 亚洲狼人国产精品| 国产午夜久久久久| 欧美一区三区二区| 在线精品视频小说1| 国产成人免费网站| 毛片基地黄久久久久久天堂| 亚洲欧美另类小说视频| 久久久久99精品国产片| 欧美喷潮久久久xxxxx| www.久久久久久久久| 久久精品国产精品亚洲综合| 亚洲国产精品一区二区www| 国产精品午夜在线观看| 精品国产乱码久久| 欧美一二区视频| 欧美日韩国产色站一区二区三区| 91啪在线观看| 成人精品一区二区三区中文字幕| 麻豆免费看一区二区三区| 亚洲成人一区在线| 一级中文字幕一区二区| 一区精品在线播放| 国产无人区一区二区三区| 精品国产青草久久久久福利| 6080国产精品一区二区| 欧美日韩亚洲综合一区二区三区| 一本到不卡免费一区二区| 99久久精品国产一区二区三区| 国产不卡免费视频| 国产精品91xxx| 国产乱妇无码大片在线观看| 国产乱码一区二区三区| 色综合久久88色综合天天免费| 国产精品一卡二卡在线观看| 国产精品香蕉一区二区三区| 韩国女主播一区二区三区| 久久精品二区亚洲w码| 免费黄网站欧美| 久久国产日韩欧美精品| 国内精品国产成人国产三级粉色| 韩国中文字幕2020精品| 国产成人综合在线| 成人国产在线观看| a4yy欧美一区二区三区| 91高清在线观看| 欧美日韩一区三区四区| 欧美久久一二三四区| 日韩小视频在线观看专区| 精品日韩av一区二区| 久久精品视频一区| 国产精品三级视频| 亚洲欧洲中文日韩久久av乱码| 尤物av一区二区| 青青青伊人色综合久久| 狠狠色丁香久久婷婷综合_中| 成人三级伦理片| 色欧美乱欧美15图片| 欧美日韩精品一区二区三区四区| 538prom精品视频线放| 久久午夜老司机| 自拍偷拍亚洲欧美日韩| 亚洲一级二级在线| 激情综合色播五月| av中文一区二区三区| 欧美日韩国产免费一区二区 | 在线观看网站黄不卡| 欧美性色黄大片| 日韩美女一区二区三区四区| 国产精品欧美精品| 丝袜脚交一区二区| 国产精品亚洲成人| 欧美性受极品xxxx喷水| 精品日韩99亚洲| 伊人夜夜躁av伊人久久| 精品在线一区二区| 99久久精品费精品国产一区二区| 7777精品伊人久久久大香线蕉的| 国产午夜精品福利| 污片在线观看一区二区| 国产91精品免费| 欧美人与禽zozo性伦| 中文字幕国产一区| 丝瓜av网站精品一区二区| av电影在线观看一区| 欧美本精品男人aⅴ天堂| 亚洲日本在线看| 国产一区二区三区免费看| 欧美性高清videossexo| 久久久久久久综合色一本| 亚洲成人你懂的| 成人黄色在线视频| 亚洲精品一区二区三区福利| 亚洲图片欧美一区| www.成人网.com| 国产色产综合色产在线视频| 日本成人在线网站| 在线精品视频一区二区三四| 国产精品对白交换视频 | 日韩免费高清av| 最新国产の精品合集bt伙计| 国内国产精品久久| 欧美一区二区三区四区久久| 亚洲综合成人在线| 91网站在线观看视频| 国产亚洲一区二区在线观看| 奇米影视7777精品一区二区| 欧美午夜精品一区二区蜜桃| 亚洲图片你懂的| 成人国产精品免费网站| 久久久国产精品麻豆| 久久99热这里只有精品| 欧美一区二区视频在线观看2020| 一区二区三区成人在线视频| 91亚洲国产成人精品一区二三 | 亚洲亚洲人成综合网络| 成人av电影在线网| 亚洲国产成人一区二区三区| 极品美女销魂一区二区三区| 欧美电影免费观看完整版| 日韩高清电影一区| 日韩一区二区免费高清| 日本欧美在线观看| 91精品国产手机| 蜜桃视频第一区免费观看| 这里只有精品99re| 日本欧美一区二区在线观看| 日韩欧美你懂的| 经典三级一区二区| 久久久99精品久久| 成人免费高清在线观看| 国产精品久久免费看| 91老司机福利 在线| 亚洲一区二区五区| 欧美麻豆精品久久久久久| 日本欧美在线观看| 久久九九全国免费| 99这里都是精品| 亚洲精品成人天堂一二三| 欧美怡红院视频| 香蕉乱码成人久久天堂爱免费| 88在线观看91蜜桃国自产| 蜜臀av在线播放一区二区三区| 精品国产一区二区三区av性色| 国产精品自在欧美一区| 亚洲欧洲日本在线| 欧美日韩一区二区在线观看视频| 天堂成人国产精品一区| 精品国产3级a| 色综合天天综合网天天看片| 五月婷婷色综合| 久久久亚洲午夜电影| 91偷拍与自偷拍精品| 天天亚洲美女在线视频|