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

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

?? wavepdd.c

?? 基于AMD Au1200(MIPS32處理器)的AC97驅(qū)動(dòng)源碼
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/*++
Copyright (c) 2001-2005  BSQUARE Corporation.  All rights reserved.

Module Name:

    wavepdd.c

Module Description:

    This module contains the pdd code of AC97 audio driver

Author:

    Jun Li, July 2001

Revision History:

--*/

#include <windows.h>
#include <bceddk.h>
#include <wavedbg.h>
#include "ac97.h"
#include "au1kac97.h"
#include "ac97aud.h"


#define DIR_STR(x) \
    (((x) == WAPI_IN) ? TEXT("WAPI_IN") : TEXT("WAPI_OUT"))


extern HANDLE hAudioInterrupt;

//static
PWAVE_DEVICE_INSTANCE WaveDevice = NULL;
PWAVE_RESOURCE WaveInResource = NULL;
PWAVE_RESOURCE WaveOutResource = NULL;

static
MMRESULT
WaveGetDeviceCapabilities(
    IN WAPI_INOUT ApiDirection,
    OUT PVOID DeviceCapabilities,
    IN UINT Size
    )

/*++

Routine Description:

    Called to determine audio device capabilities.

Arguments:

    ApiDirection - Audio direction (input or output).

    DeviceCapabilites - Pointer to device capabilities structure or NULL.

    Size - Size of device capabilities structure.

Return Value:

    Returns the appropriate MMSYSERR condition code.

--*/

{
    MMRESULT ReturnValue;
    PWAVEINCAPS InputCapabilities;
    PWAVEOUTCAPS OutputCapabilities;

    DEBUGMSG(ZONE_PDD, (TEXT("+Audio WaveGetDeviceCapabilities.\r\n")));

    ReturnValue = MMSYSERR_NOTSUPPORTED;
    InputCapabilities = DeviceCapabilities;
    OutputCapabilities = DeviceCapabilities;

    //
    // If DeviceCapabilities is NULL, we are asking if the driver PDD is
    // capable of this mode at all. In other words, if the API direction is
    // input,  we return no MMSYSERR_NOERROR if input is supported, and
    // MMSYSERR_NOTSUPPORTED otherwise.
    //

    if (DeviceCapabilities == NULL) {

        ReturnValue = MMSYSERR_NOERROR;
        goto ErrorReturn;
    }

    //
    // Fill in the device capabilities structure here.  Note that the input
    // and output capabilities structure is identical except for the the
    // dwSupport field which is present in the output structure but absent in
    // the input structure.
    //

    if (ApiDirection == WAPI_OUT) {

        OutputCapabilities->wMid = MM_MICROSOFT;

        OutputCapabilities->wPid = MM_MSFT_GENERIC_WAVEOUT;

        OutputCapabilities->vDriverVersion = MAKEWORD(0, 1);    // v1.0

        _stprintf(OutputCapabilities->szPname,
                  TEXT("BSQUARE: Au1000 AC97"));

        //
        // 11.025 kHz, 22.05 kHz, 44.1 kHz, mono and stereo, 8-bit and
        // 16-bit, all combinations thereof.
        //
        // Note that 8 kHz is also supported, but not listed here.
        //

// NOTE: Early Au1000 did not support variable sample rate audio, rather
// NOTE: audio had to be fixed at 48kHz. This driver does not support
// NOTE: early Au1000 anymore, but if it is needed, then only the 44.1khz
// NOTE: capabilities should be returned to the MDD, and the calls to
// NOTE: CodecSetSampleRate() and CodecSetADCSampleRate() should be
// NOTE: fixed to 48khz instead. This has the side effect of playing
// NOTE: sound faster than it should, but at least it plays...

        OutputCapabilities->dwFormats = WAVE_FORMAT_1M08 | WAVE_FORMAT_1M16 |
                                        WAVE_FORMAT_1S08 | WAVE_FORMAT_1S16 |
                                        WAVE_FORMAT_2M08 | WAVE_FORMAT_2M16 |
                                        WAVE_FORMAT_2S08 | WAVE_FORMAT_2S16 |
                                        WAVE_FORMAT_4M08 | WAVE_FORMAT_4M16 |
                                        WAVE_FORMAT_4S08 | WAVE_FORMAT_4S16;

        OutputCapabilities->wChannels = 2;
    
        OutputCapabilities->dwSupport = WAVECAPS_VOLUME;
    }
    else {

        InputCapabilities->wMid = MM_MICROSOFT;

        InputCapabilities->wPid = MM_MSFT_GENERIC_WAVEIN;

        InputCapabilities->vDriverVersion = MAKEWORD(0, 1);    // v1.0

        _stprintf(InputCapabilities->szPname,
                  TEXT("BSQUARE: Au1000 AC97"));

        //
        // 11.025 kHz, 22.05 kHz, 44.1 kHz, Monoaural and Stereo, 8-bit and
        // 16-bit, all combinations thereof.
        //

        InputCapabilities->dwFormats = WAVE_FORMAT_1M08 | WAVE_FORMAT_1M16 |
                                       WAVE_FORMAT_1S08 | WAVE_FORMAT_1S16 |
                                       WAVE_FORMAT_2M08 | WAVE_FORMAT_2M16 |
                                       WAVE_FORMAT_2S08 | WAVE_FORMAT_2S16 |
                                       WAVE_FORMAT_4M08 | WAVE_FORMAT_4M16 |
                                       WAVE_FORMAT_4S08 | WAVE_FORMAT_4S16;

        InputCapabilities->wChannels = 2;
    }

    ReturnValue = MMSYSERR_NOERROR;

ErrorReturn:
    DEBUGMSG(ZONE_PDD, (TEXT("-Audio WaveGetDeviceCapabilities.\r\n")));

    return ReturnValue;
}    


