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

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

?? waveoutpdd.c

?? WinCE5.0BSP for Renesas SH7770
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
//
//      Copyright(C) Renesas Technology Corp. 1999-2005. All rights reserved.
//
//      WaveDev Driver for ITS-DS7
//
//----------------------------------------------------------------------------
//
// FILE      : WAVEOUTPDD.C
// CREATED   : 1999. 4.26 (for HD64465 on PFM-DS6)
// MODIFIED  : 2005.03.04
// AUTHOR    : Renesas Technology Corp.
// HARDWARE  : RENESAS ITS-DS7
// FUNCTIONS : Playback part PDD of waveform audio driver
// HISTORY   : 
//             2003.06.20
//              - Created release code.
//                (based on WaveDev driver for ITS-DS6 Ver.2.2.0 for WCE4.1)
//             2004.04.21
//              - Revised simultaneous use check. If WAVE_FORMAT_QUERY flag  specified,
//                open flag leaks.
//             2004.06.15
//              - Modified HSSI supported full duplex mode.
//             2004.09.01
//              - Created release code for WCE5.0.
//             2005.02.25
//              - Removed software volume control.
//             2005.03.04
//              - Moved private_AudioFillBuffer is moved to each hac.c and hssi.c.

//----------------------------------------------------------------------------

//
//      Copyright (c) 1995-2000 Microsoft Corporation.  All rights reserved.
//


#include <windows.h>
#include <types.h>
#include <memory.h>
#include <excpt.h>
#include <waveddsi.h>
#include <wavedbg.h>
#include <mmsystem.h>
#include <winbase.h>

#include "platform.h"
#include "shx.h"
#include "sh7770.h"
#include "drv_glob.h"
#include "oalintr.h"
#include "wavepdd.h"
#include "waveOutpdd.h"
#include "dma.h"
//#include "drvlib.h"

extern BOOL dma_Init(int, PDMA_INFO *);
extern BOOL dma_Deinit(PDMA_INFO);
extern BOOL dma_SetPort(PDMA_INFO, DWORD);
extern BOOL dma_SetPage(PDMA_INFO, DWORD, DWORD, DWORD, DWORD);
extern BOOL dma_SetControl(PDMA_INFO, DWORD);
extern BOOL dma_SetCommand(PDMA_INFO, DWORD);
extern BOOL dma_InterruptEnable(PDMA_INFO);
extern BOOL dma_InterruptDisable(PDMA_INFO);
extern BOOL dma_Stop(PDMA_INFO);
extern BOOL dma_IsFinished(PDMA_INFO/*, DWORD*/);

PDMA_INFO	pDMA_out;	// DMA Register (for Playback)
extern DWORD	AUDIO_NO;	// Audio Driver No.

extern VOID	get_DMA_Buffer_Address(int, DWORD, ULONG *);
extern DWORD	get_DPTR(int);
extern DWORD	get_DSAR(int, DWORD, int);
extern DWORD	get_DDAR(int, DWORD, int);
extern DWORD	get_DTCR(int, DWORD, int);
extern BOOL	module_init( PDRIVER_GLOBALS, int );
extern VOID	module_deinit( VOID );
extern BOOL	codec_init( VOID );
extern VOID	module_txstart( VOID );
extern VOID	module_txdmastart( VOID );
extern VOID	module_rxstart( VOID );
extern VOID	module_rxdmastart( VOID );
extern VOID	module_txstop( VOID );
extern VOID	module_rxstop( VOID );
extern VOID	conv_sample(PCM_TYPE, ULONG *, ULONG *);
extern VOID	set_DMA_Buffer(	LONG,ULONG,ULONG,ULONG *,unsigned int,int,int *);
extern VOID	set_volume( ULONG );
extern BOOL	check_SamplesPerSec(int, DWORD);
extern BOOL check_PlayInRec(int, int);
extern void	SetMute( BOOL );

extern PWAVEFORMATEX g_pwfx[2];
extern PCM_TYPE g_pcmtype[2];

// base pointers
PBYTE   pAudioBufferBase;		// Audio buffer

extern PDRIVER_GLOBALS	pDriverGlobals;		// Drivers Globals

// Double Buffer for Audio Playback
ULONG dma_pagePhysicalAddress[2];

