Source code of Windows XP (NT5)
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

338 lines
5.9 KiB

//***************************************************************************
//
// main.c
//
// Module: Windows HBA API implmentation
//
// Purpose: Contains DLL entry points and main HBA api functions
//
// Copyright (c) 2001 Microsoft Corporation
//
//***************************************************************************
#include "hbaapip.h"
#include <stdio.h>
//***************************************************************************
//
// LibMain32
//
// Purpose: Entry point for DLL.
//
// Return: TRUE if OK.
//
//***************************************************************************
HANDLE Module;
BOOL WINAPI LibMain32(
HINSTANCE Instance,
ULONG Reason,
LPVOID pvReserved
)
{
if (DLL_PROCESS_ATTACH==Reason)
{
Mutex = CreateMutex(NULL,
FALSE,
NULL);
if (Mutex == NULL)
{
return(FALSE);
}
Module = Instance;
DisableThreadLibraryCalls(Module);
}
return(TRUE);
}
//
// Main HBA Apis
//
HBA_STATUS HBA_API HBA_RegisterLibrary(
PHBA_ENTRYPOINTS entrypoints
)
{
return(HBA_STATUS_ERROR_NOT_SUPPORTED);
}
HBA_UINT32 HBA_API HBA_GetVersion(
void
)
{
return(HBA_VERSION);
}
HBA_STATUS HBA_API HBA_LoadLibrary(
)
{
return(HBA_STATUS_OK);
}
HBA_STATUS HBA_API HBA_FreeLibrary(
void
)
{
return(HBA_STATUS_OK);
}
HBA_UINT32 HBA_API HBA_GetNumberOfAdapters(
void
)
{
HANDLE Handle;
PWNODE_ALL_DATA Buffer;
ULONG Count = 0;
ULONG Status;
Status = WmiOpenBlock((LPGUID)&MSFC_FCAdapterHBAAttributes_GUID,
GENERIC_READ,
&Handle);
if (Status == ERROR_SUCCESS)
{
Status = QueryAllData(Handle,
&Buffer);
if (Status == ERROR_SUCCESS)
{
Status = ParseAllData(Buffer,
&Count,
NULL,
NULL,
NULL),
FreeMemory(Buffer);
}
WmiCloseBlock(Handle);
}
return( Count );
}
HBA_STATUS HBA_GetAdapterNameW(
IN HBA_UINT32 AdapterIndex,
OUT PWCHAR AdapterName
)
{
HANDLE Handle;
PWNODE_ALL_DATA Buffer;
HBA_STATUS HbaStatus = HBA_STATUS_ERROR;
ULONG Count;
ULONG Len;
PWCHAR Name;
ULONG Status;
PUSHORT *InstanceNames;
Status = WmiOpenBlock((LPGUID)&MSFC_FCAdapterHBAAttributes_GUID,
GENERIC_READ,
&Handle);
if (Status == ERROR_SUCCESS)
{
Status = QueryAllData(Handle,
&Buffer);
if (Status == ERROR_SUCCESS)
{
Status = ParseAllData(Buffer,
&Count,
&InstanceNames,
NULL,
NULL);
if (Status == ERROR_SUCCESS)
{
if (AdapterIndex < Count)
{
Name = InstanceNames[AdapterIndex];
Len = *Name++;
wcsncpy(AdapterName, Name, Len/sizeof(WCHAR));
AdapterName[Len] = 0;
HbaStatus = HBA_STATUS_OK;
}
FreeMemory(InstanceNames);
}
FreeMemory(Buffer);
}
WmiCloseBlock(Handle);
}
return(HbaStatus);
}
HBA_STATUS HBA_API HBA_GetAdapterName(
IN HBA_UINT32 AdapterIndex,
OUT PCHAR AdapterName
)
{
WCHAR AdapterNameW[256];
HBA_STATUS HbaStatus;
ULONG Status;
HbaStatus = HBA_GetAdapterNameW(AdapterIndex,
AdapterNameW);
if (HbaStatus == HBA_STATUS_OK)
{
Status = UnicodeToAnsi(AdapterNameW,
AdapterName,
256);
if (Status != ERROR_SUCCESS)
{
HbaStatus = HBA_STATUS_ERROR;
}
}
return(HbaStatus);
}
HBA_HANDLE HBA_OpenAdapterW(
PWCHAR AdapterName
)
{
HBA_HANDLE HbaHandle = 0;
HANDLE Handle;
PADAPTER_HANDLE HandleData;
ULONG Status;
PWNODE_SINGLE_INSTANCE Buffer;
Status = WmiOpenBlock((LPGUID)&MSFC_FCAdapterHBAAttributes_GUID,
GENERIC_READ,
&Handle);
if (Status == ERROR_SUCCESS)
{
//
// Validate adapter name by querying for that adapter name as a
// WMI instance name
//
Status = QuerySingleInstance(Handle,
AdapterName,
&Buffer);
if (Status == ERROR_SUCCESS)
{
//
// If it exists then we allocate an adapter handle data
// structure and insert it on the list of open adapter
// handles
//
HandleData = AllocMemory(sizeof(ADAPTER_HANDLE));
if (HandleData != NULL)
{
memset(HandleData, 0, sizeof(ADAPTER_HANDLE));
HandleData->InstanceName = AllocMemory((wcslen(AdapterName) + 1) *
sizeof(WCHAR));
if (HandleData->InstanceName != NULL)
{
wcscpy(HandleData->InstanceName, AdapterName);
EnterCritSection();
HandleData->HbaHandle = HbaHandleCounter++;
InsertHeadList(&HbaHandleList, &HandleData->List);
LeaveCritSection();
HbaHandle = HandleData->HbaHandle;
} else {
FreeMemory(HandleData);
}
}
FreeMemory(Buffer);
}
WmiCloseBlock(Handle);
}
return(HbaHandle);
}
HBA_HANDLE HBA_API HBA_OpenAdapter(
PCHAR AdapterName
)
{
PWCHAR AdapterNameW;
ULONG Len, AllocLen;
ULONG Status;
HBA_HANDLE HbaHandle;
Len = strlen(AdapterName) + 1;
AllocLen = Len * sizeof(WCHAR);
AdapterNameW = AllocMemory(AllocLen);
if (AdapterNameW != NULL)
{
Status = AnsiToUnicode(AdapterName,
AdapterNameW,
Len);
HbaHandle = HBA_OpenAdapterW(AdapterNameW);
FreeMemory(AdapterNameW);
}
return(HbaHandle);
}
void HBA_API HBA_CloseAdapter(
HBA_HANDLE HbaHandle
)
{
PADAPTER_HANDLE HandleData;
HandleData = GetDataByHandle(HbaHandle);
if (HandleData != NULL)
{
EnterCritSection();
RemoveEntryList(&HandleData->List);
LeaveCritSection();
FreeMemory(HandleData->InstanceName);
FreeMemory(HandleData);
}
}
#if DBG
ULONG HbaapiDebugSpew = 1;
VOID
HbaapiDebugPrint(
PCHAR DebugMessage,
...
)
/*++
Routine Description:
Debug print for properties pages - stolen from classpnp\class.c
Arguments:
Debug print level between 0 and 3, with 3 being the most verbose.
Return Value:
None
--*/
{
CHAR SpewBuffer[DEBUG_BUFFER_LENGTH];
va_list ap;
va_start(ap, DebugMessage);
if (HbaapiDebugSpew)
{
_vsnprintf(SpewBuffer, DEBUG_BUFFER_LENGTH, DebugMessage, ap);
OutputDebugStringA(SpewBuffer);
}
va_end(ap);
} // end WmiDebugPrint()
#endif