This function returns the software-configurable network address that was stored in the registry for an NIC when it was installed in the machine.
Header file: | Ndis.h |
Windows CE versions: | 2.0 and later |
VOID NdisReadNetworkAddress( OUT PNDIS_STATUS Status,
OUT PVOID *NetworkAddress, OUT PUINT NetworkAddressLength,
IN NDIS_HANDLE ConfigurationHandle );
For PC Card NICs, if no network address was specified in the registry, NDIS reads the network address from the card’s attribute space and stores it in the registry.
This function searches the registry Parameters key designated by the specifiedd ConfigurationHandle for the keyword NetworkAddress, converts the value of this string-type entry into a sequence of byte integers, and stores the requested information internally. The storage that NDIS allocates for such an address remains valid until the NIC driver calls NdisCloseConfiguration, which frees the memory.
The caller cannot use the variable at NetworkAddress as a pointer unless this function returns NDIS_STATUS_SUCCESS at Status.
The installation program for an NIC that supports software-configurable network addressing stores a value entry named with the NetworkAddress keyword in the appropriate XXX\DriverName\Parameters key of the registry.
An NIC installer usually stores the value of a NetworkAddress entry in the registry as a string of hexadecimal digits. Optionally, an installer can store such an address as a string of paired digits, with each pair separated from the next by a hyphen. This function discards hyphens and converts each such pair into a single byte.
In either form, this function converts the address specified as a string, one character at a time, into the equivalent integer until the string is exhausted.
In the Windows CE registry, such an installed address string contains Unicode characters.
A driver that calls this function runs at IRQL PASSIVE_LEVEL.
NdisCloseConfiguration, NdisOpenConfiguration