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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? psc_i2s.c

?? 基于wince 操作系統(tǒng)的開發(fā)的i2s驅(qū)動程序
?? C
字號:
/*++
Copyright (c) 2004  BSQUARE Corporation.  All rights reserved.

Module Name:

    psc_i2s.c

Module Description:

    This module contains the platform dependent code
    of I2S audio driver for the Au1550

Author:

    Ian Rae  January 2004

Revision History:

--*/
#include <windows.h>
#include <bceddk.h>
#include "gpio.h"
#include "psc_i2s.h"

#include <wavedbg.h>

//#undef  DEBUGMSG
//#define DEBUGMSG(cond, msg)  RETAILMSG(1,msg)

#define ZONE_I2S_ERROR 1 
#define ZONE_I2S_FUNC  1
#define ZONE_I2S_DMA   1 
#define ZONE_I2S_INTR  1

ULONG gIntrAudio = SYSINTR_NOP;

extern HANDLE hAudioInterrupt;
extern PWAVE_DEVICE_INSTANCE WaveDevice;

BOOL
SMBusWriteReg(
    IN HANDLE hSMBus,
    IN UCHAR  Reg,
    IN USHORT Value
    )
{
	SMBUS_TRANSFER Transfer;

	Transfer.Address = SMBUS_ADDR_WM8731;
	Transfer.Register = (Reg << 1) | ((Value & 0x100) >> 8);
	Transfer.Data[0] = Value & 0xFF;
	Transfer.DataSize = 1;

	return SMBus_WriteData(hSMBus, &Transfer);
}    

VOID
ShutdownDma(
    IN PWAVE_RESOURCE WaveResource
    )
{
    DEBUGMSG(ZONE_I2S_FUNC, (TEXT("+ShutdownDma\r\n")));

	HalStopDMA(WaveResource->DMAChannel);

   	EnterCriticalSection(&WaveResource->CriticalSection);

    if(WaveResource->WaveDirection==WAPI_OUT) {
        WRITE_REGISTER_ULONG((PULONG)&WaveResource->pI2S->pcr, PSC_I2S_PCR_TP);
    } else {
        WRITE_REGISTER_ULONG((PULONG)&WaveResource->pI2S->pcr, PSC_I2S_PCR_RP);
    }

	WaveResource->DmaRunning = FALSE;
    
	LeaveCriticalSection(&WaveResource->CriticalSection);

	DEBUGMSG(ZONE_I2S_FUNC, (TEXT("-ShutdownDma\r\n")));

}

VOID
StartDma(
    IN PWAVE_RESOURCE WaveResource
    )
{
    DEBUGMSG(ZONE_I2S_FUNC, (TEXT("+StartDma\r\n")));

    EnterCriticalSection(&WaveResource->CriticalSection);
    
    if(WaveResource->WaveDirection==WAPI_OUT) {
        WRITE_REGISTER_ULONG((PULONG)&WaveResource->pI2S->pcr, PSC_I2S_PCR_TS);
    } else {
        WRITE_REGISTER_ULONG((PULONG)&WaveResource->pI2S->pcr, PSC_I2S_PCR_RS);
    }
    
	HalStartDMA(WaveResource->DMAChannel);
    
	WaveResource->DmaRunning = TRUE;
    LeaveCriticalSection(&WaveResource->CriticalSection);

    DEBUGMSG(ZONE_I2S_FUNC, (TEXT("-StartDma \r\n")));

}

BOOL
InitializeInterrupt(
    IN PWAVE_DEVICE_INSTANCE WaveDevice
    )
{
	ULONG HwIntr;

    DEBUGMSG(ZONE_I2S_FUNC,(L"+Initialize Interrupt\r\n"));

    HwIntr = HalGetDMAHwIntr(WaveDevice->DMAChannelOutput);
	HwIntr |= HalGetDMAHwIntr(WaveDevice->DMAChannelInput) << 8;

	gIntrAudio = InterruptConnect(Internal, 0, HwIntr, 0);

	if (gIntrAudio == SYSINTR_NOP)
	{
		RETAILMSG(1,(L"Can not allocate SYSINTR\r\n"));
		goto ErrorReturn;
	}

	DEBUGMSG(ZONE_I2S_FUNC,(L"-Initialize Interrupt\r\n"));
	return TRUE;
ErrorReturn:
	DEBUGMSG(ZONE_I2S_FUNC,(L"-Initialize Interrupt failed\r\n"));
	return FALSE;
}