extern struct _global_volume
{
    ULONG   dwMasterVolume;
    ULONG   dwLineInVolume;
    ULONG   dwMicVolume;
    BOOL    fMasterMute;
    BOOL    fLineInMute;
    BOOL    fMicMute;
    ULONG   dwInputSelect;
} g_VolumeSettings;

ULONG v_nNextPage;

static volatile BOOL v_fMoreData[2];// TRUE iff MDD layer has called StopPlay
                                    //   v_fMoreData was volatile on D9000
                                    //   It could be involved in controlling
                                    //   multiple threads.

unsigned int	extend_data_count;
unsigned int	data_write_count;

// OpenFlag
int		RecOpenFlag;
int		PlayOpenFlag;

/*****************************************************************************
*   FUNCTION :  	private_AudioOutGetInterruptType
*   DESCRIPTION :   decodes type of audio interrupt
*   INPUTS :		None
*   OUTPUTS :     	interrupt type
*   DESIGN NOTES :
*   CAUTIONS :
*****************************************************************************/
AUDIO_STATE
private_AudioOutGetInterruptType(
   VOID
   )
{
	FUNC_WPDD("+PDD_AudioOutGetInterruptType");

	// An audio interrupt has occured. We need to tell the MDD who owns it
	// and what state that puts us in.


	if ( pDriverGlobals->aud[AUDIO_NO].outInt == (USHORT)NULL ) 
	{
		DEBUGMSG(ZONE_TEST, (TEXT("PDD_AudioOutGetInterruptType: ignore")));
		FUNC_WPDD("-PDD_AudioOutGetInterruptType");
		return AUDIO_STATE_IGNORE;	// assume audio-in generated interrupt
	}

	if (!v_fMoreData[WAPI_OUT]) 
	{
		DEBUGMSG(ZONE_TEST, (TEXT("PDD_AudioOutGetInterruptType: stopped")));
		FUNC_WPDD("-PDD_AudioOutGetInterruptType");
		return AUDIO_STATE_OUT_STOPPED;
	}
	else if (pDriverGlobals->aud[AUDIO_NO].play_address != (ULONG)NULL)
	{
		DEBUGMSG(ZONE_TEST, (TEXT("PDD_AudioOutGetInterruptType: playing")));
		FUNC_WPDD("-PDD_AudioOutGetInterruptType");
		return AUDIO_STATE_OUT_PLAYING;
	}
	else
	{
		DEBUGMSG(ZONE_TEST, (TEXT("PDD_AudioOutGetInterruptType:underflow")));
		FUNC_WPDD("-PDD_AudioOutGetInterruptType");
		return AUDIO_STATE_OUT_UNDERFLOW;
	}
}

