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

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

?? tmman.c

?? PNX系列設備驅動 PNX系列設備驅動
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*---------------------------------------------------------------------------- 
COPYRIGHT (c) 1997 by Philips Semiconductors

THIS SOFTWARE IS FURNISHED UNDER A LICENSE AND MAY ONLY BE USED AND COPIED IN 
ACCORDANCE WITH THE TERMS AND CONDITIONS OF SUCH A LICENSE AND WITH THE 
INCLUSION OF THE THIS COPY RIGHT NOTICE. THIS SOFTWARE OR ANY OTHER COPIES 
OF THIS SOFTWARE MAY NOT BE PROVIDED OR OTHERWISE MADE AVAILABLE TO ANY OTHER
PERSON. THE OWNERSHIP AND TITLE OF THIS SOFTWARE IS NOT TRANSFERRED. 

THE INFORMATION IN THIS SOFTWARE IS SUBJECT TO CHANGE WITHOUT ANY PRIOR NOTICE
AND SHOULD NOT BE CONSTRUED AS A COMMITMENT BY Philips Semiconductor. 

PHILIPS ASSUMES NO RESPONSIBILITY FOR THE USE OR RELIABILITY OF THIS SOFTWARE
ON PLATFORMS OTHER THAN THE ONE ON WHICH THIS SOFTWARE IS FURNISHED.
----------------------------------------------------------------------------*/
/*
	HISTORY
	970804	Tilakraj Roy	Created from vtmman sources for NT Workstation
	982005	Volker Schildwach	Ported to WinCE User Mode DLL
*/

/*----------------------------------------------------------------------------
          SYSTEM INCLUDE FILES
----------------------------------------------------------------------------*/
#include <windows.h>
#include "ceddk.h"

/*----------------------------------------------------------------------------
          DRIVER SPECIFIC INCLUDE FILES
----------------------------------------------------------------------------*/
#include "tmmanapi.h"
#include "tmmanlib.h"
#include "platform.h"


/*----------------------------------------------------------------------------
          GLOBAL DATA STRUCTURE INSTANSCIATION
----------------------------------------------------------------------------*/
GlobalObject *TMManGlobal;


/*----------------------------------------------------------------------------
          FUNCTION PROTOTYPES
----------------------------------------------------------------------------*/
// Windows CE entry exit and IOCTL function calls are different
BOOLEAN RegistryOpen ( 
	HANDLE	*RegistryHandle, 
	PWCHAR	RegistryKey );

VOID	RegistryClose ( 
	HANDLE RegistryHandle );

BOOLEAN RegistryReadDWORD ( 
	HANDLE	RegistryHandle, 
	PWCHAR	ValueName,
	PULONG	ValuePtr );

Pointer PsGetCurrentProcess( VOID );


DWORD TMM_Init(
	DWORD	dwRegistryPath);

BOOL
TMM_Deinit(
	DWORD	dwDeviceContext);


/*----------------------------------------------------------------------------
          PAGE LOCKING
----------------------------------------------------------------------------*/


/*----------------------------------------------------------------------------
          FUNCTION DEFINITIONS
----------------------------------------------------------------------------*/

BOOL WINAPI
DllMain(
	HINSTANCE   hDllInstance, 
	ULONG       uReason, 
	LPVOID      lpReserved
   )
{
	switch (uReason) 
	{
		case DLL_PROCESS_ATTACH:
			OutputDebugString(TEXT("TMM: DLL_PROCESS_ATTACH\n"));
			break;
		case DLL_PROCESS_DETACH:
			OutputDebugString(TEXT("TMM: DLL_PROCESS_DETACH\n"));
			break;
    } 
    return TRUE;
}

