mirror of
https://github.com/reactos/reactos.git
synced 2025-01-07 06:45:24 +00:00
[IPHLPAPI]
- Fix a massive memory leak of our entire TDI entity ID database after each call to getInterfaceInfoSet - Fix another massive leak of our entire TDI interface table after each call to getInterfaceInfoByIndex and getInterfaceInfoByName - Fix some uninitialized variable warnings - Explorer no longer leaks horrendous amounts of memory (about 1 MB per minute even without network activity) when the network status icon is in the system tray svn path=/trunk/; revision=53190
This commit is contained in:
parent
2218bdc6ab
commit
85e01470a4
1 changed files with 16 additions and 8 deletions
|
@ -202,6 +202,8 @@ static NTSTATUS getInterfaceInfoSet( HANDLE tcpFile,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
tdiFreeThingSet(entIDSet);
|
||||||
|
|
||||||
if (NT_SUCCESS(status)) {
|
if (NT_SUCCESS(status)) {
|
||||||
*infoSet = infoSetInt;
|
*infoSet = infoSetInt;
|
||||||
*numInterfaces = curInterf;
|
*numInterfaces = curInterf;
|
||||||
|
@ -285,12 +287,12 @@ DWORD getNthInterfaceEntity( HANDLE tcpFile, DWORD index, TDIEntityID *ent ) {
|
||||||
TRACE("Index %d is entity #%d - %04x:%08x\n", index, i,
|
TRACE("Index %d is entity #%d - %04x:%08x\n", index, i,
|
||||||
entitySet[i].tei_entity, entitySet[i].tei_instance );
|
entitySet[i].tei_entity, entitySet[i].tei_instance );
|
||||||
|
|
||||||
|
tdiFreeThingSet( entitySet );
|
||||||
|
|
||||||
if( numInterfaces == index && i < numEntities ) {
|
if( numInterfaces == index && i < numEntities ) {
|
||||||
memcpy( ent, &entitySet[i], sizeof(*ent) );
|
memcpy( ent, &entitySet[i], sizeof(*ent) );
|
||||||
tdiFreeThingSet( entitySet );
|
|
||||||
return STATUS_SUCCESS;
|
return STATUS_SUCCESS;
|
||||||
} else {
|
} else {
|
||||||
tdiFreeThingSet( entitySet );
|
|
||||||
return STATUS_UNSUCCESSFUL;
|
return STATUS_UNSUCCESSFUL;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -302,6 +304,7 @@ NTSTATUS getInterfaceInfoByIndex( HANDLE tcpFile, DWORD index, IFInfo *info ) {
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if( NT_SUCCESS(status) )
|
if( NT_SUCCESS(status) )
|
||||||
|
{
|
||||||
for( i = 0; i < numInterfaces; i++ ) {
|
for( i = 0; i < numInterfaces; i++ ) {
|
||||||
if( ifInfo[i].if_info.ent.if_index == index ) {
|
if( ifInfo[i].if_info.ent.if_index == index ) {
|
||||||
memcpy( info, &ifInfo[i], sizeof(*info) );
|
memcpy( info, &ifInfo[i], sizeof(*info) );
|
||||||
|
@ -309,10 +312,12 @@ NTSTATUS getInterfaceInfoByIndex( HANDLE tcpFile, DWORD index, IFInfo *info ) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if( NT_SUCCESS(status) )
|
HeapFree(GetProcessHeap(), 0, ifInfo);
|
||||||
|
|
||||||
return i < numInterfaces ? STATUS_SUCCESS : STATUS_UNSUCCESSFUL;
|
return i < numInterfaces ? STATUS_SUCCESS : STATUS_UNSUCCESSFUL;
|
||||||
else
|
}
|
||||||
return status;
|
|
||||||
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
NTSTATUS getInterfaceInfoByName( HANDLE tcpFile, char *name, IFInfo *info ) {
|
NTSTATUS getInterfaceInfoByName( HANDLE tcpFile, char *name, IFInfo *info ) {
|
||||||
|
@ -322,6 +327,7 @@ NTSTATUS getInterfaceInfoByName( HANDLE tcpFile, char *name, IFInfo *info ) {
|
||||||
NTSTATUS status = getInterfaceInfoSet( tcpFile, &ifInfo, &numInterfaces );
|
NTSTATUS status = getInterfaceInfoSet( tcpFile, &ifInfo, &numInterfaces );
|
||||||
|
|
||||||
if( NT_SUCCESS(status) )
|
if( NT_SUCCESS(status) )
|
||||||
|
{
|
||||||
for( i = 0; i < numInterfaces; i++ ) {
|
for( i = 0; i < numInterfaces; i++ ) {
|
||||||
if( !strcmp((PCHAR)ifInfo[i].if_info.ent.if_descr, name) ) {
|
if( !strcmp((PCHAR)ifInfo[i].if_info.ent.if_descr, name) ) {
|
||||||
memcpy( info, &ifInfo[i], sizeof(*info) );
|
memcpy( info, &ifInfo[i], sizeof(*info) );
|
||||||
|
@ -329,10 +335,12 @@ NTSTATUS getInterfaceInfoByName( HANDLE tcpFile, char *name, IFInfo *info ) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if( NT_SUCCESS(status) )
|
HeapFree(GetProcessHeap(), 0,ifInfo);
|
||||||
|
|
||||||
return i < numInterfaces ? STATUS_SUCCESS : STATUS_UNSUCCESSFUL;
|
return i < numInterfaces ? STATUS_SUCCESS : STATUS_UNSUCCESSFUL;
|
||||||
else
|
}
|
||||||
return status;
|
|
||||||
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Note that the result of this operation must be freed later */
|
/* Note that the result of this operation must be freed later */
|
||||||
|
|
Loading…
Reference in a new issue