static
MMRESULT
WaveOpen(
    IN LPWAVEFORMATEX WaveFormat,
    IN BOOL QueryFormatOnly,
    IN OUT PWAVE_RESOURCE WaveResource
    )

/*++

Routine Description:

    Opens the specified stream or returns information about valid stream
    formats.

Arguments:

    WaveFormat - Pointer to stream format description.

    QueryFormatOnly - Flag for querying device only.

    WaveResource - Pointer to the wave stream resource structure to update.

Return Value:

    Returns the appropriate MMSYSERR condition code.

--*/

{
    MMRESULT ReturnValue;
    LONG OldValue;
  
    DEBUGMSG(ZONE_PDD, (TEXT("+Audio WaveOpen.\r\n")));

    ReturnValue = MMSYSERR_ERROR;

    //
    // Verify that a valid stream is being opened by checking the format
    // parameters.  If any of the parameters indicate an unsupported stream
    // type, return an error.
    //

    //
    // Wave stream format.  Only PCM is supported.
    //

    if (WaveFormat->wFormatTag != WAVE_FORMAT_PCM) {

        DEBUGMSG(ZONE_PDD, (
                 TEXT("   WaveOpen: WAVE_FORMAT_PCM is supported.\r\n")));

        ReturnValue = WAVERR_BADFORMAT;
        goto ErrorReturn;
    }

    //
    // Number of channels.  Only 1 (mono) or 2 (stereo) are supported.
    //

    if (WaveFormat->nChannels != 1 &&
        WaveFormat->nChannels != 2) {

        DEBUGMSG(ZONE_PDD, (
                 TEXT("   WaveOpen: 1 or 2 channels is supported.\r\n")));

        ReturnValue = WAVERR_BADFORMAT;
        goto ErrorReturn;
    }

    //
    // Sampling frequency.  Only 8000, 11025, 22050, and 44100 Hz sample
    // rates are supported.  Note that the 8000 Hz rate is not listed as a
    // supported sample rate in WaveGetDeviceCapabilities because there are
    // no defines for that sample rate.  Nevertheless, 8 khz is a popular
    // sampling rate and is thus supported.
    //

    if (WaveFormat->nSamplesPerSec != 8000 &&
        WaveFormat->nSamplesPerSec != 11025 &&
        WaveFormat->nSamplesPerSec != 22050 &&
        WaveFormat->nSamplesPerSec != 44100 && 
        WaveFormat->nSamplesPerSec != 48000) {

        DEBUGMSG(ZONE_PDD, (
                 TEXT("   WaveOpen: 8.0 kHz, 11.025, 22.05, 44.1 and 48 kHz are")
                 TEXT(" supported.\r\n")));

        ReturnValue = WAVERR_BADFORMAT;
        goto ErrorReturn;
    }

    //
    // Number of bits per sample.  Only 8-bit (signed) and 16-bit (unsigned)
    // are supported.
    //

    if (WaveFormat->wBitsPerSample != 8 &&
        WaveFormat->wBitsPerSample != 16) {

        DEBUGMSG(ZONE_PDD, (
                 TEXT("   WaveOpen: 8 or 16 bit samples are supported.\r\n")));

        ReturnValue = WAVERR_BADFORMAT;
        goto ErrorReturn;
    }

    //
    // Check if this routine is being called to just query for support of a
    // particular format.  If it is, we're done.  The format is supported.
    //

    if (QueryFormatOnly == TRUE) {

        DEBUGMSG(ZONE_PDD, (
                 TEXT("   WaveOpen: QueryFormatOnly.\r\n")));

        ReturnValue = MMSYSERR_NOERROR;
        goto ErrorReturn;
    }

    //
    // Attempt to allocate the stream.  If we fail, it's currently in use, and
    // an error is returned saying that the stream is allocated.  The
    // interlocked test exchange guarantees that only one thread opens the
    // wave device, regardless if the MDD performs any locking.
    //

    OldValue = InterlockedTestExchange(&WaveResource->InUse,
                                       FALSE,
                                       TRUE);

    if (OldValue == TRUE) {
        ReturnValue = MMSYSERR_ALLOCATED;
        goto ErrorReturn;
    }

    // Update the resource structure with the new format.
    //
    memcpy(&WaveResource->WaveFormat,
           WaveFormat,
           sizeof(*WaveFormat));

    // Ensure channel not muted 
    //
    CodecClrMasterMute(WaveDevice->AC97Ctrl);
    
	// Find a mic volume
	//
	WaveDevice->MicVolume = FindMicVolume(WaveDevice);

	// Set Mic Volume
    //
    AC97WriteReg(WaveDevice->AC97Ctrl,AC97_MIC_VOLUME,WaveDevice->MicVolume);

#ifdef PLATFORM_MIRAGE
	if (!CodecSetSampleRate(WaveDevice->AC97Ctrl, WaveFormat->nSamplesPerSec) )
		DEBUGMSG(ZONE_PDD, (TEXT("-Audio Could not set sample rate\r\n")));
#else
	if (WaveResource->WaveDirection==WAPI_OUT && !CodecSetSampleRate(WaveDevice->AC97Ctrl, WaveFormat->nSamplesPerSec) ) {
        DEBUGMSG(ZONE_PDD, (TEXT("-Audio Could not set DAC sample rate\r\n")));
	} else if (WaveResource->WaveDirection==WAPI_IN && !CodecSetADCSampleRate(WaveDevice->AC97Ctrl, WaveFormat->nSamplesPerSec) ) {
        DEBUGMSG(ZONE_PDD, (TEXT("-Audio Could not set ADC sample rate\r\n")));
	}
#endif

    ReturnValue = MMSYSERR_NOERROR;
 
ErrorReturn:
    DEBUGMSG(ZONE_PDD, (TEXT("-Audio WaveOpen.\r\n")));

    return ReturnValue;
}


