Angel Pons | d32b6de | 2020-04-03 01:23:13 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-only */ |
Stefan Reinauer | e1ae4b2 | 2012-04-27 23:20:58 +0200 | [diff] [blame] | 2 | |
Furquan Shaikh | 76cedd2 | 2020-05-02 10:24:23 -0700 | [diff] [blame] | 3 | #include <acpi/acpi.h> |
Stefan Reinauer | e1ae4b2 | 2012-04-27 23:20:58 +0200 | [diff] [blame] | 4 | #include <console/console.h> |
| 5 | #include <cpu/x86/smm.h> |
Stefan Reinauer | e1ae4b2 | 2012-04-27 23:20:58 +0200 | [diff] [blame] | 6 | #include <southbridge/intel/bd82x6x/pch.h> |
| 7 | #include <southbridge/intel/bd82x6x/me.h> |
| 8 | #include <northbridge/intel/sandybridge/sandybridge.h> |
Stefan Reinauer | e1ae4b2 | 2012-04-27 23:20:58 +0200 | [diff] [blame] | 9 | |
david | 80ef7b7 | 2015-01-19 17:11:36 +0800 | [diff] [blame] | 10 | /* Include for SIO helper functions */ |
| 11 | #include <superio/ite/it8772f/it8772f.h> |
Joel Linn | fb51661 | 2024-03-29 14:08:35 +0100 | [diff] [blame^] | 12 | #define GPIO_DEV PNP_DEV(0x2e, IT8772F_GPIO) |
Stefan Reinauer | e1ae4b2 | 2012-04-27 23:20:58 +0200 | [diff] [blame] | 13 | |
Stefan Reinauer | e1ae4b2 | 2012-04-27 23:20:58 +0200 | [diff] [blame] | 14 | /* |
| 15 | * Change LED_POWER# (SIO GPIO 45) state based on sleep type. |
david | 80ef7b7 | 2015-01-19 17:11:36 +0800 | [diff] [blame] | 16 | */ |
Stefan Reinauer | e1ae4b2 | 2012-04-27 23:20:58 +0200 | [diff] [blame] | 17 | void mainboard_smi_sleep(u8 slp_typ) |
| 18 | { |
david | 80ef7b7 | 2015-01-19 17:11:36 +0800 | [diff] [blame] | 19 | printk(BIOS_DEBUG, "SMI: sleep S%d\n", slp_typ); |
Stefan Reinauer | e1ae4b2 | 2012-04-27 23:20:58 +0200 | [diff] [blame] | 20 | switch (slp_typ) { |
Aaron Durbin | 30b0c7a | 2016-07-13 13:01:13 -0500 | [diff] [blame] | 21 | case ACPI_S3: |
| 22 | case ACPI_S4: |
Joel Linn | fb51661 | 2024-03-29 14:08:35 +0100 | [diff] [blame^] | 23 | it8772f_gpio_led(GPIO_DEV, 4 /* set */, (0x1 << 5) /* select */, |
Elyes HAOUAS | a5aad2e | 2016-09-19 09:47:16 -0600 | [diff] [blame] | 24 | (0x1 << 5) /* polarity */, (0x1 << 5) /* 1 = pullup */, |
| 25 | (0x1 << 5) /* output */, 0x00, /* 0 = Alternate function */ |
david | 80ef7b7 | 2015-01-19 17:11:36 +0800 | [diff] [blame] | 26 | SIO_GPIO_BLINK_GPIO45, IT8772F_GPIO_BLINK_FREQUENCY_1_HZ); |
Stefan Reinauer | e1ae4b2 | 2012-04-27 23:20:58 +0200 | [diff] [blame] | 27 | break; |
| 28 | |
Aaron Durbin | 30b0c7a | 2016-07-13 13:01:13 -0500 | [diff] [blame] | 29 | case ACPI_S5: |
Joel Linn | fb51661 | 2024-03-29 14:08:35 +0100 | [diff] [blame^] | 30 | it8772f_gpio_led(GPIO_DEV, 4 /* set */, (0x1 << 5) /* select */, |
Elyes HAOUAS | a5aad2e | 2016-09-19 09:47:16 -0600 | [diff] [blame] | 31 | 0x00 /* polarity: non-inverting */, 0x00 /* 0 = pulldown */, |
| 32 | (0x1 << 5) /* output */, (0x1 << 5) /* 1 = Simple IO function */, |
david | 80ef7b7 | 2015-01-19 17:11:36 +0800 | [diff] [blame] | 33 | SIO_GPIO_BLINK_GPIO45, IT8772F_GPIO_BLINK_FREQUENCY_1_HZ); |
| 34 | break; |
| 35 | default: |
Stefan Reinauer | e1ae4b2 | 2012-04-27 23:20:58 +0200 | [diff] [blame] | 36 | break; |
| 37 | } |
| 38 | } |