/*****************************************************************************
*   FUNCTION :  	private_AudioOutInitialize
*   DESCRIPTION :	sets up register access for audio-out
*			sets DA, DMA, and CMT registers that remain constant
*			sets volume to maximum (default)
*   INPUTS :		None
*   OUTPUTS :     	None
*   DESIGN NOTES :
*   CAUTIONS :
*****************************************************************************/
BOOL
private_AudioOutInitialize(
   VOID
   )
{
	BOOL	RET_VALUE;
	ULONG 	SizeOfBuffer;
	char here[] = "PDD_AudioOutInitialize";

	FUNC_WPDD("+PDD_AudioOutInitialize");
	DEBUGMSG(ZONE_TEST, (TEXT("WaveOutpdd.c private_AudioOutInitialize: START\r\n")));

	// Get DMA Transfer Buffer Address (for Playback)
	get_DMA_Buffer_Address(pDriverGlobals->aud[AUDIO_NO].PLAY_CH, AUDIO_NO, dma_pagePhysicalAddress);

	// DMAC Initialize (for Playback)
	dma_Init(pDriverGlobals->aud[AUDIO_NO].PLAY_CH, &pDMA_out);

	//
	// DMA Setting
	//
	dma_SetPort(pDMA_out, get_DPTR(pDriverGlobals->aud[AUDIO_NO].PLAY_CH));
	dma_SetPage(pDMA_out,
                    0,					// Page0
                    get_DSAR(pDriverGlobals->aud[AUDIO_NO].PLAY_CH,AUDIO_NO,0),	// Sorce Address
                    get_DDAR(pDriverGlobals->aud[AUDIO_NO].PLAY_CH,AUDIO_NO,0),	// Destination Address
                    get_DTCR(pDriverGlobals->aud[AUDIO_NO].PLAY_CH,AUDIO_NO,0));	// Transfer Count
	dma_SetPage(pDMA_out,
                    1,					// Page1
                    get_DSAR(pDriverGlobals->aud[AUDIO_NO].PLAY_CH,AUDIO_NO,1),	// Sorce Address
                    get_DDAR(pDriverGlobals->aud[AUDIO_NO].PLAY_CH,AUDIO_NO,1),	// Destination Address
                    get_DTCR(pDriverGlobals->aud[AUDIO_NO].PLAY_CH,AUDIO_NO,1));	// Transfer Count

	// Module Initialize
	if( module_init(pDriverGlobals,AUDIO_NO) == FALSE ){
		// DMAC Deinitialize (for Playback)
		dma_Deinit( pDMA_out );
	}

	// Set pointers to virtual addresses of audio buffers
	SizeOfBuffer = (AUDIO_DMA_PAGE_SIZE * 2);
	pAudioBufferBase = VirtualAlloc(	NULL,
						SizeOfBuffer,
						MEM_RESERVE,
						PAGE_NOACCESS);
	if (pAudioBufferBase == NULL) {
		DEBUGMSG(ZONE_ERROR,(TEXT("Buffer virtual alloc NG!!\r\n")));
		module_deinit();
		return FALSE;
	}
	RET_VALUE = VirtualCopy(	(PVOID)pAudioBufferBase,
					(PVOID)dma_pagePhysicalAddress[0],
					(DWORD)SizeOfBuffer,
					PAGE_READWRITE | PAGE_NOCACHE);
	if (!RET_VALUE){
		DEBUGMSG(ZONE_ERROR,(TEXT("Buffer virtual copy NG!!\r\n")));
		VirtualFree((PVOID)pAudioBufferBase, 0, MEM_RELEASE);
		pAudioBufferBase = NULL;
		module_deinit();
		dma_Deinit(pDMA_out);
		return FALSE;
	}

	//
	// CODEC Initialize
	//
	if( codec_init() != TRUE ){
		VirtualFree((PVOID)pAudioBufferBase, 0, MEM_RELEASE);
		pAudioBufferBase = NULL;
		VirtualFree((PVOID)pDriverGlobals, 0, MEM_RELEASE);
		pDriverGlobals = NULL;
		module_deinit();
		dma_Deinit(pDMA_out);
		return FALSE;
	}

	// Initialize AudioOutInterrupt Flag
	pDriverGlobals->aud[AUDIO_NO].play_address = (ULONG)NULL;
	pDriverGlobals->aud[AUDIO_NO].outInt = (USHORT)NULL;


	DEBUGMSG(ZONE_TEST, (TEXT("WaveOutpdd.c private_AudioOutInitialize: END\r\n")));
	FUNC("-PDD_AudioOutInitialize");
	return TRUE;
}

/*****************************************************************************
*   FUNCTION :  	private_AudioOutPowerHandler
*   DESCRIPTION :   performs power on/off
*   INPUTS :		bPowerDown 1=power off, 0=power on
*   OUTPUTS :     	None
*   DESIGN NOTES :
*   CAUTIONS :
*****************************************************************************/
VOID
private_AudioOutPowerHandler(
	BOOL bPowerDown
	)
{
	BOOL Success;

	FUNC("private_AudioOutPowerHandler");
	DEBUGMSG(ZONE_TEST, (TEXT("private_AudioOutPowerHandler ---- bPowerDown=%d\r\n"),bPowerDown));

	if( bPowerDown )
	{
		private_AudioOutDeinitialize();
	}
	else
	{		// power up
		Success=private_AudioOutInitialize();
	}
	return;	// (see also private_WaveOutClose)
}