static
MMRESULT
WaveClose(
    IN OUT PWAVE_RESOURCE WaveResource
    )

/*++

Routine Description:

    Closes a wave stream.  This routine is dispatched by PDD_WaveProc.  It is
    expected that for every call to WaveOpen that succeeds, there will be one
    and only one call to this routine.

Arguments:

    WaveResource - Pointer to the wave resources structure corresponding to
        the stream to be closed.

Return Value:

    Returns an MMRESULT.  MMSYSERR_NOERROR is returned on success.

--*/

{
    MMRESULT ReturnValue;

    ReturnValue = MMSYSERR_ERROR;
    DEBUGMSG(ZONE_PDD, (TEXT("+Audio WaveClose.\r\n")));
    //
    // Verify that the resource was allocated and deallocate it by marking it
    // as unused.
    //

    if (WaveResource->InUse == TRUE) {

		WaveResource->MoreData = FALSE;
        WaveResource->InUse = FALSE;
    }
    else {

        DEBUGMSG(ZONE_PDD, (
                 TEXT("   WaveClose: Tried to close unallocated stream.\r\n")));

        goto ErrorReturn;
    }


    //
    // Mute channel
    //
    CodecClrMasterMute(WaveDevice->AC97Ctrl);

    ReturnValue = MMSYSERR_NOERROR;

ErrorReturn:
    DEBUGMSG(ZONE_PDD, (TEXT("-Audio WaveClose.\r\n")));

    return ReturnValue;
}


static
VOID 
WaveStandby(
    IN OUT PWAVE_RESOURCE WaveResource
    )

