?? tmman.c
字號:
/*----------------------------------------------------------------------------
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 + -