extend/os/linux/hardware/cpu: fix typo.
CPU was transformed into a class in 8d995e961f549e555f405d2567235dab53f6baad.
This commit is contained in:
parent
a558629654
commit
57bf33302a
@ -1,67 +1,68 @@
|
|||||||
module Hardware
|
module Hardware
|
||||||
class CPU
|
class CPU
|
||||||
extend self
|
class << self
|
||||||
|
|
||||||
OPTIMIZATION_FLAGS = {
|
OPTIMIZATION_FLAGS = {
|
||||||
:penryn => "-march=core2 -msse4.1",
|
:penryn => "-march=core2 -msse4.1",
|
||||||
:core2 => "-march=core2",
|
:core2 => "-march=core2",
|
||||||
:core => "-march=prescott"
|
:core => "-march=prescott"
|
||||||
}.freeze
|
}.freeze
|
||||||
def optimization_flags
|
def optimization_flags
|
||||||
OPTIMIZATION_FLAGS
|
OPTIMIZATION_FLAGS
|
||||||
end
|
|
||||||
|
|
||||||
# Linux supports x86 only, and universal archs do not apply
|
|
||||||
def arch_32_bit
|
|
||||||
:i386
|
|
||||||
end
|
|
||||||
|
|
||||||
def arch_64_bit
|
|
||||||
:x86_64
|
|
||||||
end
|
|
||||||
|
|
||||||
def universal_archs
|
|
||||||
[].extend ArchitectureListExtension
|
|
||||||
end
|
|
||||||
|
|
||||||
def cpuinfo
|
|
||||||
@cpuinfo ||= File.read("/proc/cpuinfo")
|
|
||||||
end
|
|
||||||
|
|
||||||
def type
|
|
||||||
@type ||= if cpuinfo =~ /Intel|AMD/
|
|
||||||
:intel
|
|
||||||
else
|
|
||||||
:dunno
|
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
def family
|
# Linux supports x86 only, and universal archs do not apply
|
||||||
cpuinfo[/^cpu family\s*: ([0-9]+)/, 1].to_i
|
def arch_32_bit
|
||||||
end
|
:i386
|
||||||
alias_method :intel_family, :family
|
end
|
||||||
|
|
||||||
def cores
|
def arch_64_bit
|
||||||
cpuinfo.scan(/^processor/).size
|
:x86_64
|
||||||
end
|
end
|
||||||
|
|
||||||
def flags
|
def universal_archs
|
||||||
@flags ||= cpuinfo[/^flags.*/, 0].split
|
[].extend ArchitectureListExtension
|
||||||
end
|
end
|
||||||
|
|
||||||
# Compatibility with Mac method, which returns lowercase symbols
|
def cpuinfo
|
||||||
# instead of strings
|
@cpuinfo ||= File.read("/proc/cpuinfo")
|
||||||
def features
|
end
|
||||||
@features ||= flags[1..-1].map(&:intern)
|
|
||||||
end
|
|
||||||
|
|
||||||
%w[aes altivec avx avx2 lm sse3 ssse3 sse4 sse4_2].each do |flag|
|
def type
|
||||||
define_method(flag + "?") { flags.include? flag }
|
@type ||= if cpuinfo =~ /Intel|AMD/
|
||||||
end
|
:intel
|
||||||
alias_method :is_64_bit?, :lm?
|
else
|
||||||
|
:dunno
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def bits
|
def family
|
||||||
is_64_bit? ? 64 : 32
|
cpuinfo[/^cpu family\s*: ([0-9]+)/, 1].to_i
|
||||||
|
end
|
||||||
|
alias_method :intel_family, :family
|
||||||
|
|
||||||
|
def cores
|
||||||
|
cpuinfo.scan(/^processor/).size
|
||||||
|
end
|
||||||
|
|
||||||
|
def flags
|
||||||
|
@flags ||= cpuinfo[/^flags.*/, 0].split
|
||||||
|
end
|
||||||
|
|
||||||
|
# Compatibility with Mac method, which returns lowercase symbols
|
||||||
|
# instead of strings
|
||||||
|
def features
|
||||||
|
@features ||= flags[1..-1].map(&:intern)
|
||||||
|
end
|
||||||
|
|
||||||
|
%w[aes altivec avx avx2 lm sse3 ssse3 sse4 sse4_2].each do |flag|
|
||||||
|
define_method(flag + "?") { flags.include? flag }
|
||||||
|
end
|
||||||
|
alias_method :is_64_bit?, :lm?
|
||||||
|
|
||||||
|
def bits
|
||||||
|
is_64_bit? ? 64 : 32
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
x
Reference in New Issue
Block a user