2008-05-04 13:31:40 +02:00
|
|
|
# -*- cperl -*-
|
2011-01-18 11:03:44 +01:00
|
|
|
# Copyright (C) 2008 MySQL AB
|
2008-05-04 13:31:40 +02:00
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation; version 2 of the License.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program; if not, write to the Free Software
|
|
|
|
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
|
|
|
|
|
|
|
|
package My::SysInfo;
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
use Carp;
|
|
|
|
use My::Platform;
|
|
|
|
|
2008-05-04 16:35:16 +02:00
|
|
|
use constant DEFAULT_BOGO_MIPS => 2000;
|
2008-05-04 13:31:40 +02:00
|
|
|
|
|
|
|
sub _cpuinfo {
|
|
|
|
my ($self)= @_;
|
|
|
|
|
|
|
|
my $info_file= "/proc/cpuinfo";
|
|
|
|
if ( !( -e $info_file and -f $info_file) ) {
|
|
|
|
return undef;
|
|
|
|
}
|
|
|
|
|
|
|
|
my $F= IO::File->new($info_file) or return undef;
|
|
|
|
|
|
|
|
# Set input separator to blank line
|
|
|
|
local $/ = '';
|
|
|
|
|
|
|
|
while ( my $cpu_chunk= <$F>) {
|
|
|
|
chomp($cpu_chunk);
|
|
|
|
|
|
|
|
my $cpuinfo = {};
|
|
|
|
|
|
|
|
foreach my $cpuline ( split(/\n/, $cpu_chunk) ) {
|
|
|
|
my ( $attribute, $value ) = split(/\s*:\s*/, $cpuline);
|
|
|
|
|
|
|
|
$attribute =~ s/\s+/_/;
|
|
|
|
$attribute = lc($attribute);
|
|
|
|
|
|
|
|
if ( $value =~ /^(no|not available|yes)$/ ) {
|
|
|
|
$value = $value eq 'yes' ? 1 : 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( $attribute eq 'flags' ) {
|
|
|
|
@{ $cpuinfo->{flags} } = split / /, $value;
|
|
|
|
} else {
|
|
|
|
$cpuinfo->{$attribute} = $value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2008-05-04 16:35:16 +02:00
|
|
|
# Make sure bogomips is set to some value
|
|
|
|
$cpuinfo->{bogomips} |= DEFAULT_BOGO_MIPS;
|
|
|
|
|
|
|
|
# Cpus reported once, but with 'cpu_count' set to the actual number
|
|
|
|
my $cpu_count= $cpuinfo->{cpu_count} || 1;
|
|
|
|
for(1..$cpu_count){
|
|
|
|
push(@{$self->{cpus}}, $cpuinfo);
|
|
|
|
}
|
2008-05-04 13:31:40 +02:00
|
|
|
}
|
|
|
|
$F= undef; # Close file
|
|
|
|
return $self;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
sub _kstat {
|
|
|
|
my ($self)= @_;
|
|
|
|
while (1){
|
|
|
|
my $instance_num= $self->{cpus} ? @{$self->{cpus}} : 0;
|
2008-10-08 20:25:28 +02:00
|
|
|
my $list= `kstat -p -m cpu_info -i $instance_num 2> /dev/null`;
|
2008-05-04 16:35:16 +02:00
|
|
|
my @lines= split('\n', $list) or last; # Break loop
|
2008-05-04 13:31:40 +02:00
|
|
|
|
|
|
|
my $cpuinfo= {};
|
|
|
|
foreach my $line (@lines)
|
|
|
|
{
|
|
|
|
my ($module, $instance, $name, $statistic, $value)=
|
|
|
|
$line=~ /(\w*):(\w*):(\w*):(\w*)\t(.*)/;
|
|
|
|
|
|
|
|
$cpuinfo->{$statistic}= $value;
|
|
|
|
}
|
|
|
|
|
2008-05-04 16:35:16 +02:00
|
|
|
# Default value, the actual cpu values can be used to decrease this
|
2008-05-04 13:31:40 +02:00
|
|
|
# on slower cpus
|
2008-05-04 16:35:16 +02:00
|
|
|
$cpuinfo->{bogomips}= DEFAULT_BOGO_MIPS;
|
2008-05-04 13:31:40 +02:00
|
|
|
|
|
|
|
push(@{$self->{cpus}}, $cpuinfo);
|
|
|
|
}
|
|
|
|
|
2008-05-04 16:35:16 +02:00
|
|
|
# At least one cpu should have been found
|
|
|
|
# if this method worked
|
|
|
|
if ( $self->{cpus} ) {
|
|
|
|
return $self;
|
|
|
|
}
|
|
|
|
return undef;
|
2008-05-04 13:31:40 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
sub _unamex {
|
|
|
|
my ($self)= @_;
|
|
|
|
# TODO
|
|
|
|
return undef;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
sub new {
|
|
|
|
my ($class)= @_;
|
|
|
|
|
|
|
|
|
|
|
|
my $self= bless {
|
|
|
|
cpus => (),
|
|
|
|
}, $class;
|
|
|
|
|
|
|
|
my @info_methods =
|
|
|
|
(
|
|
|
|
\&_cpuinfo,
|
|
|
|
\&_kstat,
|
|
|
|
\&_unamex,
|
|
|
|
);
|
|
|
|
|
2008-10-11 17:30:26 +02:00
|
|
|
# Detect virtual machines
|
|
|
|
my $isvm= 0;
|
|
|
|
|
|
|
|
if (IS_WINDOWS) {
|
|
|
|
# Detect vmware service
|
|
|
|
$isvm= `tasklist` =~ /vmwareservice/i;
|
|
|
|
}
|
|
|
|
$self->{isvm}= $isvm;
|
|
|
|
|
2008-05-04 13:31:40 +02:00
|
|
|
foreach my $method (@info_methods){
|
|
|
|
if ($method->($self)){
|
|
|
|
return $self;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
# Push a dummy cpu
|
2008-05-04 16:35:16 +02:00
|
|
|
push(@{$self->{cpus}},
|
|
|
|
{
|
|
|
|
bogomips => DEFAULT_BOGO_MIPS,
|
|
|
|
model_name => "unknown",
|
|
|
|
});
|
2008-05-04 13:31:40 +02:00
|
|
|
|
|
|
|
return $self;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
# Return the list of cpus found
|
|
|
|
sub cpus {
|
|
|
|
my ($self)= @_;
|
|
|
|
return @{$self->{cpus}} or
|
|
|
|
confess "INTERNAL ERROR: No cpus in list";
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
# Return the number of cpus found
|
|
|
|
sub num_cpus {
|
|
|
|
my ($self)= @_;
|
|
|
|
return int(@{$self->{cpus}}) or
|
|
|
|
confess "INTERNAL ERROR: No cpus in list";
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
# Return the smallest bogomips value amongst the processors
|
|
|
|
sub min_bogomips {
|
|
|
|
my ($self)= @_;
|
|
|
|
|
|
|
|
my $bogomips;
|
|
|
|
|
|
|
|
foreach my $cpu (@{$self->{cpus}}) {
|
|
|
|
if (!defined $bogomips or $bogomips > $cpu->{bogomips}) {
|
|
|
|
$bogomips= $cpu->{bogomips};
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $bogomips;
|
|
|
|
}
|
|
|
|
|
2008-10-11 17:30:26 +02:00
|
|
|
sub isvm {
|
|
|
|
my ($self)= @_;
|
|
|
|
|
|
|
|
return $self->{isvm};
|
|
|
|
}
|
|
|
|
|
2008-05-04 13:31:40 +02:00
|
|
|
|
|
|
|
# Prit the cpuinfo
|
|
|
|
sub print_info {
|
|
|
|
my ($self)= @_;
|
|
|
|
|
|
|
|
foreach my $cpu (@{$self->{cpus}}) {
|
|
|
|
while ((my ($key, $value)) = each(%$cpu)) {
|
|
|
|
print " ", $key, "= ";
|
|
|
|
if (ref $value eq "ARRAY") {
|
|
|
|
print "[", join(", ", @$value), "]";
|
|
|
|
} else {
|
|
|
|
print $value;
|
|
|
|
}
|
|
|
|
print "\n";
|
|
|
|
}
|
|
|
|
print "\n";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
1;
|