DWORD TMM_Init(
	DWORD	dwRegistryPath )
{
	ULONG				Idx;
	NTSTATUS			NTStatus;
	USHORT				TMManRegistryPath[256];
    static DWORD        dwDeviceHandle = 0;
	debugParameters		DebugParameters;

	OutputDebugString(TEXT("tmman:TMM_Init:ENTER\n"));    
    
	if (dwDeviceHandle)
    {
	    DPF(0,("tmman:tmmanInit:already initialized!\n"));
        goto TMM_InitExit1;
    }
    
    if( ( TMManGlobal =  
		(GlobalObject*)memAllocate ( sizeof(GlobalObject)) ) == NULL )
	{
	    DPF(0,("tmman:tmmanInit:memAllocate:FAILED\n"));
        goto TMM_InitExit1;
	}
    
    wsprintf ( TMManRegistryPath , L"SOFTWARE\\PhilipsSemiconductors\\TriMedia\\TMMan" );


	DebugParameters.TraceBufferSize = constTMManHostTraceBufferSize;
	DebugParameters.LevelBitmap = 0x1;
	DebugParameters.Type = constTMManDebugTypeOutput;
	TMManGlobal->TargetTraceBufferSize = constTMManTargetTraceBufferSize;
	TMManGlobal->TargetTraceLeveBitmap = 0x0;
	TMManGlobal->TargetTraceType = constTMManTargetTraceType;
	TMManGlobal->MemorySize = constTMManMemorySize;
	TMManGlobal->MailboxCount = constTMManMailboxCount;
	TMManGlobal->ChannelCount = constTMManChannelCount;
	TMManGlobal->VIntrCount = constTMManVIntrCount;
	TMManGlobal->MessageCount = constTMManMessageCount;
	TMManGlobal->EventCount = constTMManEventCount;
	TMManGlobal->NameSpaceCount = constTMManNameSpaceCount;
	TMManGlobal->MemoryCount = constTMManMemoryCount;
	TMManGlobal->SGBufferCount = constTMManSGBufferCount;
	TMManGlobal->StreamCount = constTMManStreamCount;
	TMManGlobal->SpeculativeLoadFix = 0;
	TMManGlobal->PCIInterruptNumber = constTMMANTargetToHostIRQ;
	TMManGlobal->MMIOInterruptNumber = constTMMANHostToTargetIRQ;
	TMManGlobal->MapSDRAM = TRUE;

	// specific to WinCE
	TMManGlobal->OEMIOCTLBase = constTMMANOEMIoctlBase;
	TMManGlobal->PageLockedMemoryBase = constTMMANPageLockedMemoryBase;
	TMManGlobal->PageLockedMemorySize = constTMMANPageLockedMemorySize;

    if ( RegistryOpen (
		&TMManGlobal->RegistryHandle,
		TMManRegistryPath ) != TRUE )
	{
		OutputDebugString(TEXT("tmman:TMM_Init:RegistryOpen:FAIL\n"));    
        DPF(0,("tmman:RegistryOpen(%wZ) : FAILED\n", TMManRegistryPath));
	}
	else
	{
		OutputDebugString(TEXT("tmman:TMM_Init:RegistryOpen:OK\n"));    
		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"HostTraceBufferSize",
			&DebugParameters.TraceBufferSize );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"HostTraceLevelBitmap",
			&DebugParameters.LevelBitmap );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"HostTraceType",
			&DebugParameters.Type );


		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"TargetTraceBufferSize",
			&TMManGlobal->TargetTraceBufferSize );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"TargetTraceLevelBitmap",
			&TMManGlobal->TargetTraceLeveBitmap );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"TargetTraceType",
			&TMManGlobal->TargetTraceType );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"MemorySize",
			&TMManGlobal->MemorySize );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"MailboxCount",
			&TMManGlobal->MailboxCount );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"ChannelCount",
			&TMManGlobal->ChannelCount );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"VIntrCount",
			&TMManGlobal->VIntrCount );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"MessageCount",
			&TMManGlobal->MessageCount );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"EventCount",
			&TMManGlobal->EventCount );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"StreamCount",
			&TMManGlobal->StreamCount );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"NameSpaceCount",
			&TMManGlobal->NameSpaceCount );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"MemoryCount",
			&TMManGlobal->MemoryCount );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"SGBufferCount",
			&TMManGlobal->SGBufferCount );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"SpeculativeLoadFix",
			&TMManGlobal->SpeculativeLoadFix );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"PCIInterruptNumber",
			&TMManGlobal->PCIInterruptNumber );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"MMIOInterruptNumber",
			&TMManGlobal->MMIOInterruptNumber );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"MapSDRAM",
			&TMManGlobal->MapSDRAM );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"OEMIOCTLBase",
			&TMManGlobal->OEMIOCTLBase );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"PageLockedMemoryBase",
			&TMManGlobal->PageLockedMemoryBase );

		RegistryReadDWORD (
			TMManGlobal->RegistryHandle,
			L"PageLockedMemorySize",
			&TMManGlobal->PageLockedMemorySize );


		RegistryClose(
			TMManGlobal->RegistryHandle );
	}

	// end registry

	// initialize the debugging subsystem so that we can start dumping stuff
	debugInit ( &DebugParameters );

	// initialize the Global Object 
	TMManGlobal->DeviceObject = 0;

	TMManGlobal->BitFlags = 0;
	TMManGlobal->MaximumDevices = constTMMANMaximumDeviceCount;
	TMManGlobal->MaximumClients = constTMMANMaximumClientCount;
	TMManGlobal->DeviceCount = 0;
	TMManGlobal->ClientCount = 0;

	for ( Idx = 0 ; Idx < TMManGlobal->MaximumDevices ; Idx++ )
	{
			TMManGlobal->DeviceList[Idx] = NULL;
	}

	
	for ( Idx = 0 ; Idx < TMManGlobal->MaximumClients ; Idx++ )
	{
			TMManGlobal->ClientList[Idx] = NULL;
	}

	// enumerate all the PCI devices in the sytem that have a matching
	// device and vendor ID and call the tmman initializaiton routine
	// to allocate resources for the specifc device object

	// this function call the function tmmanInit with the halParameters
	// structures.
	
	pnpFindPCIDevices  ( constTMMANTM1000VendorID, constTMMANTM1000DeviceID );

	pnpFindPCIDevices  ( constTMMANTM2000VendorID, constTMMANTM2000DeviceID );

    // increase device handle
    dwDeviceHandle++;
	OutputDebugString(TEXT("tmman:TMM_Init:EXIT:OK\n"));    
    return dwDeviceHandle;

