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

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

?? wavepdd.c

?? 基于AMD Au1200(MIPS32處理器)的AC97驅動源碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*++
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")));

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久先锋资源网| 国内精品久久久久影院薰衣草| 久久国产欧美日韩精品| 欧美日韩国产另类一区| 亚洲一区二区美女| 欧美日韩国产免费一区二区 | 国产成人精品网址| 久久尤物电影视频在线观看| 一个色在线综合| 97超碰欧美中文字幕| 亚洲视频中文字幕| 一本色道**综合亚洲精品蜜桃冫| 国产精品丝袜久久久久久app| 国产精品亚洲午夜一区二区三区 | 亚洲一区二区美女| 欧美日韩美女一区二区| 亚欧色一区w666天堂| 欧美精品久久天天躁| 免费观看日韩av| 精品国产伦一区二区三区免费| 久久精品噜噜噜成人av农村| 欧美tk—视频vk| 麻豆91精品91久久久的内涵| 精品国产乱子伦一区| 精品一区二区三区视频| 久久精品亚洲国产奇米99| 成人av在线播放网站| 精品少妇一区二区三区在线播放| 国产一区视频导航| 日韩一区欧美一区| 91色在线porny| 亚洲成a人片综合在线| 日韩欧美二区三区| 成人精品小蝌蚪| 亚洲蜜臀av乱码久久精品蜜桃| 欧美日韩情趣电影| 日韩成人av影视| 国产女人水真多18毛片18精品视频| 成人av免费在线| 性做久久久久久免费观看| 精品少妇一区二区三区日产乱码 | 91在线观看地址| 亚洲精品国产无套在线观| 欧美日韩中字一区| 五月天亚洲精品| 久久先锋影音av鲁色资源| 99精品欧美一区二区蜜桃免费 | 日韩不卡免费视频| 精品免费日韩av| fc2成人免费人成在线观看播放 | 亚洲国产高清在线| 欧美在线观看视频一区二区三区| 国产在线麻豆精品观看| 偷拍日韩校园综合在线| 亚洲精品高清视频在线观看| 久久久久久久一区| 日韩欧美中文一区二区| 欧美男同性恋视频网站| 色诱亚洲精品久久久久久| 风流少妇一区二区| 国产一区二三区| 久久av中文字幕片| 热久久国产精品| 日本免费新一区视频| 视频一区视频二区中文字幕| 亚洲国产一区二区视频| 亚洲精品v日韩精品| 1024成人网| 亚洲视频一二三区| 国产精品乱人伦一区二区| 久久九九久久九九| 国产亚洲综合性久久久影院| 精品日产卡一卡二卡麻豆| 日韩天堂在线观看| 欧美电影免费观看高清完整版在| 欧美一级片在线看| 日韩欧美成人一区| 久久免费看少妇高潮| 欧美岛国在线观看| 精品少妇一区二区三区在线视频| 日韩一区二区三区免费看 | 欧美影院午夜播放| 在线观看亚洲一区| 欧美日韩亚洲综合一区| 欧美日韩三级在线| 欧美一区二区三区不卡| 日韩片之四级片| 久久久久久久久伊人| 国产精品乱码久久久久久| 国产精品免费av| 亚洲免费伊人电影| 亚洲福利一区二区| 天天做天天摸天天爽国产一区| 偷拍亚洲欧洲综合| 国产一本一道久久香蕉| 波多野结衣中文字幕一区| 色综合天天做天天爱| 欧美人xxxx| 欧美精品一区二区蜜臀亚洲| 久久尤物电影视频在线观看| 中文字幕一区在线| 亚洲成av人片在www色猫咪| 奇米影视7777精品一区二区| 韩国午夜理伦三级不卡影院| 成人一区二区三区视频| 在线精品视频免费观看| 欧美一区二区三区色| 久久精品在这里| 一区二区成人在线视频| 日韩不卡一二三区| 成人97人人超碰人人99| 欧美久久久久久久久中文字幕| 欧美一级免费大片| 亚洲视频香蕉人妖| 久色婷婷小香蕉久久| 99久久99久久免费精品蜜臀| 欧美日韩国产一级片| 国产欧美日韩不卡免费| 五月天欧美精品| 成人免费av网站| 91精品综合久久久久久| 中文字幕av不卡| 日韩va亚洲va欧美va久久| 成人综合日日夜夜| 欧美一级一区二区| 一区二区高清视频在线观看| 国产原创一区二区| 欧美性videosxxxxx| 国产精品污www在线观看| 日韩二区在线观看| www.欧美.com| 欧美精品一区二区三区一线天视频| 亚洲女人小视频在线观看| 狠狠久久亚洲欧美| 欧美图区在线视频| 国产精品国产三级国产三级人妇| 免费久久精品视频| 欧美日韩视频一区二区| 日韩一区有码在线| 国产mv日韩mv欧美| 精品国产一区二区三区久久久蜜月| 一区二区三区蜜桃网| 成人免费视频视频在线观看免费| 日韩免费电影一区| 五月激情六月综合| 91传媒视频在线播放| 国产精品久久久久影院| 国产精品一区二区免费不卡| 69成人精品免费视频| 亚洲永久精品国产| 色婷婷av一区二区三区大白胸| 亚洲国产精品99久久久久久久久| 韩国女主播成人在线观看| 欧美日韩一区二区三区高清| 亚洲另类春色国产| 91色乱码一区二区三区| 国产精品久久久久久福利一牛影视| 国产精品综合二区| 国产亚洲综合在线| 国产一区二区久久| 久久久久久久久蜜桃| 国产最新精品免费| 久久亚洲精精品中文字幕早川悠里| 日本色综合中文字幕| 欧美日韩二区三区| 日韩av午夜在线观看| 欧美巨大另类极品videosbest | 国产精品日产欧美久久久久| 国产精品综合在线视频| 久久免费的精品国产v∧| 极品少妇一区二区三区精品视频 | 国产日韩精品一区二区浪潮av | 国产精品私人影院| av午夜精品一区二区三区| 国产精品久久久久久久第一福利 | 色av成人天堂桃色av| 一区二区三区在线看| 欧美性猛交xxxx乱大交退制版 | 亚洲男人的天堂在线观看| 97精品视频在线观看自产线路二| 亚洲人成精品久久久久| 欧美性受xxxx| 水蜜桃久久夜色精品一区的特点| 日韩欧美激情四射| 国产精品77777| 中文字幕一区日韩精品欧美| 色综合久久中文综合久久牛| 亚洲国产日韩a在线播放性色| 欧美老女人在线| 国产一区二区三区观看| 国产精品美女久久久久久久网站| 91麻豆国产福利精品| 日韩av电影一区| 亚洲国产精品99久久久久久久久| 91久久奴性调教| 另类的小说在线视频另类成人小视频在线| 欧美精品一区二区三区在线| 91免费精品国自产拍在线不卡| 亚洲成人你懂的| 久久久精品黄色|