Patrick Georgi | ac95903 | 2020-05-05 22:49:26 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-or-later */ |
Jonathan Zhang | 8f89549 | 2020-01-16 11:16:45 -0800 | [diff] [blame] | 2 | |
| 3 | #include <assert.h> |
Jonathan Zhang | 8f89549 | 2020-01-16 11:16:45 -0800 | [diff] [blame] | 4 | #include <console/console.h> |
Jonathan Zhang | 8f89549 | 2020-01-16 11:16:45 -0800 | [diff] [blame] | 5 | #include <device/pci.h> |
| 6 | #include <hob_iiouds.h> |
| 7 | #include <intelblocks/cpulib.h> |
| 8 | #include <intelblocks/pcr.h> |
| 9 | #include <soc/iomap.h> |
Jonathan Zhang | 8f89549 | 2020-01-16 11:16:45 -0800 | [diff] [blame] | 10 | #include <soc/msr.h> |
| 11 | #include <soc/pci_devs.h> |
| 12 | #include <soc/pcr_ids.h> |
| 13 | #include <soc/soc_util.h> |
Andrey Petrov | 662da6c | 2020-03-16 22:46:57 -0700 | [diff] [blame] | 14 | #include <soc/util.h> |
Jonathan Zhang | 8f89549 | 2020-01-16 11:16:45 -0800 | [diff] [blame] | 15 | |
Jonathan Zhang | 8f89549 | 2020-01-16 11:16:45 -0800 | [diff] [blame] | 16 | |
| 17 | /* |
| 18 | * +-------------------------+ TOLM |
| 19 | * | System Management Mode | |
| 20 | * | code and data | |
| 21 | * | (TSEG) | |
| 22 | * +-------------------------+ SMM base (aligned) |
| 23 | * | | |
| 24 | * | Chipset Reserved Memory | |
| 25 | * | | |
| 26 | * +-------------------------+ top_of_ram (aligned) |
| 27 | * | | |
| 28 | * | CBMEM Root | |
| 29 | * | | |
| 30 | * +-------------------------+ |
| 31 | * | | |
| 32 | * | FSP Reserved Memory | |
| 33 | * | | |
| 34 | * +-------------------------+ |
| 35 | * | | |
| 36 | * | Various CBMEM Entries | |
| 37 | * | | |
| 38 | * +-------------------------+ top_of_stack (8 byte aligned) |
| 39 | * | | |
| 40 | * | stack (CBMEM Entry) | |
| 41 | * | | |
| 42 | * +-------------------------+ |
| 43 | */ |
| 44 | |
Marc Jones | 645bca4 | 2020-11-02 14:29:46 -0700 | [diff] [blame] | 45 | const struct SystemMemoryMapHob *get_system_memory_map(void) |
Jonathan Zhang | 8f89549 | 2020-01-16 11:16:45 -0800 | [diff] [blame] | 46 | { |
| 47 | size_t hob_size; |
Marc Jones | 645bca4 | 2020-11-02 14:29:46 -0700 | [diff] [blame] | 48 | const uint8_t mem_hob_guid[16] = FSP_SYSTEM_MEMORYMAP_HOB_GUID; |
| 49 | const struct SystemMemoryMapHob *memmap_addr; |
| 50 | |
| 51 | memmap_addr = fsp_find_extension_hob_by_guid(mem_hob_guid, &hob_size); |
Elyes Haouas | f1ba7d6 | 2022-09-13 10:03:44 +0200 | [diff] [blame] | 52 | assert(memmap_addr && hob_size != 0); |
Marc Jones | 645bca4 | 2020-11-02 14:29:46 -0700 | [diff] [blame] | 53 | |
| 54 | return memmap_addr; |
| 55 | } |
| 56 | |
Arthur Heymans | 550f55e | 2022-08-24 14:44:26 +0200 | [diff] [blame] | 57 | bool is_pcie_iio_stack_res(const STACK_RES *res) |
| 58 | { |
Arthur Heymans | 470f1d3 | 2023-08-31 18:19:09 +0200 | [diff] [blame^] | 59 | return res->BusBase < res->BusLimit; |
Arthur Heymans | 550f55e | 2022-08-24 14:44:26 +0200 | [diff] [blame] | 60 | } |
| 61 | |
Jonathan Zhang | ca520a7 | 2023-01-23 18:14:53 -0800 | [diff] [blame] | 62 | uint8_t get_stack_busno(const uint8_t stack) |
| 63 | { |
| 64 | if (stack >= MAX_IIO_STACK) { |
| 65 | printk(BIOS_ERR, "%s: Stack %u does not exist!\n", __func__, stack); |
| 66 | return 0; |
| 67 | } |
| 68 | const pci_devfn_t dev = PCI_DEV(UBOX_DECS_BUS, UBOX_DECS_DEV, UBOX_DECS_FUNC); |
| 69 | const uint16_t offset = stack / 4 ? UBOX_DECS_CPUBUSNO1_CSR : UBOX_DECS_CPUBUSNO_CSR; |
| 70 | return pci_io_read_config32(dev, offset) >> (8 * (stack % 4)) & 0xff; |
| 71 | } |
| 72 | |
Marc Jones | 5851f9d | 2020-11-02 15:30:10 -0700 | [diff] [blame] | 73 | uint32_t get_socket_stack_busno(uint32_t socket, uint32_t stack) |
Jonathan Zhang | 8f89549 | 2020-01-16 11:16:45 -0800 | [diff] [blame] | 74 | { |
Arthur Heymans | 83b2622 | 2020-11-06 11:50:55 +0100 | [diff] [blame] | 75 | const IIO_UDS *hob = get_iio_uds(); |
Jonathan Zhang | 8f89549 | 2020-01-16 11:16:45 -0800 | [diff] [blame] | 76 | |
Marc Jones | 645bca4 | 2020-11-02 14:29:46 -0700 | [diff] [blame] | 77 | assert(socket < MAX_SOCKET && stack < MAX_IIO_STACK); |
Jonathan Zhang | 8f89549 | 2020-01-16 11:16:45 -0800 | [diff] [blame] | 78 | |
Marc Jones | 645bca4 | 2020-11-02 14:29:46 -0700 | [diff] [blame] | 79 | return hob->PlatformData.CpuQpiInfo[socket].StackBus[stack]; |
| 80 | } |
Jonathan Zhang | 8f89549 | 2020-01-16 11:16:45 -0800 | [diff] [blame] | 81 | |
Jonathan Zhang | ca520a7 | 2023-01-23 18:14:53 -0800 | [diff] [blame] | 82 | uint32_t get_socket_ubox_busno(uint32_t socket) |
| 83 | { |
| 84 | if (socket == 0) |
| 85 | return get_stack_busno(PCU_IIO_STACK); |
| 86 | |
| 87 | return get_socket_stack_busno(socket, PCU_IIO_STACK); |
| 88 | } |
| 89 | |
Marc Jones | 645bca4 | 2020-11-02 14:29:46 -0700 | [diff] [blame] | 90 | void config_reset_cpl3_csrs(void) |
Jonathan Zhang | 8f89549 | 2020-01-16 11:16:45 -0800 | [diff] [blame] | 91 | { |
Marc Jones | 645bca4 | 2020-11-02 14:29:46 -0700 | [diff] [blame] | 92 | uint32_t data, plat_info, max_min_turbo_limit_ratio; |
Jonathan Zhang | 8f89549 | 2020-01-16 11:16:45 -0800 | [diff] [blame] | 93 | |
Marc Jones | 645bca4 | 2020-11-02 14:29:46 -0700 | [diff] [blame] | 94 | for (uint32_t socket = 0; socket < MAX_SOCKET; ++socket) { |
| 95 | uint32_t bus = get_socket_stack_busno(socket, PCU_IIO_STACK); |
Jonathan Zhang | 8f89549 | 2020-01-16 11:16:45 -0800 | [diff] [blame] | 96 | |
Marc Jones | 645bca4 | 2020-11-02 14:29:46 -0700 | [diff] [blame] | 97 | /* configure PCU_CR0_FUN csrs */ |
| 98 | pci_devfn_t cr0_dev = PCI_DEV(bus, PCU_DEV, PCU_CR0_FUN); |
Nico Huber | f4f365f | 2021-10-14 18:16:39 +0200 | [diff] [blame] | 99 | data = pci_s_read_config32(cr0_dev, PCU_CR0_P_STATE_LIMITS); |
Marc Jones | 645bca4 | 2020-11-02 14:29:46 -0700 | [diff] [blame] | 100 | data |= P_STATE_LIMITS_LOCK; |
Nico Huber | f4f365f | 2021-10-14 18:16:39 +0200 | [diff] [blame] | 101 | pci_s_write_config32(cr0_dev, PCU_CR0_P_STATE_LIMITS, data); |
Marc Jones | 645bca4 | 2020-11-02 14:29:46 -0700 | [diff] [blame] | 102 | |
Nico Huber | f4f365f | 2021-10-14 18:16:39 +0200 | [diff] [blame] | 103 | plat_info = pci_s_read_config32(cr0_dev, PCU_CR0_PLATFORM_INFO); |
Marc Jones | 645bca4 | 2020-11-02 14:29:46 -0700 | [diff] [blame] | 104 | dump_csr64("", cr0_dev, PCU_CR0_PLATFORM_INFO); |
| 105 | max_min_turbo_limit_ratio = |
| 106 | (plat_info & MAX_NON_TURBO_LIM_RATIO_MASK) >> |
| 107 | MAX_NON_TURBO_LIM_RATIO_SHIFT; |
| 108 | printk(BIOS_SPEW, "plat_info: 0x%x, max_min_turbo_limit_ratio: 0x%x\n", |
| 109 | plat_info, max_min_turbo_limit_ratio); |
| 110 | |
| 111 | /* configure PCU_CR1_FUN csrs */ |
| 112 | pci_devfn_t cr1_dev = PCI_DEV(bus, PCU_DEV, PCU_CR1_FUN); |
| 113 | |
Nico Huber | f4f365f | 2021-10-14 18:16:39 +0200 | [diff] [blame] | 114 | data = pci_s_read_config32(cr1_dev, PCU_CR1_SAPMCTL); |
Marc Jones | 645bca4 | 2020-11-02 14:29:46 -0700 | [diff] [blame] | 115 | /* clear bits 27:31 - FSP sets this with 0x7 which needs to be cleared */ |
| 116 | data &= 0x0fffffff; |
| 117 | data |= SAPMCTL_LOCK_MASK; |
Nico Huber | f4f365f | 2021-10-14 18:16:39 +0200 | [diff] [blame] | 118 | pci_s_write_config32(cr1_dev, PCU_CR1_SAPMCTL, data); |
Marc Jones | 645bca4 | 2020-11-02 14:29:46 -0700 | [diff] [blame] | 119 | |
| 120 | /* configure PCU_CR1_FUN csrs */ |
| 121 | pci_devfn_t cr2_dev = PCI_DEV(bus, PCU_DEV, PCU_CR2_FUN); |
| 122 | |
| 123 | data = PCIE_IN_PKGCSTATE_L1_MASK; |
Nico Huber | f4f365f | 2021-10-14 18:16:39 +0200 | [diff] [blame] | 124 | pci_s_write_config32(cr2_dev, PCU_CR2_PKG_CST_ENTRY_CRITERIA_MASK, data); |
Marc Jones | 645bca4 | 2020-11-02 14:29:46 -0700 | [diff] [blame] | 125 | |
| 126 | data = KTI_IN_PKGCSTATE_L1_MASK; |
Nico Huber | f4f365f | 2021-10-14 18:16:39 +0200 | [diff] [blame] | 127 | pci_s_write_config32(cr2_dev, PCU_CR2_PKG_CST_ENTRY_CRITERIA_MASK2, data); |
Marc Jones | 645bca4 | 2020-11-02 14:29:46 -0700 | [diff] [blame] | 128 | |
| 129 | data = PROCHOT_RATIO; |
| 130 | printk(BIOS_SPEW, "PCU_CR2_PROCHOT_RESPONSE_RATIO_REG data: 0x%x\n", data); |
Nico Huber | f4f365f | 2021-10-14 18:16:39 +0200 | [diff] [blame] | 131 | pci_s_write_config32(cr2_dev, PCU_CR2_PROCHOT_RESPONSE_RATIO_REG, data); |
Marc Jones | 645bca4 | 2020-11-02 14:29:46 -0700 | [diff] [blame] | 132 | dump_csr("", cr2_dev, PCU_CR2_PROCHOT_RESPONSE_RATIO_REG); |
| 133 | |
Nico Huber | f4f365f | 2021-10-14 18:16:39 +0200 | [diff] [blame] | 134 | data = pci_s_read_config32(cr2_dev, PCU_CR2_DYNAMIC_PERF_POWER_CTL); |
Marc Jones | 645bca4 | 2020-11-02 14:29:46 -0700 | [diff] [blame] | 135 | data |= UNOCRE_PLIMIT_OVERRIDE_SHIFT; |
Nico Huber | f4f365f | 2021-10-14 18:16:39 +0200 | [diff] [blame] | 136 | pci_s_write_config32(cr2_dev, PCU_CR2_DYNAMIC_PERF_POWER_CTL, data); |
Jonathan Zhang | 8f89549 | 2020-01-16 11:16:45 -0800 | [diff] [blame] | 137 | } |
Marc Jones | e1db55b | 2020-09-28 16:53:19 -0600 | [diff] [blame] | 138 | } |
Jonathan Zhang | 8f89549 | 2020-01-16 11:16:45 -0800 | [diff] [blame] | 139 | |
Marc Jones | 995a7e2 | 2020-10-28 17:08:54 -0600 | [diff] [blame] | 140 | /* |
| 141 | * EX: SKX-SP |
| 142 | * Ports Stack Stack(HOB) IioConfigIou |
| 143 | * ========================================== |
| 144 | * 0 CSTACK stack 0 IOU0 |
| 145 | * 1A..1D PSTACKZ stack 1 IOU1 |
| 146 | * 2A..2D PSTACK1 stack 2 IOU2 |
| 147 | * 3A..3D PSTACK2 stack 3 IOU3 |
| 148 | * 5A..4D PSTACK3 stack 4 IOU4 |
| 149 | * 5A..5D PSTACK4 stack 5 IOU5 |
| 150 | */ |
| 151 | int soc_get_stack_for_port(int port) |
| 152 | { |
| 153 | if (port == PORT_0) |
| 154 | return CSTACK; |
| 155 | else if (port >= PORT_1A && port <= PORT_1D) |
| 156 | return PSTACK0; |
| 157 | else if (port >= PORT_2A && port <= PORT_2D) |
| 158 | return PSTACK1; |
| 159 | else if (port >= PORT_3A && port <= PORT_3D) |
| 160 | return PSTACK2; |
| 161 | else if (port >= PORT_4A && port <= PORT_4D) |
| 162 | return PSTACK3; // MCP0 |
| 163 | else if (port >= PORT_5A && port <= PORT_5D) |
| 164 | return PSTACK4; // MCP1 |
| 165 | else |
| 166 | return -1; |
| 167 | } |
Arthur Heymans | a1cc557 | 2020-11-06 12:53:33 +0100 | [diff] [blame] | 168 | |
| 169 | uint8_t soc_get_iio_ioapicid(int socket, int stack) |
| 170 | { |
| 171 | uint8_t ioapic_id = socket ? 0xf : 0x9; |
| 172 | switch (stack) { |
| 173 | case CSTACK: |
| 174 | break; |
| 175 | case PSTACK0: |
| 176 | ioapic_id += 1; |
| 177 | break; |
| 178 | case PSTACK1: |
| 179 | ioapic_id += 2; |
| 180 | break; |
| 181 | case PSTACK2: |
| 182 | ioapic_id += 3; |
| 183 | break; |
| 184 | default: |
| 185 | return 0xff; |
| 186 | } |
| 187 | return ioapic_id; |
| 188 | } |