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
19a79f42
Commit
19a79f42
authored
May 07, 2017
by
Alex Henrie
Committed by
Alexandre Julliard
May 09, 2017
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ntdll: Implement ProcessVmCounters for Linux for other processes.
Signed-off-by:
Alex Henrie
<
alexhenrie24@gmail.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
47fca41f
Hide whitespace changes
Inline
Side-by-side
Showing
7 changed files
with
141 additions
and
4 deletions
+141
-4
process.c
dlls/ntdll/process.c
+17
-3
info.c
dlls/ntdll/tests/info.c
+22
-0
server_protocol.h
include/wine/server_protocol.h
+22
-1
process.c
server/process.c
+38
-0
protocol.def
server/protocol.def
+13
-0
request.h
server/request.h
+11
-0
trace.c
server/trace.c
+18
-0
No files found.
dlls/ntdll/process.c
View file @
19a79f42
...
@@ -294,15 +294,29 @@ NTSTATUS WINAPI NtQueryInformationProcess(
...
@@ -294,15 +294,29 @@ NTSTATUS WINAPI NtQueryInformationProcess(
{
{
if
(
!
ProcessInformation
)
if
(
!
ProcessInformation
)
ret
=
STATUS_ACCESS_VIOLATION
;
ret
=
STATUS_ACCESS_VIOLATION
;
else
if
(
!
ProcessHandle
)
ret
=
STATUS_INVALID_HANDLE
;
else
else
{
{
memset
(
&
pvmi
,
0
,
sizeof
(
VM_COUNTERS
));
memset
(
&
pvmi
,
0
,
sizeof
(
VM_COUNTERS
));
if
(
ProcessHandle
==
GetCurrentProcess
())
if
(
ProcessHandle
==
GetCurrentProcess
())
fill_VM_COUNTERS
(
&
pvmi
);
fill_VM_COUNTERS
(
&
pvmi
);
else
else
FIXME
(
"Need wineserver call to get VM counters for another process
\n
"
);
{
SERVER_START_REQ
(
get_process_vm_counters
)
{
req
->
handle
=
wine_server_obj_handle
(
ProcessHandle
);
if
(
!
(
ret
=
wine_server_call
(
req
)))
{
pvmi
.
PeakVirtualSize
=
reply
->
peak_virtual_size
;
pvmi
.
VirtualSize
=
reply
->
virtual_size
;
pvmi
.
PeakWorkingSetSize
=
reply
->
peak_working_set_size
;
pvmi
.
WorkingSetSize
=
reply
->
working_set_size
;
pvmi
.
PagefileUsage
=
reply
->
pagefile_usage
;
pvmi
.
PeakPagefileUsage
=
reply
->
peak_pagefile_usage
;
}
}
SERVER_END_REQ
;
if
(
ret
)
break
;
}
len
=
ProcessInformationLength
;
len
=
ProcessInformationLength
;
if
(
len
!=
FIELD_OFFSET
(
VM_COUNTERS
,
PrivatePageCount
))
len
=
sizeof
(
VM_COUNTERS
);
if
(
len
!=
FIELD_OFFSET
(
VM_COUNTERS
,
PrivatePageCount
))
len
=
sizeof
(
VM_COUNTERS
);
...
...
dlls/ntdll/tests/info.c
View file @
19a79f42
...
@@ -1052,6 +1052,7 @@ static void test_query_process_vm(void)
...
@@ -1052,6 +1052,7 @@ static void test_query_process_vm(void)
ULONG
ReturnLength
;
ULONG
ReturnLength
;
VM_COUNTERS
pvi
;
VM_COUNTERS
pvi
;
ULONG
old_size
=
FIELD_OFFSET
(
VM_COUNTERS
,
PrivatePageCount
);
ULONG
old_size
=
FIELD_OFFSET
(
VM_COUNTERS
,
PrivatePageCount
);
HANDLE
process
;
status
=
pNtQueryInformationProcess
(
NULL
,
ProcessVmCounters
,
NULL
,
sizeof
(
pvi
),
NULL
);
status
=
pNtQueryInformationProcess
(
NULL
,
ProcessVmCounters
,
NULL
,
sizeof
(
pvi
),
NULL
);
ok
(
status
==
STATUS_ACCESS_VIOLATION
||
status
==
STATUS_INVALID_HANDLE
,
ok
(
status
==
STATUS_ACCESS_VIOLATION
||
status
==
STATUS_INVALID_HANDLE
,
...
@@ -1079,6 +1080,27 @@ static void test_query_process_vm(void)
...
@@ -1079,6 +1080,27 @@ static void test_query_process_vm(void)
/* Check if we have some return values */
/* Check if we have some return values */
trace
(
"WorkingSetSize : %ld
\n
"
,
pvi
.
WorkingSetSize
);
trace
(
"WorkingSetSize : %ld
\n
"
,
pvi
.
WorkingSetSize
);
ok
(
pvi
.
WorkingSetSize
>
0
,
"Expected a WorkingSetSize > 0
\n
"
);
ok
(
pvi
.
WorkingSetSize
>
0
,
"Expected a WorkingSetSize > 0
\n
"
);
process
=
OpenProcess
(
PROCESS_VM_READ
,
FALSE
,
GetCurrentProcessId
());
status
=
pNtQueryInformationProcess
(
process
,
ProcessVmCounters
,
&
pvi
,
sizeof
(
pvi
),
NULL
);
ok
(
status
==
STATUS_ACCESS_DENIED
,
"Expected STATUS_ACCESS_DENIED, got %08x
\n
"
,
status
);
CloseHandle
(
process
);
process
=
OpenProcess
(
PROCESS_QUERY_LIMITED_INFORMATION
,
FALSE
,
GetCurrentProcessId
());
status
=
pNtQueryInformationProcess
(
process
,
ProcessVmCounters
,
&
pvi
,
sizeof
(
pvi
),
NULL
);
ok
(
status
==
STATUS_SUCCESS
||
broken
(
!
process
)
/* XP */
,
"Expected STATUS_SUCCESS, got %08x
\n
"
,
status
);
CloseHandle
(
process
);
memset
(
&
pvi
,
0
,
sizeof
(
pvi
));
process
=
OpenProcess
(
PROCESS_QUERY_INFORMATION
,
FALSE
,
GetCurrentProcessId
());
status
=
pNtQueryInformationProcess
(
process
,
ProcessVmCounters
,
&
pvi
,
sizeof
(
pvi
),
NULL
);
ok
(
status
==
STATUS_SUCCESS
,
"Expected STATUS_SUCCESS, got %08x
\n
"
,
status
);
/* Check if we have some return values */
trace
(
"WorkingSetSize : %ld
\n
"
,
pvi
.
WorkingSetSize
);
ok
(
pvi
.
WorkingSetSize
>
0
,
"Expected a WorkingSetSize > 0
\n
"
);
CloseHandle
(
process
);
}
}
static
void
test_query_process_io
(
void
)
static
void
test_query_process_io
(
void
)
...
...
include/wine/server_protocol.h
View file @
19a79f42
...
@@ -885,6 +885,24 @@ struct get_process_info_reply
...
@@ -885,6 +885,24 @@ struct get_process_info_reply
struct
get_process_vm_counters_request
{
struct
request_header
__header
;
obj_handle_t
handle
;
};
struct
get_process_vm_counters_reply
{
struct
reply_header
__header
;
mem_size_t
peak_virtual_size
;
mem_size_t
virtual_size
;
mem_size_t
peak_working_set_size
;
mem_size_t
working_set_size
;
mem_size_t
pagefile_usage
;
mem_size_t
peak_pagefile_usage
;
};
struct
set_process_info_request
struct
set_process_info_request
{
{
struct
request_header
__header
;
struct
request_header
__header
;
...
@@ -5541,6 +5559,7 @@ enum request
...
@@ -5541,6 +5559,7 @@ enum request
REQ_terminate_process
,
REQ_terminate_process
,
REQ_terminate_thread
,
REQ_terminate_thread
,
REQ_get_process_info
,
REQ_get_process_info
,
REQ_get_process_vm_counters
,
REQ_set_process_info
,
REQ_set_process_info
,
REQ_get_thread_info
,
REQ_get_thread_info
,
REQ_get_thread_times
,
REQ_get_thread_times
,
...
@@ -5831,6 +5850,7 @@ union generic_request
...
@@ -5831,6 +5850,7 @@ union generic_request
struct
terminate_process_request
terminate_process_request
;
struct
terminate_process_request
terminate_process_request
;
struct
terminate_thread_request
terminate_thread_request
;
struct
terminate_thread_request
terminate_thread_request
;
struct
get_process_info_request
get_process_info_request
;
struct
get_process_info_request
get_process_info_request
;
struct
get_process_vm_counters_request
get_process_vm_counters_request
;
struct
set_process_info_request
set_process_info_request
;
struct
set_process_info_request
set_process_info_request
;
struct
get_thread_info_request
get_thread_info_request
;
struct
get_thread_info_request
get_thread_info_request
;
struct
get_thread_times_request
get_thread_times_request
;
struct
get_thread_times_request
get_thread_times_request
;
...
@@ -6119,6 +6139,7 @@ union generic_reply
...
@@ -6119,6 +6139,7 @@ union generic_reply
struct
terminate_process_reply
terminate_process_reply
;
struct
terminate_process_reply
terminate_process_reply
;
struct
terminate_thread_reply
terminate_thread_reply
;
struct
terminate_thread_reply
terminate_thread_reply
;
struct
get_process_info_reply
get_process_info_reply
;
struct
get_process_info_reply
get_process_info_reply
;
struct
get_process_vm_counters_reply
get_process_vm_counters_reply
;
struct
set_process_info_reply
set_process_info_reply
;
struct
set_process_info_reply
set_process_info_reply
;
struct
get_thread_info_reply
get_thread_info_reply
;
struct
get_thread_info_reply
get_thread_info_reply
;
struct
get_thread_times_reply
get_thread_times_reply
;
struct
get_thread_times_reply
get_thread_times_reply
;
...
@@ -6395,6 +6416,6 @@ union generic_reply
...
@@ -6395,6 +6416,6 @@ union generic_reply
struct
terminate_job_reply
terminate_job_reply
;
struct
terminate_job_reply
terminate_job_reply
;
};
};
#define SERVER_PROTOCOL_VERSION 53
0
#define SERVER_PROTOCOL_VERSION 53
1
#endif
/* __WINE_WINE_SERVER_PROTOCOL_H */
#endif
/* __WINE_WINE_SERVER_PROTOCOL_H */
server/process.c
View file @
19a79f42
...
@@ -1371,6 +1371,44 @@ DECL_HANDLER(get_process_info)
...
@@ -1371,6 +1371,44 @@ DECL_HANDLER(get_process_info)
}
}
}
}
/* retrieve information about a process memory usage */
DECL_HANDLER
(
get_process_vm_counters
)
{
struct
process
*
process
=
get_process_from_handle
(
req
->
handle
,
PROCESS_QUERY_LIMITED_INFORMATION
);
if
(
!
process
)
return
;
#ifdef linux
if
(
process
->
unix_pid
!=
-
1
)
{
FILE
*
f
;
char
proc_path
[
32
],
line
[
256
];
unsigned
long
value
;
sprintf
(
proc_path
,
"/proc/%u/status"
,
process
->
unix_pid
);
if
((
f
=
fopen
(
proc_path
,
"r"
)))
{
while
(
fgets
(
line
,
sizeof
(
line
),
f
))
{
if
(
sscanf
(
line
,
"VmPeak: %lu"
,
&
value
))
reply
->
peak_virtual_size
=
(
mem_size_t
)
value
*
1024
;
else
if
(
sscanf
(
line
,
"VmSize: %lu"
,
&
value
))
reply
->
virtual_size
=
(
mem_size_t
)
value
*
1024
;
else
if
(
sscanf
(
line
,
"VmHWM: %lu"
,
&
value
))
reply
->
peak_working_set_size
=
(
mem_size_t
)
value
*
1024
;
else
if
(
sscanf
(
line
,
"VmRSS: %lu"
,
&
value
))
reply
->
working_set_size
=
(
mem_size_t
)
value
*
1024
;
else
if
(
sscanf
(
line
,
"VmSwap: %lu"
,
&
value
))
reply
->
peak_pagefile_usage
=
reply
->
pagefile_usage
=
(
mem_size_t
)
value
*
1024
;
}
fclose
(
f
);
}
else
set_error
(
STATUS_ACCESS_DENIED
);
}
else
set_error
(
STATUS_ACCESS_DENIED
);
#endif
release_object
(
process
);
}
static
void
set_process_affinity
(
struct
process
*
process
,
affinity_t
affinity
)
static
void
set_process_affinity
(
struct
process
*
process
,
affinity_t
affinity
)
{
{
struct
thread
*
thread
;
struct
thread
*
thread
;
...
...
server/protocol.def
View file @
19a79f42
...
@@ -845,6 +845,19 @@ struct rawinput_device
...
@@ -845,6 +845,19 @@ struct rawinput_device
@END
@END
/* Retrieve information about a process memory usage */
@REQ(get_process_vm_counters)
obj_handle_t handle; /* process handle */
@REPLY
mem_size_t peak_virtual_size; /* peak virtual memory in bytes */
mem_size_t virtual_size; /* virtual memory in bytes */
mem_size_t peak_working_set_size; /* peak real memory in bytes */
mem_size_t working_set_size; /* real memory in bytes */
mem_size_t pagefile_usage; /* swapped-out memory in bytes */
mem_size_t peak_pagefile_usage; /* peak swapped-out memory in bytes */
@END
/* Set a process information */
/* Set a process information */
@REQ(set_process_info)
@REQ(set_process_info)
obj_handle_t handle; /* process handle */
obj_handle_t handle; /* process handle */
...
...
server/request.h
View file @
19a79f42
...
@@ -121,6 +121,7 @@ DECL_HANDLER(init_thread);
...
@@ -121,6 +121,7 @@ DECL_HANDLER(init_thread);
DECL_HANDLER
(
terminate_process
);
DECL_HANDLER
(
terminate_process
);
DECL_HANDLER
(
terminate_thread
);
DECL_HANDLER
(
terminate_thread
);
DECL_HANDLER
(
get_process_info
);
DECL_HANDLER
(
get_process_info
);
DECL_HANDLER
(
get_process_vm_counters
);
DECL_HANDLER
(
set_process_info
);
DECL_HANDLER
(
set_process_info
);
DECL_HANDLER
(
get_thread_info
);
DECL_HANDLER
(
get_thread_info
);
DECL_HANDLER
(
get_thread_times
);
DECL_HANDLER
(
get_thread_times
);
...
@@ -410,6 +411,7 @@ static const req_handler req_handlers[REQ_NB_REQUESTS] =
...
@@ -410,6 +411,7 @@ static const req_handler req_handlers[REQ_NB_REQUESTS] =
(
req_handler
)
req_terminate_process
,
(
req_handler
)
req_terminate_process
,
(
req_handler
)
req_terminate_thread
,
(
req_handler
)
req_terminate_thread
,
(
req_handler
)
req_get_process_info
,
(
req_handler
)
req_get_process_info
,
(
req_handler
)
req_get_process_vm_counters
,
(
req_handler
)
req_set_process_info
,
(
req_handler
)
req_set_process_info
,
(
req_handler
)
req_get_thread_info
,
(
req_handler
)
req_get_thread_info
,
(
req_handler
)
req_get_thread_times
,
(
req_handler
)
req_get_thread_times
,
...
@@ -796,6 +798,15 @@ C_ASSERT( FIELD_OFFSET(struct get_process_info_reply, cpu) == 56 );
...
@@ -796,6 +798,15 @@ C_ASSERT( FIELD_OFFSET(struct get_process_info_reply, cpu) == 56 );
C_ASSERT
(
FIELD_OFFSET
(
struct
get_process_info_reply
,
debugger_present
)
==
60
);
C_ASSERT
(
FIELD_OFFSET
(
struct
get_process_info_reply
,
debugger_present
)
==
60
);
C_ASSERT
(
FIELD_OFFSET
(
struct
get_process_info_reply
,
debug_children
)
==
62
);
C_ASSERT
(
FIELD_OFFSET
(
struct
get_process_info_reply
,
debug_children
)
==
62
);
C_ASSERT
(
sizeof
(
struct
get_process_info_reply
)
==
64
);
C_ASSERT
(
sizeof
(
struct
get_process_info_reply
)
==
64
);
C_ASSERT
(
FIELD_OFFSET
(
struct
get_process_vm_counters_request
,
handle
)
==
12
);
C_ASSERT
(
sizeof
(
struct
get_process_vm_counters_request
)
==
16
);
C_ASSERT
(
FIELD_OFFSET
(
struct
get_process_vm_counters_reply
,
peak_virtual_size
)
==
8
);
C_ASSERT
(
FIELD_OFFSET
(
struct
get_process_vm_counters_reply
,
virtual_size
)
==
16
);
C_ASSERT
(
FIELD_OFFSET
(
struct
get_process_vm_counters_reply
,
peak_working_set_size
)
==
24
);
C_ASSERT
(
FIELD_OFFSET
(
struct
get_process_vm_counters_reply
,
working_set_size
)
==
32
);
C_ASSERT
(
FIELD_OFFSET
(
struct
get_process_vm_counters_reply
,
pagefile_usage
)
==
40
);
C_ASSERT
(
FIELD_OFFSET
(
struct
get_process_vm_counters_reply
,
peak_pagefile_usage
)
==
48
);
C_ASSERT
(
sizeof
(
struct
get_process_vm_counters_reply
)
==
56
);
C_ASSERT
(
FIELD_OFFSET
(
struct
set_process_info_request
,
handle
)
==
12
);
C_ASSERT
(
FIELD_OFFSET
(
struct
set_process_info_request
,
handle
)
==
12
);
C_ASSERT
(
FIELD_OFFSET
(
struct
set_process_info_request
,
mask
)
==
16
);
C_ASSERT
(
FIELD_OFFSET
(
struct
set_process_info_request
,
mask
)
==
16
);
C_ASSERT
(
FIELD_OFFSET
(
struct
set_process_info_request
,
priority
)
==
20
);
C_ASSERT
(
FIELD_OFFSET
(
struct
set_process_info_request
,
priority
)
==
20
);
...
...
server/trace.c
View file @
19a79f42
...
@@ -1346,6 +1346,21 @@ static void dump_get_process_info_reply( const struct get_process_info_reply *re
...
@@ -1346,6 +1346,21 @@ static void dump_get_process_info_reply( const struct get_process_info_reply *re
fprintf
(
stderr
,
", debug_children=%d"
,
req
->
debug_children
);
fprintf
(
stderr
,
", debug_children=%d"
,
req
->
debug_children
);
}
}
static
void
dump_get_process_vm_counters_request
(
const
struct
get_process_vm_counters_request
*
req
)
{
fprintf
(
stderr
,
" handle=%04x"
,
req
->
handle
);
}
static
void
dump_get_process_vm_counters_reply
(
const
struct
get_process_vm_counters_reply
*
req
)
{
dump_uint64
(
" peak_virtual_size="
,
&
req
->
peak_virtual_size
);
dump_uint64
(
", virtual_size="
,
&
req
->
virtual_size
);
dump_uint64
(
", peak_working_set_size="
,
&
req
->
peak_working_set_size
);
dump_uint64
(
", working_set_size="
,
&
req
->
working_set_size
);
dump_uint64
(
", pagefile_usage="
,
&
req
->
pagefile_usage
);
dump_uint64
(
", peak_pagefile_usage="
,
&
req
->
peak_pagefile_usage
);
}
static
void
dump_set_process_info_request
(
const
struct
set_process_info_request
*
req
)
static
void
dump_set_process_info_request
(
const
struct
set_process_info_request
*
req
)
{
{
fprintf
(
stderr
,
" handle=%04x"
,
req
->
handle
);
fprintf
(
stderr
,
" handle=%04x"
,
req
->
handle
);
...
@@ -4457,6 +4472,7 @@ static const dump_func req_dumpers[REQ_NB_REQUESTS] = {
...
@@ -4457,6 +4472,7 @@ static const dump_func req_dumpers[REQ_NB_REQUESTS] = {
(
dump_func
)
dump_terminate_process_request
,
(
dump_func
)
dump_terminate_process_request
,
(
dump_func
)
dump_terminate_thread_request
,
(
dump_func
)
dump_terminate_thread_request
,
(
dump_func
)
dump_get_process_info_request
,
(
dump_func
)
dump_get_process_info_request
,
(
dump_func
)
dump_get_process_vm_counters_request
,
(
dump_func
)
dump_set_process_info_request
,
(
dump_func
)
dump_set_process_info_request
,
(
dump_func
)
dump_get_thread_info_request
,
(
dump_func
)
dump_get_thread_info_request
,
(
dump_func
)
dump_get_thread_times_request
,
(
dump_func
)
dump_get_thread_times_request
,
...
@@ -4743,6 +4759,7 @@ static const dump_func reply_dumpers[REQ_NB_REQUESTS] = {
...
@@ -4743,6 +4759,7 @@ static const dump_func reply_dumpers[REQ_NB_REQUESTS] = {
(
dump_func
)
dump_terminate_process_reply
,
(
dump_func
)
dump_terminate_process_reply
,
(
dump_func
)
dump_terminate_thread_reply
,
(
dump_func
)
dump_terminate_thread_reply
,
(
dump_func
)
dump_get_process_info_reply
,
(
dump_func
)
dump_get_process_info_reply
,
(
dump_func
)
dump_get_process_vm_counters_reply
,
NULL
,
NULL
,
(
dump_func
)
dump_get_thread_info_reply
,
(
dump_func
)
dump_get_thread_info_reply
,
(
dump_func
)
dump_get_thread_times_reply
,
(
dump_func
)
dump_get_thread_times_reply
,
...
@@ -5029,6 +5046,7 @@ static const char * const req_names[REQ_NB_REQUESTS] = {
...
@@ -5029,6 +5046,7 @@ static const char * const req_names[REQ_NB_REQUESTS] = {
"terminate_process"
,
"terminate_process"
,
"terminate_thread"
,
"terminate_thread"
,
"get_process_info"
,
"get_process_info"
,
"get_process_vm_counters"
,
"set_process_info"
,
"set_process_info"
,
"get_thread_info"
,
"get_thread_info"
,
"get_thread_times"
,
"get_thread_times"
,
...
...
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