Veselin Georgiev
2fa79c9a26
Merge pull request #57 from X0rg/master
...
Replace binary literals by hex literals
2016-09-03 17:42:43 +01:00
Xorg
581ca840fa
Replace binary literals by hex literals
...
Fix #52 , again.
2016-09-03 18:39:55 +02:00
Veselin Georgiev
8f21ed54ab
Merge pull request #56 from X0rg/master
...
Fix for AMD multipliers
2016-08-30 11:07:41 +01:00
Xorg
77c6a9a666
Increase CPU clock accuracy in bus clock calculation
...
The CPU clock is computed once and cached, so it needs to be accurate. In libcpuid.h, 100ms is recommended.
2016-08-30 11:13:17 +02:00
Xorg
4a077265fd
Fixed issue #52 : Wrong CPU multipliers on AMD APU
...
Properly use formulas from AMD BKDG, it should fix CPU multipliers report from 10h family to 16h family.
Some tests are available in #52 .
2016-08-30 11:07:06 +02:00
Veselin Georgiev
3f38efb6c9
Fixed issue #54 : Intel Atom N450 not recognised properly
...
Improved parsing of brand strings for both Pineview and Cedarview
Atoms.
Add tests for both the Pineview Atom, and also Broadwell-E
(forgotten in a previous commit).
2016-08-24 15:06:40 +03:00
Veselin Georgiev
f5d82b0f1a
Merge pull request #55 from eloaders/patch-1
...
Update Changelog
2016-08-24 12:48:45 +01:00
Veselin Georgiev
1599fd5a27
Fixed issue #53 : Broadwell-E not recognised properly
...
The presence of RTM was previously incorrectly attributed to a Skylake
or later only CPUs. Broadwells have this as well, so the detected
intel_code_t for Broadwell-E was wrong (it was CORE_HASWELL*).
2016-08-24 08:50:28 +03:00
eloaders
9e3d20d25b
Update Changelog
2016-08-22 17:52:00 +02:00
Veselin Georgiev
50530f7618
Fix issue #51 : Undefined behavior.
2016-07-31 17:48:49 +03:00
Veselin Georgiev
e0505af4f6
Fix issue #50 : On some virtual machines, library returns zero number of cores.
...
As proposed in the issue discussion.
2016-07-18 09:07:51 +03:00
Veselin Georgiev
2a11739c10
Update the release date for 0.3.0 in the ChangeLog.
2016-07-10 04:55:34 +03:00
Veselin Georgiev
ea7ae60ccb
Add libcpuid_internal.h, intel_code_t.h and amd_code_t.h to Makefile.am.
...
Otherwise they don't end up in the source tarball and it doesn't compile.
2016-07-10 04:33:02 +03:00
Veselin Georgiev
51aac9f852
Update .am files about the vc9->vc10 file change.
2016-07-10 04:27:35 +03:00
Veselin Georgiev
c07d8a79d9
Fix a typo.
2016-07-10 03:01:26 +02:00
Veselin Georgiev
58569cb77b
Ignore .vcxproj.user files generated by MSVS2010.
2016-07-10 03:00:20 +02:00
Veselin Georgiev
c9ff6036a2
Ignore build directories for the VC10 projects.
2016-07-10 02:59:23 +02:00
Veselin Georgiev
bb9f03f2ba
Replace VC9 project files with improved ones for VC10.
...
The new project files are for Microsoft Visual Studio 2010.
The configurations now support building both 32- and 64-bit targets,
and the "Release DLL" target is supported much like in the vc71 project.
The output layout is as follows:
32-bit, Debug static library goes to libcpuid/x32/Debug
32-bit, Release static library goes to libcpuid/x32/Release
32-bit, DLL (only release) goes to libcpuid/x32/ReleaseDLL. It includes
the .dll and the export library .lib as well.
64-bit DLL goes to libcpuid/x64/ReleaseDLL.
and so forth.
2016-07-10 02:51:23 +02:00
Veselin Georgiev
1b1e858df4
Ignore temp/local files by MSVS2010.
2016-07-10 02:24:21 +02:00
Veselin Georgiev
647d737db8
Set version to 0.3.0 in libcpuid.h, update release date.
2016-07-09 06:54:07 +03:00
Veselin Georgiev
91dad77e6e
Similar to the previous commit: additions to the VC9 project file.
2016-07-09 06:53:12 +03:00
Veselin Georgiev
03d54ae61c
Port to MSVC7.1: C89 compliance and project updates.
2016-07-09 05:48:35 +03:00
Veselin Georiev
568db71156
Fix a bunch of warnings (emitted from MSVC).
2016-07-09 05:24:12 +03:00
Veselin Georiev
296b1efe7a
Rename ATOM enum value as it clashes with some Windows headers.
2016-07-09 05:24:12 +03:00
Veselin Georgiev
87f3052a7b
Add a test with L4 cache (courtesy of @phprus).
...
The test is a snapshot of a Haswell i7 (a.k.a. "Crystalwell") core.
This is the only test in the test DB right now which has lines for
L4 cache size, associativity and cacheline size different than "-1".
Also update create_test.py to accommodate for the new fields.
2016-07-07 00:53:03 +03:00
Veselin Georgiev
f52c02d394
Update all tests: add fields for L4 cache size, assoc. and line size.
2016-07-07 00:44:45 +03:00
Veselin Georgiev
612d2135f6
Merge pull request #49 from X0rg/master
...
Fix & Athlon 64 FX X2
2016-06-16 12:44:12 +01:00
Xorg
298539b4b0
Add Athlon 64 FX X2 (Toledo) in database
2016-06-16 12:58:42 +02:00
Xorg
bc84f0c71d
cpu_msrinfo(): Fix value of CPU_INVALID_VALUE in 'double' subfunctions
...
It returns 0x7FFFFFFF instead of 0x3FFFFFFF
0x3FFFFFFF is a 29-bit value, but become a 36-bit value when multiplied by 100, causing a value out-of-range
2016-06-16 12:40:41 +02:00
Xorg
c64f8bcc60
Ignore more files in repo
2016-06-16 12:22:04 +02:00
Veselin Georgiev
3f51d3ca25
Add detection of L4 cache.
2016-06-09 15:42:57 +03:00
Veselin Georgiev
571fe75d88
Remove redundant MSRINFO_DEFINED macro.
2016-06-06 11:38:40 +03:00
Veselin Georgiev
24d7c318d0
Resolve warnings on Mac OS X.
2016-06-06 01:50:05 +03:00
Veselin Georgiev
dbf9991553
Merge pull request #48 from X0rg/master
...
MSRs rework and man-pages
2016-06-05 14:39:57 +01:00
Xorg
ec445b0a54
Add load_driver() support for GNU/Linux & FreeBSD in cpu_msr_driver_open_core()
2016-06-05 14:10:19 +02:00
Xorg
023f0307f0
Minor changes for cpu_msrinfo()
2016-06-05 13:16:15 +02:00
Veselin Georgiev
7320ee9f29
Change configure.ac AGE (as per the comments in issue #46 ).
...
The new library generated under linux is libcpuid.so.13.0.0, which
makes it clear it's binary incompatible with the old version
(libcpuid.so.11.1.2).
2016-06-05 13:57:06 +03:00
Xorg
462ec75c79
Fix Doxygen warnings, don't warn if undocmented
2016-06-05 12:19:49 +02:00
Xorg
8fda5a74f1
Generate and install man-pages if Doxygen is installed
2016-06-05 12:09:59 +02:00
Xorg
240a862c45
Fix warnings
...
recog_intel.c:589:22: warning: implicit conversion from enumeration type 'enum _common_codes_t' to different enumeration type 'intel_code_t' (aka 'enum _intel_code_t')
recog_amd.c:449:9: warning: implicit conversion from enumeration type 'enum _common_codes_t' to different enumeration type 'amd_code_t' (aka 'enum _amd_code_t')
2016-06-05 11:07:00 +02:00
Xorg
cba9a1e19a
Replace hardcoded addresses by define in cpu_msrinfo()
2016-06-04 20:52:27 +02:00
Xorg
e631e62ce6
Silent rules in configure.ac
...
Less useless output to easily see warnings
2016-06-04 20:36:58 +02:00
Xorg
9059fb6ff5
Add INFO_BUS_CLOCK in cpu_msrinfo() as a more generic term (same as INFO_BCLK)
...
BCLK is specific to Intel
2016-06-04 20:31:01 +02:00
Xorg
eeb7a6f3c7
Report CPU minimum multiplier (INFO_MIN_MULTIPLIER) in cpu_msrinfo()
2016-06-04 20:11:09 +02:00
Xorg
24cd11fea9
In cpu_msrinfo(), add experimental support for AMD CPUs for INFO_CUR_MULTIPLIER, INFO_MAX_MULTIPLIER and INFO_BCLK
...
get_amd_multipliers() allow to share a maximum of code
2016-06-04 19:50:21 +02:00
Xorg
14cfc77b17
Improve/clean code for cpu_msrinfo()
...
* Add AMD and Intel doc links
* Use 'return' only if there is no error; on error, the end-function 'return CPU_INVALID_VALUE' is used
* Add more comments about MSRs
* Simplify a lot of things
* Avoid cpu_rdmsr_range() to override cpu_rdmsr() error
* Remove int casting in cpu_msrinfo()
2016-06-04 17:51:48 +02:00
Xorg
8fc0cc0d4a
Use internal code for MSR, replace cpuid_get_vendor() by id->vendor
2016-06-04 14:13:24 +02:00
Xorg
1ef4615d8f
Use cpu_id_t in cpu_msrinfo()
...
It can be useful to have more informations on CPU
2016-06-04 13:16:41 +02:00
Veselin Georgiev
5f99a4528c
Change version to 0.3.0 throughout the project. Update ChangeLog.
2016-06-03 21:15:37 +03:00
Xorg
5467504680
Use cpu_ident_internal() in cpu_msrinfo()
2016-06-03 15:58:45 +02:00