Angel Pons | 89ab250 | 2020-04-03 01:22:28 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-only */ |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 2 | |
Kyösti Mälkki | f1b58b7 | 2019-03-01 13:43:02 +0200 | [diff] [blame] | 3 | #include <device/pci_ops.h> |
Furquan Shaikh | 76cedd2 | 2020-05-02 10:24:23 -0700 | [diff] [blame] | 4 | #include <acpi/acpi.h> |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 5 | #include <cpu/x86/smm.h> |
Elyes HAOUAS | 26071aa | 2019-02-15 08:21:33 +0100 | [diff] [blame] | 6 | #include <version.h> |
Angel Pons | 547fe82 | 2020-06-21 16:03:07 +0200 | [diff] [blame] | 7 | #include <southbridge/intel/common/pmutil.h> |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 8 | |
Kyösti Mälkki | 64e07eb | 2020-05-30 14:50:50 +0300 | [diff] [blame] | 9 | void acpi_fill_fadt(acpi_fadt_t *fadt) |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 10 | { |
Kyösti Mälkki | c70eed1 | 2018-05-22 02:18:00 +0300 | [diff] [blame] | 11 | u16 pmbase = pci_read_config16(pcidev_on_root(0x1f, 0), 0x40) & 0xfffe; |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 12 | |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 13 | fadt->sci_int = 0x9; |
Kyösti Mälkki | 9145ce2 | 2019-11-23 07:23:40 +0200 | [diff] [blame] | 14 | |
Kyösti Mälkki | 0a9e72e | 2019-08-11 01:22:28 +0300 | [diff] [blame] | 15 | if (permanent_smi_handler()) { |
Kyösti Mälkki | 9145ce2 | 2019-11-23 07:23:40 +0200 | [diff] [blame] | 16 | fadt->smi_cmd = APM_CNT; |
| 17 | fadt->acpi_enable = APM_CNT_ACPI_ENABLE; |
| 18 | fadt->acpi_disable = APM_CNT_ACPI_DISABLE; |
Kyösti Mälkki | 9145ce2 | 2019-11-23 07:23:40 +0200 | [diff] [blame] | 19 | } |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 20 | |
| 21 | fadt->pm1a_evt_blk = pmbase; |
Angel Pons | 547fe82 | 2020-06-21 16:03:07 +0200 | [diff] [blame] | 22 | fadt->pm1a_cnt_blk = pmbase + PM1_CNT; |
Angel Pons | 547fe82 | 2020-06-21 16:03:07 +0200 | [diff] [blame] | 23 | fadt->pm2_cnt_blk = pmbase + PM2_CNT; |
| 24 | fadt->pm_tmr_blk = pmbase + PM1_TMR; |
| 25 | fadt->gpe0_blk = pmbase + GPE0_STS; |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 26 | |
| 27 | fadt->pm1_evt_len = 4; |
| 28 | fadt->pm1_cnt_len = 2; /* Upper word is reserved and |
| 29 | Linux complains about 32 bit. */ |
| 30 | fadt->pm2_cnt_len = 1; |
| 31 | fadt->pm_tmr_len = 4; |
| 32 | fadt->gpe0_blk_len = 16; |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 33 | fadt->p_lvl2_lat = 1; |
| 34 | fadt->p_lvl3_lat = 0x39; |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 35 | fadt->duty_offset = 1; |
| 36 | fadt->duty_width = 3; |
| 37 | fadt->day_alrm = 0xd; |
| 38 | fadt->mon_alrm = 0x00; |
Paul Menzel | 8ca2af1 | 2019-02-08 15:19:20 +0100 | [diff] [blame] | 39 | fadt->iapc_boot_arch = ACPI_FADT_LEGACY_FREE; |
Angel Pons | a208c6c | 2020-07-13 00:02:34 +0200 | [diff] [blame] | 40 | fadt->flags |= ACPI_FADT_WBINVD | ACPI_FADT_C1_SUPPORTED | |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 41 | ACPI_FADT_SLEEP_BUTTON | ACPI_FADT_S4_RTC_WAKE | |
Angel Pons | 79572e4 | 2020-07-13 00:17:43 +0200 | [diff] [blame] | 42 | ACPI_FADT_DOCKING_SUPPORTED | ACPI_FADT_PLATFORM_CLOCK; |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 43 | |
Angel Pons | 013711b | 2020-06-21 18:31:30 +0200 | [diff] [blame] | 44 | fadt->x_pm1a_evt_blk.space_id = ACPI_ADDRESS_SPACE_IO; |
Elyes Haouas | a6e05382 | 2022-10-11 12:55:36 +0200 | [diff] [blame] | 45 | fadt->x_pm1a_evt_blk.bit_width = fadt->pm1_evt_len * 8; |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 46 | fadt->x_pm1a_evt_blk.bit_offset = 0; |
Angel Pons | 12a4d05 | 2020-07-14 01:31:27 +0200 | [diff] [blame] | 47 | fadt->x_pm1a_evt_blk.access_size = ACPI_ACCESS_SIZE_WORD_ACCESS; |
Felix Held | 769b657 | 2022-10-14 18:32:52 +0200 | [diff] [blame] | 48 | fadt->x_pm1a_evt_blk.addrl = fadt->pm1a_evt_blk; |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 49 | fadt->x_pm1a_evt_blk.addrh = 0x0; |
| 50 | |
Angel Pons | 013711b | 2020-06-21 18:31:30 +0200 | [diff] [blame] | 51 | fadt->x_pm1a_cnt_blk.space_id = ACPI_ADDRESS_SPACE_IO; |
Elyes Haouas | 7008085 | 2022-10-11 13:09:35 +0200 | [diff] [blame] | 52 | fadt->x_pm1a_cnt_blk.bit_width = fadt->pm1_cnt_len * 8; |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 53 | fadt->x_pm1a_cnt_blk.bit_offset = 0; |
Patrick Rudolph | c02bda0 | 2020-02-28 10:19:41 +0100 | [diff] [blame] | 54 | fadt->x_pm1a_cnt_blk.access_size = ACPI_ACCESS_SIZE_WORD_ACCESS; |
Elyes Haouas | c60f3b2 | 2022-10-11 14:02:27 +0200 | [diff] [blame] | 55 | fadt->x_pm1a_cnt_blk.addrl = fadt->pm1a_cnt_blk; |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 56 | fadt->x_pm1a_cnt_blk.addrh = 0x0; |
| 57 | |
Angel Pons | 013711b | 2020-06-21 18:31:30 +0200 | [diff] [blame] | 58 | fadt->x_pm2_cnt_blk.space_id = ACPI_ADDRESS_SPACE_IO; |
Elyes Haouas | 85f87e8 | 2022-10-11 13:45:44 +0200 | [diff] [blame] | 59 | fadt->x_pm2_cnt_blk.bit_width = fadt->pm2_cnt_len * 8; |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 60 | fadt->x_pm2_cnt_blk.bit_offset = 0; |
Patrick Rudolph | c02bda0 | 2020-02-28 10:19:41 +0100 | [diff] [blame] | 61 | fadt->x_pm2_cnt_blk.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS; |
Felix Held | 96fa237 | 2022-10-14 18:41:03 +0200 | [diff] [blame] | 62 | fadt->x_pm2_cnt_blk.addrl = fadt->pm2_cnt_blk; |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 63 | fadt->x_pm2_cnt_blk.addrh = 0x0; |
| 64 | |
Angel Pons | 013711b | 2020-06-21 18:31:30 +0200 | [diff] [blame] | 65 | fadt->x_pm_tmr_blk.space_id = ACPI_ADDRESS_SPACE_IO; |
Elyes Haouas | 501b71e | 2022-10-11 13:15:37 +0200 | [diff] [blame] | 66 | fadt->x_pm_tmr_blk.bit_width = fadt->pm_tmr_len * 8; |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 67 | fadt->x_pm_tmr_blk.bit_offset = 0; |
Patrick Rudolph | c02bda0 | 2020-02-28 10:19:41 +0100 | [diff] [blame] | 68 | fadt->x_pm_tmr_blk.access_size = ACPI_ACCESS_SIZE_DWORD_ACCESS; |
Elyes Haouas | 987f1f4 | 2022-10-11 13:56:30 +0200 | [diff] [blame] | 69 | fadt->x_pm_tmr_blk.addrl = fadt->pm_tmr_blk; |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 70 | fadt->x_pm_tmr_blk.addrh = 0x0; |
| 71 | |
Angel Pons | 013711b | 2020-06-21 18:31:30 +0200 | [diff] [blame] | 72 | fadt->x_gpe0_blk.space_id = ACPI_ADDRESS_SPACE_IO; |
Elyes Haouas | baec560 | 2022-10-11 13:20:43 +0200 | [diff] [blame] | 73 | fadt->x_gpe0_blk.bit_width = fadt->gpe0_blk_len * 8; |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 74 | fadt->x_gpe0_blk.bit_offset = 0; |
Patrick Rudolph | c02bda0 | 2020-02-28 10:19:41 +0100 | [diff] [blame] | 75 | fadt->x_gpe0_blk.access_size = ACPI_ACCESS_SIZE_BYTE_ACCESS; |
Elyes Haouas | c929f09 | 2022-10-11 13:40:51 +0200 | [diff] [blame] | 76 | fadt->x_gpe0_blk.addrl = fadt->gpe0_blk; |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 77 | fadt->x_gpe0_blk.addrh = 0x0; |
Timothy Pearson | 4b373c9 | 2015-04-05 17:54:08 -0500 | [diff] [blame] | 78 | } |