diff options
author | Peter Stuge <peter@stuge.se> | 2008-11-22 17:13:36 +0000 |
---|---|---|
committer | Stefan Reinauer <stepan@openbios.org> | 2008-11-22 17:13:36 +0000 |
commit | dad1e3091f2d9a3fc03b9ca83c2990e23b4ea32c (patch) | |
tree | 4ca71d53ba7405b720fa977614fd68a96bf3d3bd /util/msrtool/sys.c | |
parent | d24fe7e80ede60847afaa2ae30692b072ea06eda (diff) | |
download | coreboot-dad1e3091f2d9a3fc03b9ca83c2990e23b4ea32c.tar.xz |
msrtool: Release Candidate 1
msrtool can decode MSRs and print the value of every field in human
readable form. It can also be used to save a set of MSRs to a file,
and at a later time compare the saved values with current values in
hardware.
Signed-off-by: Peter Stuge <peter@stuge.se>
Acked-by: Stefan Reinauer <stepan@coresystems.de>
git-svn-id: svn://svn.coreboot.org/coreboot/trunk@3766 2b7e53f0-3cfb-0310-b3e9-8179ed1497e1
Diffstat (limited to 'util/msrtool/sys.c')
-rw-r--r-- | util/msrtool/sys.c | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/util/msrtool/sys.c b/util/msrtool/sys.c new file mode 100644 index 0000000000..95539c8677 --- /dev/null +++ b/util/msrtool/sys.c @@ -0,0 +1,42 @@ +/* + * This file is part of msrtool. + * + * Copyright (c) 2008 Peter Stuge <peter@stuge.se> + * + * This program is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License version 2 as + * published by the Free Software Foundation. + * + * 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 + */ + +#include "msrtool.h" + +static struct cpuid_t id; + +struct cpuid_t *cpuid(void) { + uint32_t outeax; + asm ("cpuid" : "=a" (outeax) : "a" (1) : "%ebx", "%ecx", "%edx"); + id.stepping = outeax & 0xf; + outeax >>= 4; + id.model = outeax & 0xf; + outeax >>= 4; + id.family = outeax & 0xf; + outeax >>= 8; + id.ext_model = outeax & 0xf; + outeax >>= 4; + id.ext_family = outeax & 0xff; + if (0xf == id.family) { + /* Intel says always do this, AMD says only for family f */ + id.model |= (id.ext_model << 4); + id.family += id.ext_family; + } + return &id; +} |