/*++

Routine Description:

    Powers down the devices associated with the specified direction.  This is
    dispatched by PDD_WaveProc.  The MDD will call into PDD_WaveProc to have
    this routine run when either of the AUDIO_STATE_OUT_STOPPED or
    AUDIO_STATE_IN_STOPPED flags are returned.

Arguments:

    WaveResource - Pointer to the wave resouces structure corresponding to the
        wave stream that is to be placed in standby.

Return Value:

    None.

--*/

{

    DEBUGMSG(ZONE_PDD, (TEXT("+Audio WaveStandby.\r\n")));

    ShutdownDma(WaveResource);

    DEBUGMSG(ZONE_PDD, (TEXT("-Audio WaveStandby.\r\n")));
}

DWORD
PDD_AudioMessage(
    UINT Message,
    ULONG Param1,
    ULONG Param2
    )
{
    DEBUGMSG(ZONE_PDD, (TEXT("+Audio PDD_AudioMessage\r\n")));

	switch (Message)
	{
		case IOCTL_POWER_CAPABILITIES:

			//
			// Support all states except for D3
			//
			((PPOWER_CAPABILITIES)Param1)->DeviceDx = 0x17;
			WaveDevice->CurrentPowerState = D0;
			break;

		case IOCTL_POWER_GET:
			*((PCEDEVICE_POWER_STATE)Param1) = WaveDevice->CurrentPowerState;
			break;

		case IOCTL_POWER_SET:
			switch (Param1)
			{
				//
				// Shut down DMA for a full power off (D4) and then shut down
				// the codec for both power off and standby (D4 & D2)
				//
				case D4:

					ShutdownDma(WaveInResource);
					ShutdownDma(WaveOutResource);
 
					WaveInResource->DmaRunning = FALSE;
					WaveOutResource->DmaRunning = FALSE;
					
					// Stop the Rx/Tx Controllers.
					WRITE_REGISTER_ULONG((PULONG)&WaveDevice->AC97Ctrl->pcr,
										(PSC_AC97_PCR_RP | PSC_AC97_PCR_TP));
				
				case D2:

// Power down the amplifier if your platform has one
#ifdef PLATFORM_AMPLIFIER_POWERDOWN
	PLATFORM_AMPLIFIER_POWERDOWN
#endif

					if (!CodecPowerDown(WaveDevice->AC97Ctrl))
					{
						DEBUGMSG(ZONE_PDD,(TEXT("Codec did not power down\r\n")));

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本一区二区免费在线| 国产91精品免费| 91麻豆精品国产91久久久久久久久| 久久日一线二线三线suv| 亚洲成av人影院| 在线亚洲人成电影网站色www| 久久人人超碰精品| 天堂久久久久va久久久久| 欧美日韩视频在线一区二区| 国产精品二三区| 国产福利一区二区三区在线视频| 欧美日韩国产在线观看| 日韩理论电影院| 日本伦理一区二区| 国产在线观看一区二区| 九色综合狠狠综合久久| 成人激情综合网站| 亚洲视频一区在线| 欧美日韩在线不卡| 美女精品自拍一二三四| 久久免费视频一区| 99国产精品久久久久久久久久| 国产精品国产三级国产a| 91在线一区二区三区| 亚洲小说欧美激情另类| 日韩丝袜美女视频| 粉嫩蜜臀av国产精品网站| 亚洲精选在线视频| 欧美一区二区三区白人| 国产成人夜色高潮福利影视| 日一区二区三区| 精品国产乱子伦一区| 黄色精品一二区| 久久免费国产精品| 欧美精品v国产精品v日韩精品| 韩日av一区二区| 亚洲人快播电影网| 日韩精品一区二区三区四区视频| 日韩成人一区二区| 中文字幕中文字幕一区| 91麻豆免费在线观看| 亚洲高清在线精品| 中文字幕不卡在线播放| 欧美高清精品3d| 另类欧美日韩国产在线| 中文字幕一区二区在线观看| 精品国产乱码久久久久久牛牛| 欧美天堂一区二区三区| 在线观看视频91| 成人av网站在线观看免费| 久久国产精品99精品国产| 亚洲一区二区在线观看视频 | 欧美视频在线观看一区二区| 国产一区二区在线视频| 男女男精品网站| 国产日韩欧美高清| 久久综合成人精品亚洲另类欧美 | 国产精品亚洲专一区二区三区| 天天免费综合色| 日韩二区三区四区| 秋霞电影网一区二区| 日韩激情视频网站| 久久99精品久久久久久国产越南| 日韩极品在线观看| 国产在线不卡视频| av亚洲精华国产精华| 欧美午夜免费电影| 精品久久久久久久久久久院品网 | eeuss鲁片一区二区三区| 国产99久久久国产精品潘金网站| 午夜影院久久久| 天天色图综合网| 久久91精品久久久久久秒播| 日韩精品成人一区二区在线| 亚洲第一福利一区| 久久99国产精品麻豆| 色婷婷久久综合| 欧美tk丨vk视频| 亚洲香肠在线观看| 国产一区在线观看视频| 91在线免费看| 欧美tickling挠脚心丨vk| 亚洲色图欧美偷拍| 天堂影院一区二区| 91在线精品一区二区三区| 欧美一区三区四区| 亚洲最新视频在线观看| 国产成人亚洲综合色影视| 欧美精品一级二级三级| 日韩理论片在线| 粉嫩av亚洲一区二区图片| 欧美日韩精品系列| 国产精品动漫网站| 国产不卡视频在线播放| 精品乱人伦小说| 日本va欧美va精品发布| 欧美日韩一区不卡| 亚洲欧美色一区| 99亚偷拍自图区亚洲| 中文字幕亚洲一区二区va在线| 成人激情文学综合网| xnxx国产精品| 国产一区二区三区四区五区美女 | 亚洲免费观看高清| 国内外精品视频| 日韩欧美中文字幕制服| 久久国产成人午夜av影院| 欧美猛男超大videosgay| 午夜精品成人在线视频| 色欲综合视频天天天| 亚洲欧洲精品成人久久奇米网| 成人永久看片免费视频天堂| 国产日韩欧美激情| 9i在线看片成人免费| 一区二区高清视频在线观看| 欧美日韩aaaaa| 精品亚洲国内自在自线福利| 国产日韩欧美精品一区| 欧美一a一片一级一片| 日韩精品一级中文字幕精品视频免费观看| 777xxx欧美| 国产不卡免费视频| 一区二区三区自拍| 欧美精品九九99久久| 国产福利一区在线| 五月天中文字幕一区二区| 久久理论电影网| 欧美男生操女生| 成人av午夜影院| 国产精品99久久久久| 亚洲综合激情另类小说区| 日韩精品中文字幕一区 | 亚洲男人电影天堂| 欧美日韩亚洲高清一区二区| 激情综合五月婷婷| 亚洲裸体在线观看| 欧美激情一二三区| 在线不卡a资源高清| www.日韩av| 国产一区啦啦啦在线观看| 日本中文字幕不卡| 天堂一区二区在线| 亚洲乱码国产乱码精品精98午夜| 精品国产乱码久久久久久老虎 | 久久久亚洲精华液精华液精华液| 日韩一级视频免费观看在线| 欧美亚洲国产bt| 色呦呦网站一区| 91在线看国产| 91网页版在线| 成人免费高清视频在线观看| 成人性生交大片| 国产大片一区二区| 成人国产精品视频| 国产aⅴ精品一区二区三区色成熟| 国产精品中文字幕一区二区三区| 国产乱国产乱300精品| 国产一区二区三区香蕉| 国产福利一区二区三区视频| 国产经典欧美精品| 成人精品视频一区二区三区 | 色www精品视频在线观看| 在线观看视频一区二区欧美日韩| 色视频成人在线观看免| 在线国产电影不卡| 欧美日韩精品二区第二页| 欧美久久一二三四区| 日韩一区二区在线观看视频| 精品三级av在线| 久久精品夜色噜噜亚洲a∨| 国产精品久久久久久户外露出| 国产精品嫩草久久久久| 秋霞成人午夜伦在线观看| av在线综合网| 欧美电影免费提供在线观看| 国产精品美女久久久久久久久| 亚洲欧美日韩国产一区二区三区| 偷窥少妇高潮呻吟av久久免费| 国产高清亚洲一区| 色噜噜狠狠成人中文综合| 精品少妇一区二区三区日产乱码| 国产精品久久久久三级| 免费成人小视频| 欧美日韩精品一区二区在线播放| 久久久久久久综合日本| 一区二区三区在线影院| 国产精品99久久久久久似苏梦涵 | 免费观看久久久4p| 欧美日本韩国一区| 最新日韩在线视频| 9人人澡人人爽人人精品| 7777精品伊人久久久大香线蕉| 国产精品五月天| 国产一区在线精品| 日韩天堂在线观看| 日韩精品一二三| 91精品国产福利| 久久99久久99精品免视看婷婷 | 色一情一伦一子一伦一区| 国产色91在线|