Commit 9f16ac9a authored by Huw Davies's avatar Huw Davies Committed by Alexandre Julliard

iphlpapi: Implement GetInterfaceInfo() on top of GetIfTable().

Eventually this should be implemented using NSI. This is an intermediate step to keep the interface names in sync. Signed-off-by: 's avatarHuw Davies <huw@codeweavers.com> Signed-off-by: 's avatarAlexandre Julliard <julliard@winehq.org>
parent ecce6909
...@@ -2060,65 +2060,33 @@ DWORD WINAPI GetIfTable2( MIB_IF_TABLE2 **table ) ...@@ -2060,65 +2060,33 @@ DWORD WINAPI GetIfTable2( MIB_IF_TABLE2 **table )
* BUGS * BUGS
* MSDN states this should return non-loopback interfaces only. * MSDN states this should return non-loopback interfaces only.
*/ */
DWORD WINAPI GetInterfaceInfo(PIP_INTERFACE_INFO pIfTable, PULONG dwOutBufLen) DWORD WINAPI GetInterfaceInfo( IP_INTERFACE_INFO *table, ULONG *size )
{ {
DWORD ret; MIB_IFTABLE *if_table;
DWORD err, needed, i;
TRACE("pIfTable %p, dwOutBufLen %p\n", pIfTable, dwOutBufLen); TRACE("table %p, size %p\n", table, size );
if (!dwOutBufLen) if (!size) return ERROR_INVALID_PARAMETER;
ret = ERROR_INVALID_PARAMETER;
else {
DWORD numInterfaces = get_interface_indices( FALSE, NULL );
ULONG size = sizeof(IP_INTERFACE_INFO);
if (numInterfaces > 1) err = AllocateAndGetIfTableFromStack( &if_table, 0, GetProcessHeap(), 0 );
size += (numInterfaces - 1) * sizeof(IP_ADAPTER_INDEX_MAP); if (err) return err;
if (!pIfTable || *dwOutBufLen < size) {
*dwOutBufLen = size;
ret = ERROR_INSUFFICIENT_BUFFER;
}
else {
InterfaceIndexTable *table;
get_interface_indices( FALSE, &table );
if (table) { needed = FIELD_OFFSET(IP_INTERFACE_INFO, Adapter[if_table->dwNumEntries]);
size = sizeof(IP_INTERFACE_INFO); if (!table || *size < needed)
if (table->numIndexes > 1) {
size += (table->numIndexes - 1) * sizeof(IP_ADAPTER_INDEX_MAP); *size = needed;
if (*dwOutBufLen < size) { heap_free( if_table );
*dwOutBufLen = size; return ERROR_INSUFFICIENT_BUFFER;
ret = ERROR_INSUFFICIENT_BUFFER; }
}
else {
DWORD ndx;
char nameBuf[MAX_ADAPTER_NAME];
*dwOutBufLen = size; table->NumAdapters = if_table->dwNumEntries;
pIfTable->NumAdapters = 0; for (i = 0; i < if_table->dwNumEntries; i++)
for (ndx = 0; ndx < table->numIndexes; ndx++) { {
const char *walker, *name; table->Adapter[i].Index = if_table->table[i].dwIndex;
WCHAR *assigner; strcpyW( table->Adapter[i].Name, if_table->table[i].wszName );
pIfTable->Adapter[ndx].Index = table->indexes[ndx];
name = getInterfaceNameByIndex(table->indexes[ndx], nameBuf);
for (walker = name, assigner = pIfTable->Adapter[ndx].Name;
walker && *walker &&
assigner - pIfTable->Adapter[ndx].Name < MAX_ADAPTER_NAME - 1;
walker++, assigner++)
*assigner = *walker;
*assigner = 0;
pIfTable->NumAdapters++;
}
ret = NO_ERROR;
}
HeapFree(GetProcessHeap(), 0, table);
}
else
ret = ERROR_OUTOFMEMORY;
} }
} heap_free( if_table );
TRACE("returning %d\n", ret); return ERROR_SUCCESS;
return ret;
} }
......
...@@ -1040,7 +1040,7 @@ static void testWinNT4Functions(void) ...@@ -1040,7 +1040,7 @@ static void testWinNT4Functions(void)
static void testGetInterfaceInfo(void) static void testGetInterfaceInfo(void)
{ {
DWORD apiReturn; DWORD apiReturn;
ULONG len = 0; ULONG len = 0, i;
apiReturn = GetInterfaceInfo(NULL, NULL); apiReturn = GetInterfaceInfo(NULL, NULL);
if (apiReturn == ERROR_NOT_SUPPORTED) { if (apiReturn == ERROR_NOT_SUPPORTED) {
...@@ -1061,6 +1061,16 @@ static void testGetInterfaceInfo(void) ...@@ -1061,6 +1061,16 @@ static void testGetInterfaceInfo(void)
ok(apiReturn == NO_ERROR, ok(apiReturn == NO_ERROR,
"GetInterfaceInfo(buf, &dwSize) returned %d, expected NO_ERROR\n", "GetInterfaceInfo(buf, &dwSize) returned %d, expected NO_ERROR\n",
apiReturn); apiReturn);
for (i = 0; i < buf->NumAdapters; i++)
{
MIB_IFROW row = { .dwIndex = buf->Adapter[i].Index };
GetIfEntry( &row );
ok( !wcscmp( buf->Adapter[i].Name, row.wszName ), "got %s vs %s\n",
debugstr_w( buf->Adapter[i].Name ), debugstr_w( row.wszName ) );
todo_wine_if( row.dwType == IF_TYPE_SOFTWARE_LOOPBACK)
ok( row.dwType != IF_TYPE_SOFTWARE_LOOPBACK, "got loopback\n" );
}
HeapFree(GetProcessHeap(), 0, buf); HeapFree(GetProcessHeap(), 0, buf);
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment