2015-11-03 23:28:44 +00:00
|
|
|
libcpuid
|
|
|
|
========
|
|
|
|
|
|
|
|
libcpuid provides CPU identification for the x86 (and x86_64).
|
2020-05-09 15:34:07 +00:00
|
|
|
For details about the programming API, you might want to
|
2016-05-22 20:35:30 +00:00
|
|
|
take a look at the project's website on sourceforge
|
|
|
|
(http://libcpuid.sourceforge.net/). There you'd find a short
|
|
|
|
[tutorial](http://libcpuid.sf.net/documentation.html), as well
|
|
|
|
as the full [API reference](http://libcpuid.sf.net/doxy).
|
2015-11-03 23:28:44 +00:00
|
|
|
|
|
|
|
Configuring after checkout
|
|
|
|
--------------------------
|
|
|
|
|
2018-04-16 07:45:15 +00:00
|
|
|
Under Linux, where you download the sources, there's no
|
2015-11-03 23:28:44 +00:00
|
|
|
configure script to run. This is because it isn't a good practice to keep
|
|
|
|
such scripts in a source control system. To create it, you need to run the
|
|
|
|
following commands once, after you checkout the libcpuid sources
|
|
|
|
from github:
|
|
|
|
|
|
|
|
1. run "libtoolize"
|
|
|
|
2. run "autoreconf --install"
|
|
|
|
|
|
|
|
You need to have `autoconf`, `automake` and `libtool` installed.
|
|
|
|
|
|
|
|
After that you can run `./configure` and `make` - this will build
|
|
|
|
the library.
|
|
|
|
|
|
|
|
`make dist` will create a tarball (with "configure" inside) with the
|
|
|
|
sources.
|
|
|
|
|
2018-04-16 07:45:15 +00:00
|
|
|
Prerequisites
|
|
|
|
-------------
|
|
|
|
|
|
|
|
Using libcpuid requires no dependencies on any of the supported OSes.
|
|
|
|
Building it requires the aforementioned libtool and autotools commands
|
|
|
|
to be available, which is a matter of installing a few common packages
|
|
|
|
with related names (e.g. automake, autoconf, libtool).
|
|
|
|
It also requires a POSIX-compatible shell. On NetBSD, you may need
|
|
|
|
to install one (credits to @brucelilly):
|
|
|
|
|
|
|
|
1. Install a POSIX-compatible shell such as ksh93
|
|
|
|
(pkg_add ast-ksh || pkgin in ast-ksh)
|
|
|
|
2. export CONFIG_SHELL=/usr/pkg/bin/ksh93 (substitute the
|
|
|
|
correct path if required)
|
|
|
|
3. Follow the regular Linux instructions
|
|
|
|
|
2016-04-19 10:38:41 +00:00
|
|
|
Testing
|
|
|
|
-------
|
|
|
|
|
|
|
|
After any change to the detection routines or match tables, it's always
|
|
|
|
a good idea to run `make test`. If some test fails, and you're confident
|
|
|
|
that the test is wrong and needs fixing, run `make fix-tests`.
|
|
|
|
|
|
|
|
You can also add a new test (which is basically a file containing
|
2020-05-09 15:34:07 +00:00
|
|
|
the raw CPUID data and the expected decoded items) by using
|
2016-04-19 10:38:41 +00:00
|
|
|
`tests/create_test.py`. The workflow there is as follows:
|
|
|
|
|
|
|
|
1. Run "cpuid_tool" with no arguments. It will tell you that it
|
|
|
|
has written a pair of files, raw.txt and report.txt. Ensure
|
|
|
|
that report.txt contains meaningful data.
|
|
|
|
2. Run "tests/create_test.py raw.txt report.txt > «my-cpu».test"
|
|
|
|
3. Use a proper descriptive name for the test (look into tests/amd
|
|
|
|
and tests/intel to get an idea) and copy your test file to an
|
|
|
|
appropriate place within the tests directory hierarchy.
|
|
|
|
|
|
|
|
For non-developers, who still want to contribute tests for the project,
|
|
|
|
use [this page](http://libcpuid.sourceforge.net/bugreport.php) to report
|
|
|
|
misdetections or new CPUs that libcpuid doesn't handle well yet.
|
|
|
|
|
2015-11-03 23:28:44 +00:00
|
|
|
Users
|
|
|
|
-----
|
|
|
|
|
|
|
|
So far, I'm aware of the following projects which utilize libcpuid:
|
|
|
|
|
|
|
|
* CPU-X (https://github.com/X0rg/CPU-X)
|
|
|
|
* fre:ac (https://www.freac.org/)
|
2015-11-03 23:35:06 +00:00
|
|
|
* ucbench (http://anrieff.net/ucbench)
|
2017-04-04 14:31:03 +00:00
|
|
|
* Multiprecision Computing Toolbox for MATLAB (https://www.advanpix.com/)
|
2015-11-03 23:28:44 +00:00
|
|
|
|
|
|
|
We'd love to hear from you if you are also using libcpuid and want your project listed above.
|