⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tmman.c

📁 PNX系列设备驱动 PNX系列设备驱动
💻 C
📖 第 1 页 / 共 3 页
字号:
/*---------------------------------------------------------------------------- 
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
*/

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

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


/*----------------------------------------------------------------------------
          FUNCTION PROTOTYPES
----------------------------------------------------------------------------*/

NTSTATUS DriverEntry(
    IN PDRIVER_OBJECT pDriverObject,
    IN PUNICODE_STRING RegistryPath );

VOID DriverExit(
    IN PDRIVER_OBJECT pDriverObject );

NTSTATUS tmmanOpen(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp );

NTSTATUS tmmanClose(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp );

NTSTATUS tmmanDeviceControl(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp );

NTSTATUS tmmanRead(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp );

NTSTATUS tmmanWrite(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp );


BOOLEAN RegistryEnumerateKeyNameToDWORD( 
	HANDLE	RegistryHandle,
	ULONG   Index,
	PULONG	ValuePtr );


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

BOOLEAN 
InitTriMedia (
	halParameters* Config );

BOOLEAN
InitBridge ( 
	halParameters* Config );

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

#ifdef ALLOC_PRAGMA
#pragma alloc_text(INIT,DriverEntry)
#pragma alloc_text(INIT,tmmanInit)
#endif

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

#define MAX_TMSUBSYSTEMID_ACCEPTED 10


NTSTATUS DriverEntry(
    IN PDRIVER_OBJECT DriverObject,
    IN PUNICODE_STRING RegistryPath
)
{
	
	ULONG				TMSubSystemIDAccepted[MAX_TMSUBSYSTEMID_ACCEPTED];
	ULONG				ulTMSubSystemIDAcceptedCount;
	ULONG				Idx;
	NTSTATUS			NTStatus;
    UNICODE_STRING		UserDeviceNameString;
    UNICODE_STRING		KernelDeviceNameString;
	PDEVICE_OBJECT		DeviceObject;
    OBJECT_ATTRIBUTES	RegistryObjectAttributes;
	UNICODE_STRING		TMManRegistryPath;
	debugParameters		DebugParameters;
    ULONG				Disposition;


	RtlInitUnicodeString ( &UserDeviceNameString, L"\\DosDevices\\TMMAN" );
	RtlInitUnicodeString ( &KernelDeviceNameString, L"\\Device\\TriMedia" );

	DbgPrint ( "\nRegistryPath[%wZ]\n",
		RegistryPath );
	
	DbgPrint ( "UserName[%wZ]\n",
		&UserDeviceNameString );

	DbgPrint ( "KernelName[%wZ]\n",
		&KernelDeviceNameString );



	// Create the device object
    NTStatus = IoCreateDevice(
		 DriverObject,
		 sizeof (GlobalObject),
		 &KernelDeviceNameString,
		 FILE_DEVICE_UNKNOWN,
		 0,                        // No standard device characteristics
		 FALSE,                    // This isn't an exclusive device
		 &DeviceObject  );

    if ( ! NT_SUCCESS(NTStatus) )
    {
		DbgPrint ( "tmman:DriverEntryIoCreateDevice:FAIL[%x]\n", NTStatus );
		goto DriverEntryExit1;
	}

    // Create a link from our device name to a name in the Win32 namespace.
    NTStatus = IoCreateSymbolicLink ( 
		&UserDeviceNameString, 
		&KernelDeviceNameString);

    if ( ! NT_SUCCESS(NTStatus) )
    {
		DbgPrint ( "tmman:DriverEntry:IoCreateSymbolicLink:FAIL[%x]\n", NTStatus );
		goto DriverEntryExit2;
    }

    // set the io flags
    DeviceObject->Flags |= DO_BUFFERED_IO;

	TMManGlobal = (GlobalObject*)DeviceObject->DeviceExtension;

	// begin registry param reads here

	RtlInitUnicodeString ( &TMManRegistryPath , 
		L"\\REGISTRY\\Machine\\SOFTWARE\\PhilipsSemiconductors\\TriMedia\\TMMan" );

	DebugParameters.TraceBufferSize = constTMManHostTraceBufferSize;
	DebugParameters.LevelBitmap = constTMManHostTraceLeveBitmap;
	DebugParameters.Type = constTMManHostTraceType;
	TMManGlobal->TargetTraceBufferSize = constTMManTargetTraceBufferSize;
	TMManGlobal->TargetTraceLeveBitmap = constTMManTargetTraceLeveBitmap;
	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;

    InitializeObjectAttributes(
        &RegistryObjectAttributes,
        &TMManRegistryPath,           
        OBJ_CASE_INSENSITIVE,   
        NULL,                   
        NULL                    
        );

    NTStatus = ZwCreateKey(
		&TMManGlobal->RegistryHandle,
		KEY_WRITE,
		&RegistryObjectAttributes,
		0,                 
		NULL,              
		0,                 
		&Disposition);     

	if ( ! NT_SUCCESS ( NTStatus ) )
	{
		DbgPrint ( "tmman:ZwCreateKey(%wZ):FAIL[%x]\n", &TMManRegistryPath, NTStatus );
	}
	else
	{
		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 );


		

		NTStatus = ZwClose(
			TMManGlobal->RegistryHandle );
	}


	
	RtlInitUnicodeString ( &TMManRegistryPath , L"\\REGISTRY\\Machine\\SOFTWARE\\PhilipsSemiconductors\\TriMedia\\TMMan\\TMSubSystemID" );

	InitializeObjectAttributes(
        &RegistryObjectAttributes,
        &TMManRegistryPath,           
        OBJ_CASE_INSENSITIVE,   
        NULL,                   
        NULL                    
        );

    NTStatus = ZwCreateKey(
		&TMManGlobal->RegistryHandle,
		KEY_WRITE,
		&RegistryObjectAttributes,
		0,                 
		NULL,              
		0,                 
		&Disposition);     

	memSet( TMSubSystemIDAccepted, 0, sizeof(TMSubSystemIDAccepted));
	ulTMSubSystemIDAcceptedCount = 0;
	if ( ! NT_SUCCESS ( NTStatus ) )
	{
		DbgPrint ( "tmman:ZwCreateKey(%wZ):FAIL[%x]\n", &TMManRegistryPath, NTStatus );
	}
	else
	{
		// Read all SubSystemID
		NTSTATUS status;
		ULONG i = 0;
		ULONG ulValue;
	
		for( i = 0; i < MAX_TMSUBSYSTEMID_ACCEPTED; i++)
		{
		
			if(RegistryEnumerateKeyNameToDWORD( TMManGlobal->RegistryHandle, i, &ulValue ))
			{
				ulTMSubSystemIDAcceptedCount++;
				TMSubSystemIDAccepted[i] = ulValue;
				DbgPrint ( "\t SubVendorID: 0x%x\n", ulValue);
			}
			else
			{
				DbgPrint ( "\t SubVendorID exit: %d\n", i);
				break;
			}
		}
	}

	NTStatus = ZwClose( TMManGlobal->RegistryHandle );
	
	
	// end registry

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

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

	TMManGlobal->DriverObject = DriverObject;

	TMManGlobal->DriverRegistryPath.Length = 0;

	TMManGlobal->DriverRegistryPath.Buffer = 
		ExAllocatePool ( PagedPool, RegistryPath->Length );
		
	if ( TMManGlobal->DriverRegistryPath.Buffer == NULL )
	{
		DPF(0,("tmman:DriverEntry:ExAllocatePool:RegistryPath:FAIL\n"));
		goto DriverEntryExit3;
	}

	TMManGlobal->DriverRegistryPath.MaximumLength = RegistryPath->Length;

	RtlCopyUnicodeString ( &TMManGlobal->DriverRegistryPath,  RegistryPath );

	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;
	}

    //Create dispatch points
	DriverObject->MajorFunction[IRP_MJ_CREATE]         = tmmanOpen;
	DriverObject->MajorFunction[IRP_MJ_CLOSE]          = tmmanClose;
    DriverObject->MajorFunction[IRP_MJ_DEVICE_CONTROL] = tmmanDeviceControl;
    DriverObject->DriverUnload                         = DriverExit;


	// 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  ( constTMMANDECBridgeVendorID, constTMMANDECBridgeDeviceID, NULL );
	//check if user requested only specific SubSystemID
	pnpFindPCIDevices  ( constTMMANTM1000VendorID, constTMMANTM1000DeviceID, ulTMSubSystemIDAcceptedCount == 0 ? NULL : TMSubSystemIDAccepted );

	pnpFindPCIDevices  ( constTMMANTM2000VendorID, constTMMANTM2000DeviceID, NULL );
	//check if user requested only specific SubSystemID
	pnpFindPCIDevices  ( constTMMANTM1300VendorID, constTMMANTM1300DeviceID, ulTMSubSystemIDAcceptedCount == 0 ? NULL : TMSubSystemIDAccepted );
	

	// if we haven't found atleast one board to run on, then unload
	/*
	if ( TMManGlobal->DeviceCount  == 0 )
	{
		goto DriverEntryExit4;	
	}
	*/
	return STATUS_SUCCESS;