BOOL
InitializeRegisters(PSC_I2S *pI2S)
{
	ULONG timeout;
	BOOL  status = TRUE;

	// Reset and configure the PSC for I2S
	WRITE_REGISTER_ULONG((PULONG)&pI2S->psc.sel, PSC_SEL_PS_I2S | PSC_SEL_CLK_OFFCHIP);

	// Enable the PSC
	WRITE_REGISTER_ULONG((PULONG)&pI2S->psc.ctl, PSC_CTL_CE);
	WRITE_REGISTER_ULONG((PULONG)&pI2S->psc.ctl, PSC_CTL_CE |PSC_CTL_EN);

	// wait for clock detect
	timeout = 50;
	while (timeout && !(READ_REGISTER_ULONG((PULONG)&pI2S->sts) & PSC_I2S_STS_SR)) {
		HalStallExecution(1000);
		timeout--;
	}

	if (!timeout) {
		RETAILMSG(1,(TEXT("Failed waiting for SR\r\n")));
		status = FALSE;
		goto ErrorReturn;
	}

	// Configure the PSC
	WRITE_REGISTER_ULONG((PULONG)&pI2S->cfg, PSC_I2S_CFG_WS_N(63) |
									         PSC_I2S_CFG_BI |
									         PSC_I2S_CFG_XM |
									         PSC_I2S_CFG_LEN_N(15) |
									         PSC_I2S_CFG_TBS_N(3) |
									         PSC_I2S_CFG_RBS_N(3) |
									         PSC_I2S_CFG_DE );

	// mask all interrupts
	WRITE_REGISTER_ULONG((PULONG)&pI2S->msk,0xffffffff);

	// wait unti the device is ready
	timeout = 50;
	while (timeout && !(READ_REGISTER_ULONG((PULONG)&pI2S->sts) & PSC_I2S_STS_DR)) {
		HalStallExecution(1000);
		timeout--;
	}

	if (!timeout) {
		RETAILMSG(1,(TEXT("Failed waiting for DR\r\n")));
		status = FALSE;
		goto ErrorReturn;
	}

ErrorReturn:
	return status;
}

