NAME

System::CPU - Cross-platform CPU information / topology with no dependencies

VERSION

Version 0.01

SYNOPSIS

use System::CPU;

# Number of logical cores. E.g. on SMT systems this will be the num of Hyper-Threads
my $logical_cpu = System::CPU::get_ncpu();

# For some platforms you can separately get the number of processors/sockets and cores
my ($phys_processors, $phys_cpu, $logical_cpu) = System::CPU::get_cpu();

# Model name of the CPU
my $name = System::CPU::get_name();

# CPU Architecture
my $arch = System::CPU::get_arch();

DESCRIPTION

A pure Perl module with no dependencies to get basic CPU information on any platform. The data you can get differs depending on platform, but for many systems running Linux/BSD/MacOS you can get extra nuance like number of threads vs cores etc.

It was created for Benchmarking::DKbench with the get_ncpu function modeled after the one on MCE::Util. In fact, some code was copied from that function as it had the most reliable way to consistently get the logical cpus of the system.

FUNCTIONS

get_cpu

Returns as detailed CPU topology as the platform allows. A list of three values will be returned, the first and the second possibly undef:

my ($phys_processors, $phys_cpu, $logical_cpu) = System::CPU::get_cpu();

For many Linux systems, the number of physical processors (sockets), as well as the number of physical CPU cores and logical CPUs (CPU threads) will be returned.

For MacOS and BSD, the physical processors (sockets) will be undef, but the cores vs threads numbers should still be available for most systems.

For the systems where the extra information is not available (i.e. all other OSes), the first two values will be undef.

get_ncpu

my $logical_cpus = System::CPU::get_ncpu();

This function behaves very similar to MCE::Util::get_ncpu - in fact code is borrowed from it. The number of logical CPUs will be return, this is the number of threads for SMT systems and the number of cores for most others.

get_name

my $cpu_name = System::CPU::get_name(raw => $raw?);

Returns the CPU model name. By default it will remove some extra spaces and Intel's (TM) and (R), but you can pass in the raw argument if you do not want that.

get_arch

my $arch = System::CPU::get_arch();

Will return the CPU architecture as reported by the system. There is no standarized form, e.g. Linux will report aarch64 on a system where Darwin would report arm64 etc.

CAVEATS

Since text output from commands is parsed for most platforms, only the English language locales are supported.

NOTES

I did try to use existing solutions before writing my own. Sys::Info has issues installing on modern Linux systems (I tried submitting a PR, but the author seems unresponsive).

System::Info is the most promising, however, it returns a simple "core" count which seems to inconsistently be either physical cores or threads depending on the platform. The author got back to me, so I will try to sort that out, as that module is more generic than System::CPU.

There are also several platform-specific modules, most requiring a compiler too (e.g. Unix::Processors, Sys::Info, various *::Sysinfo).

In the end, I wanted to get the CPU topology where possible - number of processors/sockets, cores, threads separately, something that wasn't readily available.

I intend to support all systems possible with this simple pure Perl module. If you have access to a system that is not supported or where the module cannot currently give you the correct output, feel free to contact me about extending support.

Currently supported systems:

Linux/Android, BSD/MacOS, Win32/Cygwin, AIX, Solaris, IRIX, HP-UX, Haiku, GNU and variants of those.

AUTHOR

Dimitrios Kechagias, <dkechag at cpan.org>

BUGS

Please report any bugs or feature requests to https://github.com/dkechag/System-CPU/issues.

You can also submit PRs with fixes/enhancements directly.

SUPPORT

You can find documentation for this module with the perldoc command.

perldoc System::CPU

You can also look for information at:

ACKNOWLEDGEMENTS

Some code borrowed from MCE.

LICENSE AND COPYRIGHT

This software is copyright (c) 2023 by Dimitrios Kechagias.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.