//+--------------------------------------------------------------------------- // // Microsoft Windows // Copyright (C) Microsoft Corporation, 1997. // // File: K K E N E T . C P P // // Contents: Ethernet address function // // Notes: // // Author: kumarp // //---------------------------------------------------------------------------- #include "pch.h" #pragma hdrstop #include "kkutils.h" #include "ndispnp.h" #include "ntddndis.h" // This defines the IOCTL constants. extern const WCHAR c_szDevice[]; HRESULT HrGetNetCardAddr(IN PCWSTR pszDriver, OUT ULONGLONG* pqwNetCardAddr) { AssertValidReadPtr(pszDriver); AssertValidWritePtr(pqwNetCardAddr); DefineFunctionName("HrGetNetCardAddr"); HRESULT hr = S_OK; // Form the device name in form "\Device\{GUID}" tstring strDeviceName = c_szDevice; strDeviceName.append(pszDriver); UNICODE_STRING ustrDevice; ::RtlInitUnicodeString(&ustrDevice, strDeviceName.c_str()); UINT uiRet; UCHAR MacAddr[6]; UCHAR PMacAddr[6]; UCHAR VendorId[3]; ULONGLONG qw = 0; uiRet = NdisQueryHwAddress(&ustrDevice, MacAddr, PMacAddr, VendorId); if (uiRet) { for (int i=0; i<=4; i++) { qw |= MacAddr[i]; qw <<= 8; } qw |= MacAddr[i]; } else { hr = HrFromLastWin32Error(); } *pqwNetCardAddr = qw; TraceError(__FUNCNAME__, hr); return hr; } //+--------------------------------------------------------------------------- // // Function: HrGetNetCardAddrOld // // Purpose: Get mac address of a netcard without using NdisQueryHwAddress // // Arguments: // pszDriver [in] name (on NT3.51/4) or guid (on NT5) of driver // pqwNetCardAddr [out] pointer to result // // Returns: S_OK on success, otherwise an error code // // Author: kumarp 11-February-99 // // Notes: // #define DEVICE_PREFIX L"\\\\.\\" HRESULT HrGetNetCardAddrOld(IN PCWSTR pszDriver, OUT ULONGLONG* pqwNetCardAddr) { DefineFunctionName("HrGetNetCardAddrOld"); AssertValidReadPtr(pszDriver); *pqwNetCardAddr = 0; WCHAR LinkName[512]; WCHAR DeviceName[80]; WCHAR szMACFileName[80]; WCHAR OidData[4096]; BOOL fCreatedDevice = FALSE; DWORD ReturnedCount; HANDLE hMAC; HRESULT hr = S_OK; NDIS_OID OidCode[] = { OID_802_3_PERMANENT_ADDRESS, // Ethernet OID_802_5_PERMANENT_ADDRESS, // TokenRing OID_FDDI_LONG_PERMANENT_ADDR, // FDDI }; // // Check to see if the DOS name for the MAC driver already exists. // Its not created automatically in version 3.1 but may be later. // TraceTag (ttidDefault, "Attempting to get address of %S", pszDriver); if (QueryDosDevice(pszDriver, LinkName, celems(LinkName)) == 0) { if (ERROR_FILE_NOT_FOUND == GetLastError()) { wcscpy(DeviceName, L"\\Device\\"); wcscat(DeviceName, pszDriver); // // It doesn't exist so create it. // if (DefineDosDevice( DDD_RAW_TARGET_PATH, pszDriver, DeviceName)) { fCreatedDevice = TRUE; } else { TraceLastWin32Error("DefineDosDevice returned an error creating the device"); hr = HrFromLastWin32Error(); } } else { TraceLastWin32Error("QueryDosDevice returned an error"); hr = HrFromLastWin32Error(); } } if (S_OK == hr) { // // Construct a device name to pass to CreateFile // wcscpy(szMACFileName, DEVICE_PREFIX); wcscat(szMACFileName, pszDriver); hMAC = CreateFile( szMACFileName, GENERIC_READ, FILE_SHARE_READ | FILE_SHARE_WRITE, NULL, OPEN_EXISTING, 0, INVALID_HANDLE_VALUE ); if (hMAC != INVALID_HANDLE_VALUE) { DWORD count = 0; DWORD ReturnedCount = 0; // // We successfully opened the driver, format the IOCTL to pass the // driver. // while ((0 == ReturnedCount) && (count < celems (OidCode))) { if (DeviceIoControl( hMAC, IOCTL_NDIS_QUERY_GLOBAL_STATS, &OidCode[count], sizeof(OidCode[count]), OidData, sizeof(OidData), &ReturnedCount, NULL )) { TraceTag (ttidDefault, "OID %lX succeeded", OidCode[count]); if (ReturnedCount == 6) { *pqwNetCardAddr = (ULONGLONG) 0; WORD wAddrLen=6; for (int i=0; i