/* SPDX-License-Identifier: GPL-2.0-only */ #include <bootblock_common.h> #include <device/pci_ops.h> #include <northbridge/intel/sandybridge/sandybridge.h> #include <superio/ite/common/ite.h> #include <superio/ite/it8772f/it8772f.h> #define GPIO_DEV PNP_DEV(0x2e, IT8772F_GPIO) #define MOUSE_DEV PNP_DEV(0x2e, IT8772F_KBCM) #define EC_DEV PNP_DEV(0x2e, IT8772F_EC) void bootblock_mainboard_early_init(void) { pci_write_config16(PCI_DEV(0, 0x1f, 0), 0x82, 0x3f0e); pci_write_config16(PCI_DEV(0, 0x1f, 0), 0x80, 0x0010); /* Set up GPIOs on Super I/O. */ ite_ac_resume_southbridge(EC_DEV); ite_reg_write(MOUSE_DEV, 0x30, 0x00); // PS/2 Mouse disable ite_reg_write(EC_DEV, 0x30, 0x01); // Environment controller activate ite_reg_write(EC_DEV, 0x60, 0x0a); // Environment controller MSB Register Base Address ite_reg_write(EC_DEV, 0x61, 0x30); // Environment controller LSB Register Base Address ite_reg_write(EC_DEV, 0x62, 0x0a); // PME Direct Access MSB Register Base Address ite_reg_write(EC_DEV, 0x63, 0x20); // PME Direct Access LSB Register Base Address ite_reg_write(GPIO_DEV, 0x25, 0x00); // GPIO Set 1 ite_reg_write(GPIO_DEV, 0x26, 0xfc); // GPIO Set 2, Enable pin 7 and 8 to GPIO ite_reg_write(GPIO_DEV, 0x27, 0x00); // GPIO Set 3 ite_reg_write(GPIO_DEV, 0x28, 0x00); // GPIO Set 4 ite_reg_write(GPIO_DEV, 0x29, 0x00); // GPIO Set 5 and 6 ite_reg_write(GPIO_DEV, 0x2a, 0x00); // Special function 1 ite_reg_write(GPIO_DEV, 0x2b, 0x00); // Special function 2 ite_reg_write(GPIO_DEV, 0x2c, 0x03); // Special function 3 ite_reg_write(GPIO_DEV, 0x60, 0x0a); // SMI MSB Register Base Address ite_reg_write(GPIO_DEV, 0x62, 0x0a); // Simple I/O MSB Register Base Address ite_reg_write(GPIO_DEV, 0xb0, 0x00); // Pin set 1 polarity registers ite_reg_write(GPIO_DEV, 0xb1, 0x00); // Pin set 2 polarity registers ite_reg_write(GPIO_DEV, 0xb2, 0x00); // Pin set 3 polarity registers ite_reg_write(GPIO_DEV, 0xb3, 0x00); // Pin set 4 polarity registers ite_reg_write(GPIO_DEV, 0xb4, 0x00); // Pin set 5 polarity registers ite_reg_write(GPIO_DEV, 0xb8, 0x00); // Pin set 1 int pull-up disable ite_reg_write(GPIO_DEV, 0xb9, 0x00); // Pin set 1 int pull-up disable ite_reg_write(GPIO_DEV, 0xba, 0x00); // Pin set 1 int pull-up disable ite_reg_write(GPIO_DEV, 0xbb, 0x00); // Pin set 1 int pull-up disable ite_reg_write(GPIO_DEV, 0xbc, 0x00); // Pin set 1 int pull-up disable ite_reg_write(GPIO_DEV, 0xbd, 0x00); // Pin set 1 int pull-up disable ite_reg_write(GPIO_DEV, 0xc0, 0x01); // Set Simple I/O functions on SI/O Set 1 ite_reg_write(GPIO_DEV, 0xc1, 0x0c); // Set Simple I/O functions on SI/O Set 2 ite_reg_write(GPIO_DEV, 0xc2, 0x00); // Set Simple I/O functions on SI/O Set 3 ite_reg_write(GPIO_DEV, 0xc3, 0x40); // Set Simple I/O functions on SI/O Set 4 ite_reg_write(GPIO_DEV, 0xc4, 0x00); // Set Simple I/O functions on SI/O Set 5 ite_reg_write(GPIO_DEV, 0xc8, 0x01); // Set Simple I/O Output on SI/O Set 1 ite_reg_write(GPIO_DEV, 0xc9, 0x0c); // Set Simple I/O Output on SI/O Set 2 ite_reg_write(GPIO_DEV, 0xca, 0x00); // Set Simple I/O Output on SI/O Set 3 ite_reg_write(GPIO_DEV, 0xcb, 0x40); // Set Simple I/O Output on SI/O Set 4 ite_reg_write(GPIO_DEV, 0xcc, 0x00); // Set Simple I/O Output on SI/O Set 5 ite_reg_write(GPIO_DEV, 0xcd, 0x00); // Set Simple I/O Output on SI/O Set 6 ite_reg_write(GPIO_DEV, 0xe9, 0x07); // GPIO Bus Select Control Register ite_reg_write(GPIO_DEV, 0xf6, 0x00); // Hardware Monitor Alert Beep Pin Mapping Register }