//DriverEntryExit4:
//	ExFreePool (TMManGlobal->DriverRegistryPath.Buffer  );

DriverEntryExit3:
	IoDeleteSymbolicLink ( &UserDeviceNameString );

DriverEntryExit2:
	IoDeleteDevice ( DeviceObject );

DriverEntryExit1:
	return STATUS_UNSUCCESSFUL;

}

VOID DriverExit (
    IN PDRIVER_OBJECT DriverObject )
{
	ULONG	Idx;
    UNICODE_STRING	UserDeviceNameString;
	RtlInitUnicodeString ( &UserDeviceNameString, L"\\DosDevices\\TMMAN" );
	
	for ( Idx = 0 ; Idx < TMManGlobal->DeviceCount ;
		Idx++ )
	{
		if ( TMManGlobal->DeviceList[Idx] )
		{
			tmmanExit ( Idx );
			TMManGlobal->DeviceList[Idx] = NULL;
		}
	}

	debugExit( );

	ExFreePool ( TMManGlobal->DriverRegistryPath.Buffer  );

	IoDeleteSymbolicLink ( &UserDeviceNameString );

	IoDeleteDevice ( TMManGlobal->DeviceObject );
}

//////////////////////////////////////////////////////////////////////////////
//
//	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;

	NTSTATUS					NTStatus;
	TMStatus					Status;
	PHYSICAL_ADDRESS			HighestPhysicalAddress;
	TMManDeviceObject*			TMManDevice;

	HANDLE						RegistryHandle;
	OBJECT_ATTRIBUTES			RegistryObjectAttributes;
	ULONG						Disposition;
	CHAR						TMManRegistryPathCHAR[100];
	UNICODE_STRING				TMManRegistryPath;
	ANSI_STRING					TMManRegistryPathANSI;



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

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -