summaryrefslogtreecommitdiffstats
path: root/src/cpu/amd/family_10h-family_15h/tsc_freq.c
blob: 793cc1bfad6d5fd2463682a289ff77333bec4128 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
/*
 * This file is part of the coreboot project.
 *
 * 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.
 */

#include <stdint.h>
#include <cpu/x86/msr.h>
#include <cpu/amd/msr.h>
#include <cpu/x86/tsc.h>

unsigned long tsc_freq_mhz(void)
{
	msr_t msr;
	uint8_t cpufid;
	uint8_t cpudid;

	/* On Family 10h/15h CPUs the TSC increments
	 * at the P0 clock rate.  Read the P0 clock
	 * frequency from the P0 MSR and convert
	 * to MHz.  See also the Family 15h BKDG
	 * Rev. 3.14 page 569.
	 */
	msr = rdmsr(PSTATE_0_MSR);
	cpufid = (msr.lo & 0x3f);
	cpudid = (msr.lo & 0x1c0) >> 6;

	return (100 * (cpufid + 0x10)) / (0x01 << cpudid);
}