soc/intel/pantherlake: Remove soc_info.[hc] interface
[coreboot2.git] / src / soc / intel / tigerlake / lockdown.c
blob2f7ccebc8b3355837149023cea62aef0a4d2f421
1 /* SPDX-License-Identifier: GPL-2.0-only */
3 /*
4 * This file is created based on Intel Tiger Lake Processor PCH Datasheet
5 * Document number: 575857
6 * Chapter number: 4
7 */
9 #include <device/mmio.h>
10 #include <intelblocks/cfg.h>
11 #include <intelpch/lockdown.h>
12 #include <soc/pm.h>
13 #include <stdint.h>
15 static void pmc_lock_pmsync(void)
17 uint8_t *pmcbase;
18 uint32_t pmsyncreg;
20 pmcbase = pmc_mmio_regs();
22 pmsyncreg = read32(pmcbase + PMSYNC_TPR_CFG);
23 pmsyncreg |= PCH2CPU_TPR_CFG_LOCK;
24 write32(pmcbase + PMSYNC_TPR_CFG, pmsyncreg);
27 static void pmc_lock_abase(void)
29 uint8_t *pmcbase;
30 uint32_t reg32;
32 pmcbase = pmc_mmio_regs();
34 reg32 = read32(pmcbase + GEN_PMCON_B);
35 reg32 |= (SLP_STR_POL_LOCK | ACPI_BASE_LOCK);
36 write32(pmcbase + GEN_PMCON_B, reg32);
39 static void pmc_lock_smi(void)
41 uint8_t *pmcbase;
42 uint8_t reg8;
44 pmcbase = pmc_mmio_regs();
46 reg8 = read8(pmcbase + GEN_PMCON_B);
47 reg8 |= SMI_LOCK;
48 write8(pmcbase + GEN_PMCON_B, reg8);
51 static void pmc_lockdown_cfg(int chipset_lockdown)
53 /* PMSYNC */
54 pmc_lock_pmsync();
55 /* Lock down ABASE and sleep stretching policy */
56 pmc_lock_abase();
58 if (chipset_lockdown == CHIPSET_LOCKDOWN_COREBOOT)
59 pmc_lock_smi();
62 void soc_lockdown_config(int chipset_lockdown)
64 /* PMC lock down configuration */
65 pmc_lockdown_cfg(chipset_lockdown);