BOOL
InitializePlatform(
    IN PWAVE_DEVICE_INSTANCE WaveDevice
    )
{
	PHYSICAL_ADDRESS PhyAdd;
	HANDLE           hGPIO = NULL;

	RETAILMSG(ZONE_I2S_FUNC,(TEXT("+PSC_I2S InitializePlatform\r\n")));

#if (PLATFORM_I2S_PSC==0)
	PhyAdd.QuadPart = PSC0_PHYS_ADDR;
#elif (PLATFORM_I2S_PSC==1)
	PhyAdd.QuadPart = PSC1_PHYS_ADDR;
#elif (PLATFORM_I2S_PSC==2)
	PhyAdd.QuadPart = PSC2_PHYS_ADDR;
#elif (PLATFORM_I2S_PSC==3)
	PhyAdd.QuadPart = PSC3_PHYS_ADDR;
#else
#error PLATFORM_I2S_PSC must be defined in the range 0 to 3
#endif

	RETAILMSG(1,(L"Initializing PSC%d for I2S operation\r\n",PLATFORM_I2S_PSC));

	WaveDevice->pI2S = MmMapIoSpace(PhyAdd,
								    sizeof(WaveDevice->pI2S),
								    FALSE);
	if(WaveDevice->pI2S==NULL) {
		DEBUGMSG(ZONE_I2S_ERROR,(L"Can not map I2S Control registers\r\n"));
		goto ErrorReturn;
	}

    hGPIO = GPIO_Init();
    if(hGPIO==INVALID_HANDLE_VALUE) {
        DEBUGMSG(ZONE_I2S_ERROR,(L"I2S: Can not open GPIO device\r\n"));
        goto ErrorReturn;
    }

	// CPU dependent GPIO pin functionality
#if defined(CPU_AU1200) && (PLATFORM_I2S_PSC==0)
    if(!GPIO_ClearPinFunction(hGPIO,SYS_PINFUNC_P0A | SYS_PINFUNC_P0B)) {
        DEBUGMSG(ZONE_I2S_ERROR,(L"I2S: Can not set pinfunc for I2S\r\n"));
        goto ErrorReturn;
    }
#elif defined(CPU_AU1200) && (PLATFORM_I2S_PSC==1)
    if(!GPIO_ClearPinFunction(hGPIO,SYS_PINFUNC_P1A | SYS_PINFUNC_P1B)) {
        DEBUGMSG(ZONE_I2S_ERROR,(L"I2S: Can not set pinfunc for I2S\r\n"));
        goto ErrorReturn;
    }
#endif

	// Handle any platform specific initialization, GPIO handle available if needed
#if defined(PLATFORM_I2S_PSC_INIT_CODE)
	PLATFORM_I2S_PSC_INIT_CODE
#endif

	// we are done with GPIO now
	CloseHandle(hGPIO);

	// Get a handle to the SMBus
	WaveDevice->hSMBus = SMBus_Initialize();

	// Reset external codec
	SMBusWriteReg(WaveDevice->hSMBus, WM8731_RR, RR_RESET);

	// Configure external codec
	SMBusWriteReg(WaveDevice->hSMBus, WM8731_DAPC, DAPC_DEEMP_44);
	SMBusWriteReg(WaveDevice->hSMBus, WM8731_SC, SC_SR_N(8));	// set for 44.1 DAC and ADC
	                                                            // with the Pb1550s 12MHz this will
																// be ~6% fast
	SMBusWriteReg(WaveDevice->hSMBus, WM8731_DAIF, DAIF_FORMAT_I2S |
	                                               DAIF_IWL_16 |
												   DAIF_LRP );
	SMBusWriteReg(WaveDevice->hSMBus, WM8731_AAPC, AAPC_INSEL | AAPC_MICBOOST |
	                                               AAPC_DACSEL);
	SMBusWriteReg(WaveDevice->hSMBus, WM8731_AC, AC_ACTIVE);
	SMBusWriteReg(WaveDevice->hSMBus, WM8731_PDC, 0x00);	

	InitializeRegisters(WaveDevice->pI2S);

	DEBUGMSG(ZONE_I2S_FUNC,(L"-Initialize Platform\r\n"));
    return TRUE;


ErrorReturn:
	if(WaveDevice->pI2S) {
		MmUnmapIoSpace((PVOID)WaveDevice->pI2S, sizeof(*WaveDevice->pI2S));
	}

	if(WaveDevice->hSMBus) {
		CloseHandle(WaveDevice->hSMBus);
	}

	if(hGPIO) {
		CloseHandle(hGPIO);
	}

	DEBUGMSG(ZONE_I2S_FUNC,(L"-Initialize Platform failed\r\n"));
	return FALSE;
}
  