/*****************************************************************************
*   FUNCTION :  	private_AudioOutDeinitialize
*   DESCRIPTION :   Reset playback device to initial state
*   INPUTS :		None
*   OUTPUTS :     	None
*   DESIGN NOTES :
*   CAUTIONS :
*****************************************************************************/
VOID
private_AudioOutDeinitialize(
	VOID
	)
{
	FUNC("+PDD_AudioOutDeinitialize");

	// DMA Deinit
	dma_Deinit(pDMA_out);
		
	// Module Deinit
	module_deinit();

	// DMA Transfer Buffer Release
	if( pAudioBufferBase ){
		VirtualFree((PVOID)pAudioBufferBase, 0, MEM_RELEASE);
		pAudioBufferBase = NULL;
	}
		
	// Audio Global Buffer Release
	if( pDriverGlobals ){
		VirtualFree((PVOID)pDriverGlobals, 0, MEM_RELEASE);
		pDriverGlobals = NULL;
	}

	FUNC("-PDD_AudioOutDeinitialize");

}

/*****************************************************************************
*   FUNCTION :  	private_WaveOutStart
*   DESCRIPTION :   Initiates playback of wave
*   INPUTS :		wave
*   OUTPUTS :     	None
*   DESIGN NOTES :  puts double buffer in initial state, starts play
*   CAUTIONS :
*****************************************************************************/
VOID
private_WaveOutStart (
	PWAVEHDR pwh
	)
{
	const PPCMWAVEFORMAT pFormat = (PPCMWAVEFORMAT) g_pwfx[WAPI_OUT];
	DWORD i;

	FUNC_WPDD("+PDD_WaveOutStart");

	v_fMoreData[WAPI_OUT] = TRUE;						// more data expected

	module_txstart();	// Tx Start

	i = 0;
	while ( private_ChangeSampleRate(pFormat->wf.nSamplesPerSec) == FALSE ){		// Set Sampling Rate
		i++;
		if(i>5) break;
	}
	
	v_nNextPage = 0;

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
经典三级视频一区| 激情综合色播五月| 蜜桃在线一区二区三区| 豆国产96在线|亚洲| 91麻豆国产在线观看| 欧美性大战久久久| 91国偷自产一区二区使用方法| 91美女福利视频| 91在线porny国产在线看| 93久久精品日日躁夜夜躁欧美| 97久久精品人人澡人人爽| 欧美三级三级三级| 91麻豆精品国产91久久久久| 日韩欧美色综合| 亚洲欧美一区二区在线观看| 国产美女视频91| 91理论电影在线观看| 欧美性一区二区| 久久久久久久久久看片| 亚洲欧洲日产国码二区| 久久99精品网久久| 在线视频欧美精品| 精品人伦一区二区色婷婷| 国产精品久久久久久亚洲毛片 | 中文字幕成人av| 亚洲一区在线观看网站| 精品一区免费av| 色偷偷一区二区三区| 久久女同性恋中文字幕| 国产精品污www在线观看| 亚洲国产日韩综合久久精品| 国产福利精品一区| 欧美高清性hdvideosex| 中文字幕av一区二区三区免费看| 亚洲一区二区三区四区在线免费观看| 久久99国内精品| 精品视频在线视频| 亚洲女同女同女同女同女同69| 美国欧美日韩国产在线播放| 欧美视频一二三区| 欧美激情在线一区二区| 久久精品国产秦先生| 欧美不卡在线视频| 免费人成精品欧美精品 | 亚洲最快最全在线视频| 成人综合婷婷国产精品久久蜜臀| 欧美一区二区久久| 久久激情五月激情| 久久久久久免费毛片精品| 成人小视频在线观看| 国产精品蜜臀在线观看| 色系网站成人免费| 秋霞国产午夜精品免费视频| 久久精品视频一区二区| 色哟哟一区二区| 蜜桃视频在线观看一区| 国产色产综合色产在线视频| av一本久道久久综合久久鬼色| ...av二区三区久久精品| 精品视频全国免费看| 午夜精品在线看| 久久影院视频免费| 色综合久久久久综合体| 久久成人精品无人区| 国产亚洲欧美一级| 91精彩视频在线| 日韩av一区二| 国产精品天干天干在线综合| 91久久精品日日躁夜夜躁欧美| 午夜精品久久久久久不卡8050| 制服丝袜日韩国产| 成人永久免费视频| 天天综合网天天综合色| 国产日产欧美一区二区视频| 欧美色倩网站大全免费| 国产不卡视频一区| 日产精品久久久久久久性色| 欧美极品另类videosde| 欧美久久高跟鞋激| caoporm超碰国产精品| 蜜臀av性久久久久蜜臀aⅴ流畅| 国产精品入口麻豆九色| 欧美一区二区三区视频| 色综合一区二区| 国产一区啦啦啦在线观看| 亚洲线精品一区二区三区八戒| 欧美精品一区二区久久久| 欧美日韩精品一区二区三区| 国产成人综合在线观看| 青青青爽久久午夜综合久久午夜| 自拍偷拍亚洲欧美日韩| 久久综合资源网| 91精品免费在线观看| 色综合中文字幕| 国产在线精品免费av| 一区二区三区中文免费| 国产日产欧产精品推荐色 | 国产精品嫩草影院com| 欧美精品国产精品| 欧洲一区在线电影| 处破女av一区二区| 国产又黄又大久久| 麻豆精品蜜桃视频网站| 亚洲国产日韩一级| 亚洲小说欧美激情另类| 亚洲欧美一区二区不卡| 中文字幕五月欧美| 欧美国产精品一区二区三区| 欧美tickling网站挠脚心| 欧美日韩中字一区| 日本韩国一区二区| 91美女片黄在线| 色综合久久九月婷婷色综合| 成人午夜碰碰视频| 97精品国产97久久久久久久久久久久 | av不卡免费在线观看| 国产高清久久久久| 粉嫩欧美一区二区三区高清影视| 久久成人精品无人区| 国产曰批免费观看久久久| 久久精品国产成人一区二区三区| 日日欢夜夜爽一区| 日本在线观看不卡视频| 国产一区中文字幕| 国产寡妇亲子伦一区二区| 成人av资源站| 色天天综合久久久久综合片| 在线观看网站黄不卡| 欧美美女bb生活片| 91精品国产乱| 久久一二三国产| 欧美国产日韩亚洲一区| 一区二区三区国产精华| 亚洲精品视频免费观看| 一区二区三区欧美视频| 视频一区在线视频| 国产麻豆精品在线| 91在线观看一区二区| 欧美性感一区二区三区| 欧美精品 国产精品| 国产亚洲一区二区三区在线观看 | 国产suv精品一区二区6| 99久久综合国产精品| 欧美无砖专区一中文字| 日韩欧美成人一区| 中文字幕 久热精品 视频在线| 亚洲最新视频在线观看| 另类小说视频一区二区| 成人综合在线网站| 欧美日韩国产影片| 久久久久久久久久久久电影| 亚洲少妇最新在线视频| 美国一区二区三区在线播放| 国模少妇一区二区三区| 91在线一区二区| 91精品国产乱| 亚洲乱码日产精品bd| 人妖欧美一区二区| 高清beeg欧美| 91精品国产乱码| 一区二区三区四区在线播放| 美国十次综合导航| 在线亚洲一区二区| 久久午夜羞羞影院免费观看| 亚洲一区中文日韩| 岛国一区二区三区| 日韩女优电影在线观看| 亚洲日本在线a| 国产成人自拍在线| 欧美一卡二卡三卡| 亚洲成人自拍网| 成人激情免费电影网址| 日韩女优制服丝袜电影| 亚洲国产精品精华液网站| 成人午夜激情片| 精品久久一区二区三区| 日韩精品一区第一页| 99久久婷婷国产综合精品| 精品久久久久香蕉网| 亚洲妇女屁股眼交7| 成人av电影在线观看| 2021国产精品久久精品| 天天综合色天天综合| 中文字幕欧美激情| 麻豆91精品91久久久的内涵| 在线观看日韩电影| 欧美激情一区二区三区不卡| 国内精品写真在线观看| 欧美高清视频在线高清观看mv色露露十八| 久久久久久久久久久久久女国产乱| 亚洲成av人影院| 欧美日韩免费高清一区色橹橹| 1区2区3区精品视频| 国产福利一区二区| 中文无字幕一区二区三区| 美女在线观看视频一区二区| 欧美三级韩国三级日本三斤| 亚洲另类在线视频| 色婷婷一区二区三区四区| 国产精品国产三级国产|