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
772236fe
Commit
772236fe
authored
Jun 14, 2013
by
Hans Leidekker
Committed by
Alexandre Julliard
Jun 14, 2013
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wbemprox: Implement Win32_Processor.NumberOfCores.
parent
38e976ac
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
20 additions
and
6 deletions
+20
-6
builtin.c
dlls/wbemprox/builtin.c
+20
-6
No files found.
dlls/wbemprox/builtin.c
View file @
772236fe
...
@@ -168,6 +168,8 @@ static const WCHAR prop_modelW[] =
...
@@ -168,6 +168,8 @@ static const WCHAR prop_modelW[] =
{
'M'
,
'o'
,
'd'
,
'e'
,
'l'
,
0
};
{
'M'
,
'o'
,
'd'
,
'e'
,
'l'
,
0
};
static
const
WCHAR
prop_netconnectionstatusW
[]
=
static
const
WCHAR
prop_netconnectionstatusW
[]
=
{
'N'
,
'e'
,
't'
,
'C'
,
'o'
,
'n'
,
'n'
,
'e'
,
'c'
,
't'
,
'i'
,
'o'
,
'n'
,
'S'
,
't'
,
'a'
,
't'
,
'u'
,
's'
,
0
};
{
'N'
,
'e'
,
't'
,
'C'
,
'o'
,
'n'
,
'n'
,
'e'
,
'c'
,
't'
,
'i'
,
'o'
,
'n'
,
'S'
,
't'
,
'a'
,
't'
,
'u'
,
's'
,
0
};
static
const
WCHAR
prop_numcoresW
[]
=
{
'N'
,
'u'
,
'm'
,
'b'
,
'e'
,
'r'
,
'O'
,
'f'
,
'C'
,
'o'
,
'r'
,
'e'
,
's'
,
0
};
static
const
WCHAR
prop_numlogicalprocessorsW
[]
=
static
const
WCHAR
prop_numlogicalprocessorsW
[]
=
{
'N'
,
'u'
,
'm'
,
'b'
,
'e'
,
'r'
,
'O'
,
'f'
,
'L'
,
'o'
,
'g'
,
'i'
,
'c'
,
'a'
,
'l'
,
'P'
,
'r'
,
'o'
,
'c'
,
'e'
,
's'
,
's'
,
'o'
,
'r'
,
's'
,
0
};
{
'N'
,
'u'
,
'm'
,
'b'
,
'e'
,
'r'
,
'O'
,
'f'
,
'L'
,
'o'
,
'g'
,
'i'
,
'c'
,
'a'
,
'l'
,
'P'
,
'r'
,
'o'
,
'c'
,
'e'
,
's'
,
's'
,
'o'
,
'r'
,
's'
,
0
};
static
const
WCHAR
prop_numprocessorsW
[]
=
static
const
WCHAR
prop_numprocessorsW
[]
=
...
@@ -363,6 +365,7 @@ static const struct column col_processor[] =
...
@@ -363,6 +365,7 @@ static const struct column col_processor[] =
{
prop_manufacturerW
,
CIM_STRING
|
COL_FLAG_DYNAMIC
},
{
prop_manufacturerW
,
CIM_STRING
|
COL_FLAG_DYNAMIC
},
{
prop_maxclockspeedW
,
CIM_UINT32
,
VT_I4
},
{
prop_maxclockspeedW
,
CIM_UINT32
,
VT_I4
},
{
prop_nameW
,
CIM_STRING
|
COL_FLAG_DYNAMIC
},
{
prop_nameW
,
CIM_STRING
|
COL_FLAG_DYNAMIC
},
{
prop_numcoresW
,
CIM_UINT32
,
VT_I4
},
{
prop_numlogicalprocessorsW
,
CIM_UINT32
,
VT_I4
},
{
prop_numlogicalprocessorsW
,
CIM_UINT32
,
VT_I4
},
{
prop_processoridW
,
CIM_STRING
|
COL_FLAG_DYNAMIC
},
{
prop_processoridW
,
CIM_STRING
|
COL_FLAG_DYNAMIC
},
{
prop_uniqueidW
,
CIM_STRING
}
{
prop_uniqueidW
,
CIM_STRING
}
...
@@ -605,6 +608,7 @@ struct record_processor
...
@@ -605,6 +608,7 @@ struct record_processor
const
WCHAR
*
manufacturer
;
const
WCHAR
*
manufacturer
;
UINT32
maxclockspeed
;
UINT32
maxclockspeed
;
const
WCHAR
*
name
;
const
WCHAR
*
name
;
UINT32
num_cores
;
UINT32
num_logical_processors
;
UINT32
num_logical_processors
;
const
WCHAR
*
processor_id
;
const
WCHAR
*
processor_id
;
const
WCHAR
*
unique_id
;
const
WCHAR
*
unique_id
;
...
@@ -799,13 +803,14 @@ static UINT get_processor_count(void)
...
@@ -799,13 +803,14 @@ static UINT get_processor_count(void)
return
info
.
NumberOfProcessors
;
return
info
.
NumberOfProcessors
;
}
}
static
UINT
get_logical_processor_count
(
void
)
static
UINT
get_logical_processor_count
(
UINT
*
num_cores
)
{
{
SYSTEM_LOGICAL_PROCESSOR_INFORMATION
*
info
;
SYSTEM_LOGICAL_PROCESSOR_INFORMATION
*
info
;
UINT
i
,
j
,
count
=
0
;
UINT
i
,
j
,
count
=
0
;
NTSTATUS
status
;
NTSTATUS
status
;
ULONG
len
;
ULONG
len
;
if
(
num_cores
)
*
num_cores
=
get_processor_count
();
status
=
NtQuerySystemInformation
(
SystemLogicalProcessorInformation
,
NULL
,
0
,
&
len
);
status
=
NtQuerySystemInformation
(
SystemLogicalProcessorInformation
,
NULL
,
0
,
&
len
);
if
(
status
!=
STATUS_INFO_LENGTH_MISMATCH
)
return
get_processor_count
();
if
(
status
!=
STATUS_INFO_LENGTH_MISMATCH
)
return
get_processor_count
();
...
@@ -816,10 +821,17 @@ static UINT get_logical_processor_count(void)
...
@@ -816,10 +821,17 @@ static UINT get_logical_processor_count(void)
heap_free
(
info
);
heap_free
(
info
);
return
get_processor_count
();
return
get_processor_count
();
}
}
if
(
num_cores
)
*
num_cores
=
0
;
for
(
i
=
0
;
i
<
len
/
sizeof
(
*
info
);
i
++
)
for
(
i
=
0
;
i
<
len
/
sizeof
(
*
info
);
i
++
)
{
{
if
(
info
[
i
].
Relationship
!=
RelationProcessorCore
)
continue
;
if
(
info
[
i
].
Relationship
==
RelationProcessorCore
)
for
(
j
=
0
;
j
<
sizeof
(
ULONG_PTR
);
j
++
)
if
(
info
[
i
].
ProcessorMask
&
(
1
<<
j
))
count
++
;
{
for
(
j
=
0
;
j
<
sizeof
(
ULONG_PTR
);
j
++
)
if
(
info
[
i
].
ProcessorMask
&
(
1
<<
j
))
count
++
;
}
else
if
(
info
[
i
].
Relationship
==
RelationProcessorPackage
&&
num_cores
)
{
for
(
j
=
0
;
j
<
sizeof
(
ULONG_PTR
);
j
++
)
if
(
info
[
i
].
ProcessorMask
&
(
1
<<
j
))
(
*
num_cores
)
++
;
}
}
}
heap_free
(
info
);
heap_free
(
info
);
return
count
;
return
count
;
...
@@ -859,7 +871,7 @@ static enum fill_status fill_compsys( struct table *table, const struct expr *co
...
@@ -859,7 +871,7 @@ static enum fill_status fill_compsys( struct table *table, const struct expr *co
rec
->
manufacturer
=
compsys_manufacturerW
;
rec
->
manufacturer
=
compsys_manufacturerW
;
rec
->
model
=
compsys_modelW
;
rec
->
model
=
compsys_modelW
;
rec
->
name
=
get_computername
();
rec
->
name
=
get_computername
();
rec
->
num_logical_processors
=
get_logical_processor_count
();
rec
->
num_logical_processors
=
get_logical_processor_count
(
NULL
);
rec
->
num_processors
=
get_processor_count
();
rec
->
num_processors
=
get_processor_count
();
rec
->
total_physical_memory
=
get_total_physical_memory
();
rec
->
total_physical_memory
=
get_total_physical_memory
();
if
(
!
match_row
(
table
,
row
,
cond
,
&
status
))
free_row_values
(
table
,
row
);
if
(
!
match_row
(
table
,
row
,
cond
,
&
status
))
free_row_values
(
table
,
row
);
...
@@ -1672,7 +1684,7 @@ static enum fill_status fill_processor( struct table *table, const struct expr *
...
@@ -1672,7 +1684,7 @@ static enum fill_status fill_processor( struct table *table, const struct expr *
static
const
WCHAR
fmtW
[]
=
{
'C'
,
'P'
,
'U'
,
'%'
,
'u'
,
0
};
static
const
WCHAR
fmtW
[]
=
{
'C'
,
'P'
,
'U'
,
'%'
,
'u'
,
0
};
WCHAR
device_id
[
14
],
processor_id
[
17
],
manufacturer
[
13
],
name
[
49
]
=
{
0
};
WCHAR
device_id
[
14
],
processor_id
[
17
],
manufacturer
[
13
],
name
[
49
]
=
{
0
};
struct
record_processor
*
rec
;
struct
record_processor
*
rec
;
UINT
i
,
offset
=
0
,
maxclockspeed
,
num_logical_processors
,
count
=
get_processor_count
();
UINT
i
,
offset
=
0
,
maxclockspeed
,
num_
cores
,
num_
logical_processors
,
count
=
get_processor_count
();
enum
fill_status
status
=
FILL_STATUS_UNFILTERED
;
enum
fill_status
status
=
FILL_STATUS_UNFILTERED
;
if
(
!
resize_table
(
table
,
count
,
sizeof
(
*
rec
)
))
return
FILL_STATUS_FAILED
;
if
(
!
resize_table
(
table
,
count
,
sizeof
(
*
rec
)
))
return
FILL_STATUS_FAILED
;
...
@@ -1682,7 +1694,8 @@ static enum fill_status fill_processor( struct table *table, const struct expr *
...
@@ -1682,7 +1694,8 @@ static enum fill_status fill_processor( struct table *table, const struct expr *
get_processor_name
(
name
);
get_processor_name
(
name
);
maxclockspeed
=
get_processor_maxclockspeed
();
maxclockspeed
=
get_processor_maxclockspeed
();
num_logical_processors
=
get_logical_processor_count
()
/
count
;
num_logical_processors
=
get_logical_processor_count
(
&
num_cores
)
/
count
;
num_cores
/=
count
;
for
(
i
=
0
;
i
<
count
;
i
++
)
for
(
i
=
0
;
i
<
count
;
i
++
)
{
{
...
@@ -1695,6 +1708,7 @@ static enum fill_status fill_processor( struct table *table, const struct expr *
...
@@ -1695,6 +1708,7 @@ static enum fill_status fill_processor( struct table *table, const struct expr *
rec
->
manufacturer
=
heap_strdupW
(
manufacturer
);
rec
->
manufacturer
=
heap_strdupW
(
manufacturer
);
rec
->
maxclockspeed
=
maxclockspeed
;
rec
->
maxclockspeed
=
maxclockspeed
;
rec
->
name
=
heap_strdupW
(
name
);
rec
->
name
=
heap_strdupW
(
name
);
rec
->
num_cores
=
num_cores
;
rec
->
num_logical_processors
=
num_logical_processors
;
rec
->
num_logical_processors
=
num_logical_processors
;
rec
->
processor_id
=
heap_strdupW
(
processor_id
);
rec
->
processor_id
=
heap_strdupW
(
processor_id
);
rec
->
unique_id
=
NULL
;
rec
->
unique_id
=
NULL
;
...
...
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