BOOL
InitializeDMA(
    IN PWAVE_DEVICE_INSTANCE WaveDevice
    )
{
    DEBUGMSG(ZONE_I2S_FUNC,(L"+InitializeDMA\r\n"));

    WaveDevice->DMAChannelOutput = HalAllocateDMAChannel();

    if(WaveDevice->DMAChannelOutput==NULL) {
        DEBUGMSG(ZONE_I2S_ERROR,(L"Can not allocate output DMA Channel\r\n"));
        goto ErrorReturn;
    } else {
        DEBUGMSG(1,(L"Using DMA channel for I2S output\r\n"));
    }
    
    HalInitDmaChannel(WaveDevice->DMAChannelOutput,
	                  DMA_I2S_TX,
	                  WaveDevice->DmaBufferSize,
					  TRUE);

    WaveDevice->DMAChannelInput = HalAllocateDMAChannel();

    if(WaveDevice->DMAChannelInput==NULL) {
        DEBUGMSG(ZONE_I2S_ERROR,(L"Can not allocate input DMA Channel\r\n"));
        goto ErrorReturn;
    } else {
        DEBUGMSG(1,(L"Using DMA channel for I2S input\r\n"));
    }

    HalInitDmaChannel(WaveDevice->DMAChannelInput,
	                  DMA_I2S_RX,
	                  WaveDevice->DmaBufferSize,
					  TRUE);

    DEBUGMSG(ZONE_I2S_FUNC,(L"-InitializeDMA\r\n"));    
    return TRUE;

  ErrorReturn:

    DEBUGMSG(ZONE_I2S_FUNC,(L"-InitializeDMA failed\r\n"));    
    return FALSE;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美日韩dvd在线观看| 欧美专区亚洲专区| 久久久久久久av麻豆果冻| 国内外精品视频| 国产女主播一区| 色综合久久久久| 午夜久久久影院| 精品处破学生在线二十三| 国产成人免费在线视频| 1区2区3区国产精品| 欧美撒尿777hd撒尿| 免费成人在线视频观看| 欧美激情一区在线观看| 色美美综合视频| 奇米综合一区二区三区精品视频 | 91热门视频在线观看| 亚洲午夜三级在线| 欧美精品一区二区三区蜜桃| 成人在线视频首页| 亚洲成人激情av| 久久在线观看免费| 欧美自拍丝袜亚洲| 国产自产2019最新不卡| 亚洲精品免费在线播放| 日韩美女主播在线视频一区二区三区| 国产精品一卡二卡| 香蕉成人伊视频在线观看| 久久精品欧美日韩| 欧美人妇做爰xxxⅹ性高电影| 久久精品国产精品青草| 亚洲欧美福利一区二区| 日韩一区二区三区视频| 99精品视频在线播放观看| 日本不卡的三区四区五区| 国产精品白丝在线| 精品国产乱子伦一区| 在线观看亚洲a| 粉嫩av亚洲一区二区图片| 亚洲国产精品视频| 中文字幕一区在线观看视频| 欧美疯狂做受xxxx富婆| av爱爱亚洲一区| 久久se精品一区精品二区| 亚洲一区二区三区精品在线| 国产色产综合产在线视频| 欧美日韩久久一区二区| av电影天堂一区二区在线 | 欧美电影免费观看高清完整版| 91在线一区二区| 精品一区二区三区免费| 亚洲第一主播视频| 亚洲青青青在线视频| 国产欧美日韩一区二区三区在线观看| 91精品国产福利| 欧美在线播放高清精品| 99视频在线观看一区三区| 国内精品伊人久久久久影院对白| 亚洲电影中文字幕在线观看| 亚洲精品欧美在线| 中文字幕一区二区在线观看| 国产日韩v精品一区二区| 精品免费一区二区三区| 日韩天堂在线观看| 欧美一区二区三区日韩| 欧美高清一级片在线| 欧美在线综合视频| 欧美亚洲一区二区在线观看| 色天使色偷偷av一区二区| 99久久国产综合色|国产精品| 国产高清亚洲一区| 国产成人精品一区二区三区网站观看| 精品一区二区久久| 狠狠色丁香久久婷婷综合丁香| 日韩中文字幕一区二区三区| 亚洲午夜精品一区二区三区他趣| 亚洲激情在线播放| 亚洲精品高清视频在线观看| 一区二区欧美视频| 亚洲一区二区视频在线观看| 一区二区三区日韩精品| 亚洲午夜成aⅴ人片| 午夜精品aaa| 美女被吸乳得到大胸91| 麻豆91免费观看| 激情欧美一区二区三区在线观看| 日韩av高清在线观看| 久久99精品久久久久久国产越南 | 中文字幕免费不卡在线| 久久精品视频一区二区| 欧美国产日韩亚洲一区| 国产精品美女久久久久久久久久久 | 日韩福利视频网| 麻豆成人av在线| 国产精品一区二区在线播放| eeuss国产一区二区三区| 91香蕉视频污| 欧美精品九九99久久| 26uuu亚洲| 国产精品国产三级国产普通话99| 亚洲男人都懂的| 日韩专区欧美专区| 国产91在线|亚洲| 色婷婷国产精品综合在线观看| 在线成人av网站| 国产女人aaa级久久久级| 日韩一区在线免费观看| 天天影视网天天综合色在线播放| 男人操女人的视频在线观看欧美| 国产一二精品视频| 日本道免费精品一区二区三区| 欧美精品在线一区二区| 国产日韩欧美制服另类| 亚洲高清免费视频| 高清国产一区二区三区| 欧美性xxxxxx少妇| 久久久99久久| 亚洲成人动漫在线免费观看| 国产一区二区免费视频| 在线区一区二视频| 久久久一区二区| 亚洲一区二区三区在线| 国产一区二区伦理片| 欧美日韩中文另类| 国产喂奶挤奶一区二区三区| 亚洲国产综合人成综合网站| 国产成a人无v码亚洲福利| 欧美日韩一级二级| 亚洲国产激情av| 蜜臀av一区二区在线免费观看| 99re在线视频这里只有精品| 精品国内二区三区| 午夜精品一区在线观看| 91一区一区三区| 久久夜色精品国产欧美乱极品| 亚洲国产一区二区在线播放| 成+人+亚洲+综合天堂| 欧美成人女星排行榜| 亚洲午夜影视影院在线观看| 成人av在线影院| 久久免费电影网| 蜜臀av亚洲一区中文字幕| 欧美日韩在线播放三区四区| 国产精品久久久久久久午夜片| 久久99精品一区二区三区| 3d动漫精品啪啪一区二区竹菊| 亚洲欧美日韩国产综合| 粉嫩一区二区三区在线看| 精品国免费一区二区三区| 日韩高清不卡一区| 欧美日韩1234| 亚洲va欧美va人人爽午夜| 91激情在线视频| 亚洲欧美日本韩国| 99久久久国产精品| 国产精品素人一区二区| 国产精品一区在线观看你懂的| 日韩视频一区二区三区| 无码av免费一区二区三区试看| 欧美在线一区二区| 亚洲国产一区二区三区青草影视 | 欧美午夜不卡视频| 一级中文字幕一区二区| 色综合久久天天综合网| 成人欧美一区二区三区小说| 成人美女在线观看| 中文字幕一区三区| 97精品视频在线观看自产线路二| 国产精品第五页| 一本一道综合狠狠老| 中文字幕亚洲在| 色综合天天综合给合国产| 国产精品国产三级国产aⅴ入口| 成人av先锋影音| 亚洲天堂av一区| 欧美亚洲日本国产| 亚洲大片免费看| 日韩你懂的在线播放| 国产一区二区三区四区五区美女| 精品国产免费久久| 国产99久久久精品| 亚洲激情成人在线| 欧美日韩精品一区二区| 日本欧美在线观看| 久久久久久免费网| 北条麻妃国产九九精品视频| 亚洲欧洲中文日韩久久av乱码| 91国模大尺度私拍在线视频| 亚洲高清在线视频| 日韩精品一区国产麻豆| 国产一区二区三区四区五区入口 | 国产成人鲁色资源国产91色综| 欧美经典三级视频一区二区三区| av不卡免费在线观看| 亚洲成av人在线观看| 精品入口麻豆88视频| 成人av综合在线| 亚洲国产乱码最新视频 | 国产精品久久久久久久久图文区 | 成人欧美一区二区三区白人 | 国产成人av网站|