TMM_InitExit1:
	OutputDebugString(TEXT("tmman:TMM_Init:EXIT:FAIL\n"));    
	return NULL;

}

BOOL
TMM_Deinit(
	DWORD	dwDeviceContext )
{
	ULONG	Idx;
	
	for ( Idx = 0 ; Idx < TMManGlobal->DeviceCount ;
		Idx++ )
	{
		if ( TMManGlobal->DeviceList[Idx] )
		{
			tmmanExit ( Idx );
			TMManGlobal->DeviceList[Idx] = NULL;
		}
	}

	debugExit( );


    // free allocated structure
    memFree (TMManGlobal);      

    return TRUE;
}

//////////////////////////////////////////////////////////////////////////////
//
//	STANDARD ENTRY POINTS
//
//////////////////////////////////////////////////////////////////////////////

Pointer	tmmanInit ( 
	UInt32 DSPNumber, 
	Pointer Configuration )
{

	halParameters*				HalParameters = (halParameters*)Configuration;
	channelManagerParameters	ChannelParameters;
	vintrManagerParameters		VIntrParameters;
	eventManagerParameters		EventParameters;
	messageManagerParameters	MessageParameters;
	memoryManagerParameters		MemoryParameters;
	namespaceManagerParameters	NameSpaceParameters;
	sgbufferManagerParameters	SGBufferParameters;

	UInt32						TMManControlSize;
	UInt32						HalControlSize;
	UInt32						NameSpaceControlSize;
	UInt32						MemoryControlSize;

	TMStatus					Status;

	// required by MmAllocateContigiousPhysicalMemory
	PHYSICAL_ADDRESS			HighestPhysicalAddress;

	TMManDeviceObject* TMManDevice;

	// all this has to be done on a device specific basis

	TMManDevice = memAllocate ( 
		sizeof ( TMManDeviceObject ) );

	if ( TMManDevice == NULL )
	{
		DPF(0,("tmman:tmmanInit:memAllocate:TMManDevice:FAIL\n"));
		goto tmmanInitExit1;			
	}
	
	// for back reference
	TMManDevice->Status = constTMManDSPStatusReset;
	TMManDevice->DSPNumber = DSPNumber;

	// allocate shared memory for TMMan Control, Hal, NameSpace, Memory 
	// allocating these toghether provides optimum usage of Contiguous Memory

	//calculate the total size required
	TMManControlSize = sizeof ( TMManSharedStruct );
	HalControlSize = sizeof  ( HalControl );
	NameSpaceControlSize = namespaceSharedDataSize ( TMManGlobal->NameSpaceCount );
	MemoryControlSize = memorySharedDataSize ( TMManGlobal->MemoryCount );

	// allocate all the contiguous memeory at one shot, that will optimize 
	// IA32 page usage.
	HighestPhysicalAddress.LowPart = 0xffffffff;
	HighestPhysicalAddress.HighPart = 0x00000000;

	// any shred memory that is allocate outside memoryCreate should be done

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品视频1区2区| 亚洲视频在线一区观看| 中文在线资源观看网站视频免费不卡| 国产精品美女www爽爽爽| 日韩中文字幕麻豆| 99免费精品视频| 日韩欧美一级二级三级久久久| 国产精品午夜在线观看| 精品亚洲国产成人av制服丝袜 | 日本道免费精品一区二区三区| 91精品国产欧美一区二区成人 | 日韩三级精品电影久久久| 亚洲免费色视频| 成人动漫在线一区| 久久久777精品电影网影网 | 日韩国产在线观看| 在线亚洲一区观看| 中文字幕日本不卡| 国产成人鲁色资源国产91色综| 欧美一区二区网站| 日韩精品一级二级| 欧美日韩大陆一区二区| 亚洲一区二区三区四区不卡 | 国产成人精品免费| 久久青草国产手机看片福利盒子 | 亚洲成人资源网| 欧洲精品视频在线观看| 一区二区三区精品视频在线| 91热门视频在线观看| **欧美大码日韩| 91一区二区三区在线播放| 久久久久久久久久久久电影| 狠狠久久亚洲欧美| 久久久www成人免费毛片麻豆| 精品影视av免费| 国产亚洲一区二区三区四区 | 国产亚洲短视频| 国产成人av网站| 国产精品萝li| 日本韩国欧美在线| 午夜精品久久久久久不卡8050| 欧美丝袜自拍制服另类| 五月天丁香久久| 日韩欧美国产三级电影视频| 狠狠色2019综合网| 国产精品久久久久久户外露出 | 夜夜精品浪潮av一区二区三区| 在线观看国产91| 日韩电影免费一区| 久久综合丝袜日本网| 成人福利视频网站| 亚洲国产综合在线| 欧美大尺度电影在线| 国产乱对白刺激视频不卡| 国产精品成人免费在线| 欧美自拍丝袜亚洲| 乱中年女人伦av一区二区| 国产视频不卡一区| 在线免费精品视频| 免费观看一级特黄欧美大片| 国产亚洲欧美日韩在线一区| 99精品视频中文字幕| 日韩在线观看一区二区| 国产欧美日本一区二区三区| 91美女精品福利| 毛片不卡一区二区| 亚洲丝袜另类动漫二区| 欧美精品久久久久久久多人混战| 国产资源精品在线观看| 一区二区三区四区视频精品免费 | 7878成人国产在线观看| 国产一区激情在线| 亚洲高清视频中文字幕| 国产三级欧美三级日产三级99 | 色素色在线综合| 男女性色大片免费观看一区二区| 欧美国产1区2区| 337p亚洲精品色噜噜| 高清国产午夜精品久久久久久| 亚洲激情校园春色| 国产日韩av一区| 制服视频三区第一页精品| 成人av第一页| 国产综合久久久久影院| 日本在线播放一区二区三区| 日韩美女视频19| 久久综合九色综合久久久精品综合| 欧美三级一区二区| 99久久婷婷国产精品综合| 国产在线精品一区二区夜色| 亚洲成人资源网| 一区二区高清免费观看影视大全 | 午夜精品久久久久影视| 一区二区三区资源| 91麻豆国产福利精品| 黑人精品欧美一区二区蜜桃| 亚洲成人免费观看| 亚洲欧洲一区二区在线播放| 久久综合一区二区| 日韩视频在线永久播放| 欧美夫妻性生活| 精品视频全国免费看| 一本久久a久久免费精品不卡| youjizz久久| 国产成人精品免费在线| 国产成人日日夜夜| 国产激情偷乱视频一区二区三区| 国产综合成人久久大片91| 麻豆精品视频在线观看免费| 秋霞影院一区二区| 麻豆成人av在线| 久久精品国产精品亚洲精品| 免费精品视频在线| 麻豆国产欧美日韩综合精品二区| 奇米影视一区二区三区| 日本不卡高清视频| 黄一区二区三区| 国产高清成人在线| 成人综合婷婷国产精品久久蜜臀 | 久久久久久久久久久久电影| 日韩免费性生活视频播放| 日韩一区二区电影在线| 日韩午夜中文字幕| 精品国产一区二区三区四区四 | 亚洲精品免费在线播放| 亚洲美女免费在线| 夜夜精品视频一区二区| 天天av天天翘天天综合网| 婷婷成人综合网| 精品亚洲国产成人av制服丝袜| 国产高清精品在线| 色欧美片视频在线观看| 欧美日韩在线观看一区二区| 91精品国产欧美一区二区| 精品精品欲导航| 国产精品毛片a∨一区二区三区| 亚洲欧美另类久久久精品| 亚洲电影你懂得| 精品亚洲免费视频| 99综合电影在线视频| 欧美三级中文字幕| 欧美不卡一二三| 亚洲欧洲国产日本综合| 日本亚洲最大的色成网站www| 国产在线播精品第三| 91免费视频大全| 日韩欧美国产综合| 国产精品第四页| 美女免费视频一区二区| 粉嫩av亚洲一区二区图片| 在线精品亚洲一区二区不卡| 日韩一区二区免费视频| 亚洲免费三区一区二区| 久久国产尿小便嘘嘘| 91色乱码一区二区三区| 欧美大片顶级少妇| 亚洲一区视频在线| 丰满白嫩尤物一区二区| 正在播放亚洲一区| 欧美国产日韩一二三区| 日本成人在线不卡视频| 91首页免费视频| 亚洲欧洲一区二区在线播放| 久久国产夜色精品鲁鲁99| 欧美在线啊v一区| 中文字幕不卡在线观看| 日本亚洲视频在线| 欧美综合亚洲图片综合区| 久久久久久久久岛国免费| 亚洲午夜羞羞片| 91一区二区三区在线观看| 26uuu久久天堂性欧美| 性感美女久久精品| 色老汉av一区二区三区| 国产亚洲精品中文字幕| 麻豆精品在线播放| 欧美午夜电影一区| 亚洲乱码中文字幕| 国产99精品视频| 久久综合狠狠综合久久激情| 日日骚欧美日韩| 欧美三级午夜理伦三级中视频| 亚洲人精品一区| 大美女一区二区三区| 久久久精品免费网站| 极品尤物av久久免费看| 日韩欧美一区二区免费| 五月婷婷另类国产| 欧美三区在线观看| 亚洲一区二区三区小说| 欧美亚洲国产怡红院影院| 一区二区三区鲁丝不卡| 色婷婷国产精品综合在线观看| 中文字幕高清不卡| 粉嫩一区二区三区性色av| 中文一区一区三区高中清不卡| 国产剧情一区二区三区| 久久久久久久久免费| 国产成人精品三级| 国产精品国模大尺度视频|