Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
d069e498
Commit
d069e498
authored
Mar 02, 2009
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
iphlpapi: Reimplement GetUdpTable to avoid parsing the same information three times.
parent
9b309b01
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
58 additions
and
79 deletions
+58
-79
iphlpapi_main.c
dlls/iphlpapi/iphlpapi_main.c
+5
-24
ipstats.c
dlls/iphlpapi/ipstats.c
+53
-55
No files found.
dlls/iphlpapi/iphlpapi_main.c
View file @
d069e498
...
...
@@ -1686,30 +1686,16 @@ DWORD WINAPI GetUdpStatistics(PMIB_UDPSTATS pStats)
DWORD
WINAPI
GetUdpTable
(
PMIB_UDPTABLE
pUdpTable
,
PDWORD
pdwSize
,
BOOL
bOrder
)
{
DWORD
ret
;
PMIB_UDPTABLE
table
;
TRACE
(
"pUdpTable %p, pdwSize %p, bOrder %d
\n
"
,
pUdpTable
,
pdwSize
,
(
DWORD
)
bOrder
);
if
(
!
pdwSize
)
ret
=
ERROR_INVALID_PARAMETER
;
else
{
DWORD
numEntries
=
getNumUdpEntries
();
DWORD
size
=
sizeof
(
MIB_UDPTABLE
);
TRACE
(
"pUdpTable %p, pdwSize %p, bOrder %d
\n
"
,
pUdpTable
,
pdwSize
,
bOrder
);
if
(
numEntries
>
1
)
size
+=
(
numEntries
-
1
)
*
sizeof
(
MIB_UDPROW
);
if
(
!
pUdpTable
||
*
pdwSize
<
size
)
{
*
pdwSize
=
size
;
ret
=
ERROR_INSUFFICIENT_BUFFER
;
}
else
{
PMIB_UDPTABLE
table
;
if
(
!
pdwSize
)
return
ERROR_INVALID_PARAMETER
;
ret
=
getUdpTable
(
&
table
,
GetProcessHeap
(),
0
);
if
(
!
ret
)
{
size
=
sizeof
(
MIB_UDPTABLE
);
if
(
table
->
dwNumEntries
>
1
)
size
+=
(
table
->
dwNumEntries
-
1
)
*
sizeof
(
MIB_UDPROW
);
if
(
*
pdwSize
<
size
)
{
DWORD
size
=
FIELD_OFFSET
(
MIB_UDPTABLE
,
table
[
table
->
dwNumEntries
]
);
if
(
!
pUdpTable
||
*
pdwSize
<
size
)
{
*
pdwSize
=
size
;
ret
=
ERROR_INSUFFICIENT_BUFFER
;
}
...
...
@@ -1719,14 +1705,9 @@ DWORD WINAPI GetUdpTable(PMIB_UDPTABLE pUdpTable, PDWORD pdwSize, BOOL bOrder)
if
(
bOrder
)
qsort
(
pUdpTable
->
table
,
pUdpTable
->
dwNumEntries
,
sizeof
(
MIB_UDPROW
),
UdpTableSorter
);
ret
=
NO_ERROR
;
}
HeapFree
(
GetProcessHeap
(),
0
,
table
);
}
else
ret
=
ERROR_OUTOFMEMORY
;
}
}
TRACE
(
"returning %d
\n
"
,
ret
);
return
ret
;
}
...
...
dlls/iphlpapi/ipstats.c
View file @
d069e498
/* Copyright (C) 2003,2006 Juan Lang
/*
* Copyright (C) 2003,2006 Juan Lang
* Copyright (C) 2007 TransGaming Technologies Inc.
* Copyright (C) 2009 Alexandre Julliard
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
...
...
@@ -14,9 +16,6 @@
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
*
* This file implements statistics getting using the /proc filesystem exported
* by Linux, and maybe other OSes.
*/
#include "config.h"
...
...
@@ -1480,71 +1479,70 @@ DWORD getNumUdpEntries(void)
#endif
}
static
MIB_UDPTABLE
*
append_udp_row
(
HANDLE
heap
,
DWORD
flags
,
MIB_UDPTABLE
*
table
,
DWORD
*
count
,
const
MIB_UDPROW
*
row
)
{
if
(
table
->
dwNumEntries
>=
*
count
)
{
MIB_UDPTABLE
*
new_table
;
DWORD
new_count
=
table
->
dwNumEntries
*
2
;
if
(
!
(
new_table
=
HeapReAlloc
(
heap
,
flags
,
table
,
FIELD_OFFSET
(
MIB_UDPTABLE
,
table
[
new_count
]
))))
{
HeapFree
(
heap
,
0
,
table
);
return
NULL
;
}
*
count
=
new_count
;
table
=
new_table
;
}
memcpy
(
&
table
->
table
[
table
->
dwNumEntries
++
],
row
,
sizeof
(
*
row
)
);
return
table
;
}
DWORD
getUdpTable
(
PMIB_UDPTABLE
*
ppUdpTable
,
HANDLE
heap
,
DWORD
flags
)
{
DWORD
ret
;
MIB_UDPTABLE
*
table
;
MIB_UDPROW
row
;
DWORD
ret
=
NO_ERROR
,
count
=
16
;
#if defined(HAVE_SYS_SYSCTL_H) && defined(NET_RT_DUMP)
ERR
(
"unimplemented!
\n
"
);
return
ERROR_NOT_SUPPORTED
;
#endif
if
(
!
ppUdpTable
)
return
ERROR_INVALID_PARAMETER
;
if
(
!
ppUdpTable
)
ret
=
ERROR_INVALID_PARAMETER
;
else
{
DWORD
numEntries
=
getNumUdpEntries
();
DWORD
size
=
sizeof
(
MIB_UDPTABLE
);
PMIB_UDPTABLE
table
;
if
(
!
(
table
=
HeapAlloc
(
heap
,
flags
,
FIELD_OFFSET
(
MIB_UDPTABLE
,
table
[
count
]
))))
return
ERROR_OUTOFMEMORY
;
if
(
numEntries
>
1
)
size
+=
(
numEntries
-
1
)
*
sizeof
(
MIB_UDPROW
);
table
=
HeapAlloc
(
heap
,
flags
,
size
);
if
(
table
)
{
table
->
dwNumEntries
=
0
;
#ifdef __linux__
{
FILE
*
fp
;
ret
=
NO_ERROR
;
*
ppUdpTable
=
table
;
table
->
dwNumEntries
=
0
;
/* get from /proc/net/udp, no error if can't */
fp
=
fopen
(
"/proc/net/udp"
,
"r"
);
if
(
fp
)
{
char
buf
[
512
]
=
{
0
},
*
ptr
;
if
((
fp
=
fopen
(
"/proc/net/udp"
,
"r"
)))
{
char
buf
[
512
],
*
ptr
;
DWORD
dummy
;
/* skip header line */
ptr
=
fgets
(
buf
,
sizeof
(
buf
),
fp
);
while
(
ptr
&&
table
->
dwNumEntries
<
numEntries
)
{
memset
(
&
table
->
table
[
table
->
dwNumEntries
],
0
,
sizeof
(
MIB_UDPROW
));
ptr
=
fgets
(
buf
,
sizeof
(
buf
),
fp
);
if
(
ptr
)
{
char
*
endPtr
;
if
(
ptr
&&
*
ptr
)
{
strtoul
(
ptr
,
&
endPtr
,
16
);
/* skip */
ptr
=
endPtr
;
}
if
(
ptr
&&
*
ptr
)
{
ptr
++
;
table
->
table
[
table
->
dwNumEntries
].
dwLocalAddr
=
strtoul
(
ptr
,
&
endPtr
,
16
);
ptr
=
endPtr
;
}
if
(
ptr
&&
*
ptr
)
{
ptr
++
;
table
->
table
[
table
->
dwNumEntries
].
dwLocalPort
=
strtoul
(
ptr
,
&
endPtr
,
16
);
ptr
=
endPtr
;
}
table
->
dwNumEntries
++
;
}
while
((
ptr
=
fgets
(
buf
,
sizeof
(
buf
),
fp
)))
{
if
(
sscanf
(
ptr
,
"%u: %x:%x"
,
&
dummy
,
&
row
.
dwLocalAddr
,
&
row
.
dwLocalPort
)
!=
3
)
continue
;
row
.
dwLocalPort
=
htons
(
row
.
dwLocalPort
);
if
(
!
(
table
=
append_udp_row
(
heap
,
flags
,
table
,
&
count
,
&
row
)))
break
;
}
fclose
(
fp
);
}
else
ret
=
ERROR_NOT_SUPPORTED
;
}
else
ret
=
ERROR_OUTOFMEMORY
;
else
ret
=
ERROR_NOT_SUPPORTED
;
}
#else
FIXME
(
"not implemented
\n
"
);
ret
=
ERROR_NOT_SUPPORTED
;
#endif
if
(
!
table
)
return
ERROR_OUTOFMEMORY
;
if
(
!
ret
)
*
ppUdpTable
=
table
;
else
HeapFree
(
heap
,
flags
,
table
);
return
ret
;
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment