blob: c6145dc8f6ac03bbb5736aa3227534042e41e85f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
|
# Fact: physicalprocessorcount
#
# Purpose: Return the number of physical processors.
#
# Resolution:
#
# Attempts to use sysfs to get the physical IDs of the processors. Falls
# back to /proc/cpuinfo and "physical id" if sysfs is not available.
#
# Caveats:
#
Facter.add('physicalprocessorcount') do
confine :kernel => :linux
setcode do
sysfs_cpu_directory = '/sys/devices/system/cpu' # This should always be there ...
if File.exists?(sysfs_cpu_directory)
#
# We assume that the sysfs file system has the correct number of entries
# under the "/sys/device/system/cpu" directory and if so then we process
# content of the file "physical_package_id" located inside the "topology"
# directory in each of the per-CPU sub-directories.
#
# As per Linux Kernel documentation and the file "cputopology.txt" located
# inside the "/usr/src/linux/Documentation" directory we can find following
# short explanation:
#
# (...)
#
# 1) /sys/devices/system/cpu/cpuX/topology/physical_package_id:
#
# physical package id of cpuX. Typically corresponds to a physical
# socket number, but the actual value is architecture and platform
# dependent.
#
# (...)
#
lookup_pattern = "#{sysfs_cpu_directory}" +
"/cpu*/topology/physical_package_id"
ids = Dir.glob(lookup_pattern).collect { |f| Facter::Util::Resolution.exec("cat #{f}")}
ids = ids.join if ids.is_a?(Array)
ids.scan(/\d+/).uniq.size
else
#
# Try to count number of CPUs using the proc file system next ...
#
# We assume that /proc/cpuinfo has what we need and is so then we need
# to make sure that we only count unique entries ...
#
str = Facter::Util::Resolution.exec("grep 'physical.\\+:' /proc/cpuinfo")
if not str.nil? then str.scan(/\d+/).uniq.size; end
end
end
end
|