1 // SPDX-License-Identifier: GPL-2.0
2 /*
3  * Copyright (c) 2016 Google, Inc
4  *
5  * Based on code from coreboot src/soc/intel/broadwell/cpu.c
6  */
7 
8 #include <common.h>
9 #include <dm.h>
10 #include <cpu.h>
11 #include <init.h>
12 #include <log.h>
13 #include <asm/cpu.h>
14 #include <asm/cpu_x86.h>
15 #include <asm/cpu_common.h>
16 #include <asm/global_data.h>
17 #include <asm/intel_regs.h>
18 #include <asm/lpc_common.h>
19 #include <asm/msr.h>
20 #include <asm/pci.h>
21 #include <asm/post.h>
22 #include <asm/turbo.h>
23 #include <asm/arch/cpu.h>
24 #include <asm/arch/pch.h>
25 #include <asm/arch/rcb.h>
26 
arch_cpu_init_dm(void)27 int arch_cpu_init_dm(void)
28 {
29 	struct udevice *dev;
30 	int ret;
31 
32 	/* Start up the LPC so we have serial */
33 	ret = uclass_first_device(UCLASS_LPC, &dev);
34 	if (ret)
35 		return ret;
36 	if (!dev)
37 		return -ENODEV;
38 	ret = cpu_set_flex_ratio_to_tdp_nominal();
39 	if (ret)
40 		return ret;
41 
42 	return 0;
43 }
44 
set_max_freq(void)45 void set_max_freq(void)
46 {
47 	msr_t msr, perf_ctl;
48 
49 	if (cpu_config_tdp_levels()) {
50 		/* Set to nominal TDP ratio */
51 		msr = msr_read(MSR_CONFIG_TDP_NOMINAL);
52 		perf_ctl.lo = (msr.lo & 0xff) << 8;
53 	} else {
54 		/* Platform Info bits 15:8 give max ratio */
55 		msr = msr_read(MSR_PLATFORM_INFO);
56 		perf_ctl.lo = msr.lo & 0xff00;
57 	}
58 
59 	perf_ctl.hi = 0;
60 	msr_write(MSR_IA32_PERF_CTL, perf_ctl);
61 
62 	debug("CPU: frequency set to %d MHz\n",
63 	      ((perf_ctl.lo >> 8) & 0xff) * INTEL_BCLK_MHZ);
64 }
65 
arch_cpu_init(void)66 int arch_cpu_init(void)
67 {
68 	post_code(POST_CPU_INIT);
69 
70 #ifdef CONFIG_TPL
71 	/* Do a mini-init if TPL has already done the full init */
72 	return x86_cpu_reinit_f();
73 #else
74 	return x86_cpu_init_f();
75 #endif
76 }
77 
checkcpu(void)78 int checkcpu(void)
79 {
80 	int ret;
81 
82 	set_max_freq();
83 
84 	ret = cpu_common_init();
85 	if (ret)
86 		return ret;
87 	gd->arch.pei_boot_mode = PEI_BOOT_NONE;
88 
89 	return 0;
90 }
91 
print_cpuinfo(void)92 int print_cpuinfo(void)
93 {
94 	char processor_name[CPU_MAX_NAME_LEN];
95 	const char *name;
96 
97 	/* Print processor name */
98 	name = cpu_get_name(processor_name);
99 	printf("CPU:   %s\n", name);
100 
101 	return 0;
102 }
103 
board_debug_uart_init(void)104 void board_debug_uart_init(void)
105 {
106 	/* com1 / com2 decode range */
107 	pci_x86_write_config(PCH_DEV_LPC, LPC_IO_DEC, 1 << 4, PCI_SIZE_16);
108 
109 	pci_x86_write_config(PCH_DEV_LPC, LPC_EN, COMA_LPC_EN, PCI_SIZE_16);
110 }
111